前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >聊聊nacos的ServerChangeListener

聊聊nacos的ServerChangeListener

原创
作者头像
code4it
修改2019-10-08 10:47:12
4700
修改2019-10-08 10:47:12
举报
文章被收录于专栏:码匠的流水账

本文主要研究一下nacos的ServerChangeListener

ServerChangeListener

nacos-1.1.3/naming/src/main/java/com/alibaba/nacos/naming/cluster/servers/ServerChangeListener.java

代码语言:javascript
复制
public interface ServerChangeListener {
​
    /**
     * If member list changed, this method is invoked.
     *
     * @param servers servers after change
     */
    void onChangeServerList(List<Server> servers);
​
    /**
     * If reachable member list changed, this method is invoked.
     *
     * @param healthyServer reachable servers after change
     */
    void onChangeHealthyServerList(List<Server> healthyServer);
}
  • ServerChangeListener定义了onChangeServerList、onChangeHealthyServerList方法

DistroMapper

nacos-1.1.3/naming/src/main/java/com/alibaba/nacos/naming/core/DistroMapper.java

代码语言:javascript
复制
@Component("distroMapper")
public class DistroMapper implements ServerChangeListener {
​
    private List<String> healthyList = new ArrayList<>();
​
    //......
​
    @Override
    public void onChangeServerList(List<Server> latestMembers) {
​
    }
​
    @Override
    public void onChangeHealthyServerList(List<Server> latestReachableMembers) {
​
        List<String> newHealthyList = new ArrayList<>();
        for (Server server : latestReachableMembers) {
            newHealthyList.add(server.getKey());
        }
        healthyList = newHealthyList;
    }
​
    //......
}
  • DistroMapper实现了ServerChangeListener接口,其onChangeHealthyServerList会更新自己的healthyList

RaftPeerSet

nacos-1.1.3/naming/src/main/java/com/alibaba/nacos/naming/consistency/persistent/raft/RaftPeerSet.java

代码语言:javascript
复制
@Component
@DependsOn("serverListManager")
public class RaftPeerSet implements ServerChangeListener, ApplicationContextAware {
​
    @Autowired
    private ServerListManager serverListManager;
​
    private ApplicationContext applicationContext;
​
    private AtomicLong localTerm = new AtomicLong(0L);
​
    private RaftPeer leader = null;
​
    private Map<String, RaftPeer> peers = new HashMap<>();
​
    private Set<String> sites = new HashSet<>();
​
    private boolean ready = false;
​
    //......
​
    @Override
    public void onChangeServerList(List<Server> latestMembers) {
​
        Map<String, RaftPeer> tmpPeers = new HashMap<>(8);
        for (Server member : latestMembers) {
​
            if (peers.containsKey(member.getKey())) {
                tmpPeers.put(member.getKey(), peers.get(member.getKey()));
                continue;
            }
​
            RaftPeer raftPeer = new RaftPeer();
            raftPeer.ip = member.getKey();
​
            // first time meet the local server:
            if (NetUtils.localServer().equals(member.getKey())) {
                raftPeer.term.set(localTerm.get());
            }
​
            tmpPeers.put(member.getKey(), raftPeer);
        }
​
        // replace raft peer set:
        peers = tmpPeers;
​
        if (RunningConfig.getServerPort() > 0) {
            ready = true;
        }
​
        Loggers.RAFT.info("raft peers changed: " + latestMembers);
    }
​
    @Override
    public void onChangeHealthyServerList(List<Server> latestReachableMembers) {
​
    }
​
    //......
}
  • RaftPeerSet实现了ServerChangeListener接口,其onChangeServerList方法会更新peers及ready属性

小结

ServerChangeListener定义了onChangeServerList、onChangeHealthyServerList方法;DistroMapper实现了ServerChangeListener接口,其onChangeHealthyServerList会更新自己的healthyList;RaftPeerSet实现了ServerChangeListener接口,其onChangeServerList方法会更新peers及ready属性

doc

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • ServerChangeListener
  • DistroMapper
  • RaftPeerSet
  • 小结
  • doc
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档