Files
EdgeNode/internal/nodes/task_sync_api_nodes.go

129 lines
2.6 KiB
Go
Raw Normal View History

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"
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"
"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() {
if !teaconst.IsMain {
return
}
2021-02-24 11:01:06 +08:00
events.On(events.EventStart, func() {
goman.New(func() {
2022-01-12 20:31:04 +08:00
sharedSyncAPINodesTask.Start()
})
2021-02-24 11:01:06 +08:00
})
events.OnClose(func() {
2022-01-12 20:31:04 +08:00
sharedSyncAPINodesTask.Stop()
})
2021-02-24 11:01:06 +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 {
// 如果有节点定制的API节点地址
var hasCustomizedAPINodeAddrs = sharedNodeConfig != nil && len(sharedNodeConfig.APINodeAddrs) > 0
config, err := configs.LoadAPIConfig()
if err != nil {
return err
}
// 是否禁止自动升级
2023-08-12 15:08:22 +08:00
if config.RPCDisableUpdate {
return nil
}
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
}
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
}
// 测试是否有API节点可用
var hasOk = rpcClient.TestEndpoints(newEndpoints)
if !hasOk {
return nil
}
2021-02-24 11:01:06 +08:00
// 修改RPC对象配置
2023-08-12 15:08:22 +08:00
config.RPCEndpoints = newEndpoints
// 更新当前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
}