/
use_config.go
49 lines (41 loc) · 1007 Bytes
/
use_config.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
package cluster
import (
"github.com/bytedance/Elkeid/server/service_discovery/common"
"github.com/bytedance/Elkeid/server/service_discovery/common/safemap"
"github.com/bytedance/Elkeid/server/service_discovery/common/ylog"
"time"
)
type ConfigCluster struct {
BaseCluster
}
func NewConfigCluster(host string) Cluster {
cc := &ConfigCluster{BaseCluster{
Mode: configMode,
Host: host,
Members: safemap.NewSafeMap(defaultClusterName),
Done: make(chan bool),
}}
go cc.refresh()
go cc.ping()
return cc
}
func (cc *ConfigCluster) refresh() {
t := time.NewTicker(10 * time.Second)
defer t.Stop()
for {
select {
case changed := <-common.ConfigChangeNotify:
if changed {
members := common.V.GetStringSlice("Cluster.Members")
cc.Members.Del(defaultClusterName)
for _, host := range members {
cc.Members.HSet(defaultClusterName, host, "ok")
}
}
case <-t.C:
case <-cc.Done:
ylog.Debugf("refresh", "cluster refesh strop\n")
return
}
}
}