2021-02-24 11:01:06 +08:00
|
|
|
package nodes
|
|
|
|
|
|
|
|
|
|
import (
|
2024-07-27 15:42:50 +08:00
|
|
|
"time"
|
|
|
|
|
|
2021-02-24 11:01:06 +08:00
|
|
|
"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
|
|
|
|
|
"github.com/TeaOSLab/EdgeNode/internal/configs"
|
2023-03-10 15:14:14 +08:00
|
|
|
teaconst "github.com/TeaOSLab/EdgeNode/internal/const"
|
2021-02-24 11:01:06 +08:00
|
|
|
"github.com/TeaOSLab/EdgeNode/internal/events"
|
|
|
|
|
"github.com/TeaOSLab/EdgeNode/internal/rpc"
|
2022-11-21 19:55:28 +08:00
|
|
|
"github.com/TeaOSLab/EdgeNode/internal/utils"
|
2024-05-11 09:23:54 +08:00
|
|
|
"github.com/TeaOSLab/EdgeNode/internal/utils/goman"
|
|
|
|
|
"github.com/TeaOSLab/EdgeNode/internal/utils/trackers"
|
2021-02-24 11:01:06 +08:00
|
|
|
"github.com/iwind/TeaGo/Tea"
|
|
|
|
|
"github.com/iwind/TeaGo/logs"
|
|
|
|
|
)
|
|
|
|
|
|
2022-01-12 20:31:04 +08:00
|
|
|
var sharedSyncAPINodesTask = NewSyncAPINodesTask()
|
|
|
|
|
|
2021-02-24 11:01:06 +08:00
|
|
|
func init() {
|
2023-03-10 15:14:14 +08:00
|
|
|
if !teaconst.IsMain {
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
|
2021-02-24 11:01:06 +08:00
|
|
|
events.On(events.EventStart, func() {
|
2021-12-08 15:17:45 +08:00
|
|
|
goman.New(func() {
|
2022-01-12 20:31:04 +08:00
|
|
|
sharedSyncAPINodesTask.Start()
|
2021-12-08 15:17:45 +08:00
|
|
|
})
|
2021-02-24 11:01:06 +08:00
|
|
|
})
|
2023-06-23 17:45:39 +08:00
|
|
|
events.OnClose(func() {
|
2022-01-12 20:31:04 +08:00
|
|
|
sharedSyncAPINodesTask.Stop()
|
|
|
|
|
})
|
2021-02-24 11:01:06 +08:00
|
|
|
}
|
|
|
|
|
|
2021-07-20 18:17:25 +08:00
|
|
|
// SyncAPINodesTask API节点同步任务
|
2021-02-24 11:01:06 +08:00
|
|
|
type SyncAPINodesTask struct {
|
2022-01-12 20:31:04 +08:00
|
|
|
ticker *time.Ticker
|
2021-02-24 11:01:06 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func NewSyncAPINodesTask() *SyncAPINodesTask {
|
|
|
|
|
return &SyncAPINodesTask{}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (this *SyncAPINodesTask) Start() {
|
2022-01-12 20:31:04 +08:00
|
|
|
this.ticker = time.NewTicker(5 * time.Minute)
|
2021-02-24 11:01:06 +08:00
|
|
|
if Tea.IsTesting() {
|
|
|
|
|
// 快速测试
|
2022-01-12 20:31:04 +08:00
|
|
|
this.ticker = time.NewTicker(1 * time.Minute)
|
2021-02-24 11:01:06 +08:00
|
|
|
}
|
2022-01-12 20:31:04 +08:00
|
|
|
for range this.ticker.C {
|
2021-02-24 11:01:06 +08:00
|
|
|
err := this.Loop()
|
|
|
|
|
if err != nil {
|
|
|
|
|
logs.Println("[TASK][SYNC_API_NODES_TASK]" + err.Error())
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2022-01-12 20:31:04 +08:00
|
|
|
func (this *SyncAPINodesTask) Stop() {
|
|
|
|
|
if this.ticker != nil {
|
|
|
|
|
this.ticker.Stop()
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2021-02-24 11:01:06 +08:00
|
|
|
func (this *SyncAPINodesTask) Loop() error {
|
2022-11-21 19:55:28 +08:00
|
|
|
// 如果有节点定制的API节点地址
|
|
|
|
|
var hasCustomizedAPINodeAddrs = sharedNodeConfig != nil && len(sharedNodeConfig.APINodeAddrs) > 0
|
|
|
|
|
|
2022-07-21 14:06:38 +08:00
|
|
|
config, err := configs.LoadAPIConfig()
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 是否禁止自动升级
|
2023-08-12 15:08:22 +08:00
|
|
|
if config.RPCDisableUpdate {
|
2022-07-21 14:06:38 +08:00
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
|
2021-11-14 10:55:09 +08:00
|
|
|
var tr = trackers.Begin("SYNC_API_NODES")
|
|
|
|
|
defer tr.End()
|
|
|
|
|
|
2021-02-24 11:01:06 +08:00
|
|
|
// 获取所有可用的节点
|
|
|
|
|
rpcClient, err := rpc.SharedRPC()
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
2022-08-24 20:04:46 +08:00
|
|
|
resp, err := rpcClient.APINodeRPC.FindAllEnabledAPINodes(rpcClient.Context(), &pb.FindAllEnabledAPINodesRequest{})
|
2021-02-24 11:01:06 +08:00
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
2022-07-21 14:06:38 +08:00
|
|
|
var newEndpoints = []string{}
|
2021-11-05 15:37:07 +08:00
|
|
|
for _, node := range resp.ApiNodes {
|
2021-02-24 11:01:06 +08:00
|
|
|
if !node.IsOn {
|
|
|
|
|
continue
|
|
|
|
|
}
|
|
|
|
|
newEndpoints = append(newEndpoints, node.AccessAddrs...)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 和现有的对比
|
2023-08-12 15:08:22 +08:00
|
|
|
if utils.EqualStrings(newEndpoints, config.RPCEndpoints) {
|
2021-02-24 11:01:06 +08:00
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
|
2021-07-20 18:17:25 +08:00
|
|
|
// 测试是否有API节点可用
|
2022-11-21 19:55:28 +08:00
|
|
|
var hasOk = rpcClient.TestEndpoints(newEndpoints)
|
2021-07-20 18:17:25 +08:00
|
|
|
if !hasOk {
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
|
2021-02-24 11:01:06 +08:00
|
|
|
// 修改RPC对象配置
|
2023-08-12 15:08:22 +08:00
|
|
|
config.RPCEndpoints = newEndpoints
|
2022-11-21 19:55:28 +08:00
|
|
|
|
|
|
|
|
// 更新当前RPC
|
|
|
|
|
if !hasCustomizedAPINodeAddrs {
|
|
|
|
|
err = rpcClient.UpdateConfig(config)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
2021-02-24 11:01:06 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 保存到文件
|
2023-08-12 15:08:22 +08:00
|
|
|
err = config.WriteFile(Tea.ConfigFile(configs.ConfigFileName))
|
2021-02-24 11:01:06 +08:00
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return nil
|
|
|
|
|
}
|