| | |
| | | |
| | | // create serf agent with serf config |
| | | logger.Info("conf.Config.EncryptKey:", conf.EncryptKey) |
| | | serfAgent, err := agent.Create(conf.Config, serfConf, nil) |
| | | serfAgent, err := agent.Create(conf.Config, serfConf, logger.GetLogFile()) |
| | | if err != nil { |
| | | return nil, err |
| | | } |
| | |
| | | switch ev := event.(type) { |
| | | case serf.UserEvent: |
| | | if ev.Name == UserEventSyncSql { |
| | | logger.Info("receive a UserEventSyncSql event") |
| | | var sqlUe SqlUserEvent |
| | | err := json.Unmarshal(ev.Payload, &sqlUe) |
| | | if err !=nil { |
| | | logger.Error("sqlUe unmarshal err:",err) |
| | | return |
| | | } |
| | | |
| | | logger.Info("ev.LTime:", ev.LTime ,"owner:", sqlUe.Owner, "sql:", sqlUe.Sql) |
| | | |
| | | if sqlUe.Owner != a.conf.NodeName { |
| | | |
| | | flag, e := ExecuteSqlByGorm(sqlUe.Sql) |
| | | |
| | | evTime := uint64(ev.LTime) |
| | | logger.Info("ev.LTime:",evTime,"userEvent exec ",sqlUe.Sql,",Result:",flag,", err:",e) |
| | | go func() { |
| | | flag, e := ExecuteSqlByGorm(sqlUe.Sql) |
| | | logger.Info("ev.LTime:",ev.LTime,"userEvent exec ",sqlUe.Sql,",Result:",flag,", err:",e) |
| | | }() |
| | | } |
| | | } else if ev.Name == UserEventSyncDbTablePersonCache { |
| | | logger.Info("LTime:",ev.LTime,",ev.Payload.len:",len(ev.Payload)) |
| | |
| | | //for _, r := range rows { |
| | | // rowsReturn = append(rowsReturn, *r) |
| | | //} |
| | | logger.Info("receive QueryEventUpdateDBData, current node:", a.conf.NodeName) |
| | | var fromP QueryTableDataParam |
| | | err := json.Unmarshal(ev.Payload, &fromP) |
| | | if err !=nil { |
| | | logger.Error("Query tableNames unmarshal err") |
| | | if query, ok := event.(*serf.Query); ok { |
| | | if err := query.Respond([]byte("request unmarshal err")); err != nil { |
| | | logger.Error("query.Respond err: %s\n", err) |
| | | return |
| | | } |
| | | } |
| | | return |
| | | } |
| | | logger.Info("Query tableNames:",fromP.Tables) |
| | | datas, err := ExecuteQueryByGorm(fromP.Tables) |
| | | if err !=nil { |
| | | logger.Error("queryByGorm err") |
| | | logger.Error("queryByGorm err:", err) |
| | | if query, ok := event.(*serf.Query); ok { |
| | | if err := query.Respond([]byte("queryByGorm err")); err != nil { |
| | | logger.Error("query.Respond err: %s\n", err) |
| | | return |
| | | } |
| | | } |
| | | return |
| | | } |
| | | bytesReturn, err := json.Marshal(datas) |
| | |
| | | } |
| | | logger.Debug("targetNode:",targetNode.Name) |
| | | if targetNode !=nil { |
| | | addr := targetNode.Addr.String() + ":" + strconv.Itoa(TcpTransportPort) |
| | | sendErr := rawSendTcpMsg(addr, bytesReturn) |
| | | go func() { |
| | | addr := targetNode.Addr.String() + ":" + strconv.Itoa(TcpTransportPort) |
| | | sendErr := rawSendTcpMsg(addr, bytesReturn) |
| | | |
| | | if sendErr != nil { |
| | | logger.Debug("sendToTcp err:",sendErr) |
| | | } else { |
| | | logger.Debug("sendToTcp success") |
| | | } |
| | | |
| | | if sendErr != nil { |
| | | logger.Debug("sendToTcp err:",sendErr) |
| | | } else { |
| | | logger.Debug("sendToTcp success") |
| | | } |
| | | }() |
| | | } else { |
| | | logger.Debug("targetNode is nil") |
| | | } |
| | |
| | | var QueryTcpResponseChan = make(chan []byte) |
| | | //GetDbFromCluster get the newest database after join cluster |
| | | //dbPathWrite the path where to write after got a database, |
| | | func (a *Agent) GetTableDataFromCluster(tableNames []string) (*[]string,error) { |
| | | func (a *Agent) GetTableDataFromCluster(tableNames []string, timeout time.Duration) (*[]string,error) { |
| | | //members: get name of first member |
| | | mbs := a.GroupMembers(a.conf.ClusterID) |
| | | var specmembername string |
| | |
| | | } |
| | | } |
| | | logger.Info("mbs:",mbs,"a.conf.BindAddr:",a.conf.BindAddr,"specmembername:",specmembername) |
| | | if specmembername == "" {//如果未找到目标节点,说明当前集群内除了本节点,没有其他可用节点 |
| | | return nil,errors.New("specmembername not found") |
| | | } |
| | | |
| | | //query: get db file. |
| | | params := serf.QueryParam{ |
| | |
| | | |
| | | var wg sync.WaitGroup |
| | | wg.Add(1) |
| | | ticker := time.NewTicker(300*time.Second) |
| | | ticker := time.NewTicker(timeout) |
| | | go func(tk *time.Ticker) { |
| | | defer tk.Stop() |
| | | defer wg.Done() |