6 log "github.com/sirupsen/logrus"
8 "github.com/vapor/p2p/discover/dht"
9 "github.com/vapor/toolbar/precog/config"
17 func (m *monitor) discoveryRoutine() {
18 ticker := time.NewTicker(time.Duration(discvFreqSec) * time.Second)
22 nodes := make([]*dht.Node, nodesToDiscv)
23 num := m.sw.GetDiscv().ReadRandomNodes(nodes)
24 for _, node := range nodes[:num] {
25 if n, ok := m.discvMap[node.ID.String()]; ok && n.String() == node.String() {
29 log.WithFields(log.Fields{"new node": node}).Info("discover")
31 if err := m.upSertNode(&config.Node{
32 PublicKey: node.ID.String(),
36 log.WithFields(log.Fields{"node": node, "err": err}).Error("upSertNode")
38 m.discvMap[node.ID.String()] = node