精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

反問面試官:如何實現集群內選主

開發 前端
本文主要演示了一個簡易的多Server的選主過程,以下代碼是一個簡單的基于Netty實現的集群選舉過程的示例。

面試官經常喜歡問什么zookeeper選主原理、什么CAP理論、什么數據一致性。經常都被問煩了,我就想問問面試官,你自己還會實現一個簡單的集群內選主呢?估計大部分面試官自己也寫不出來。

本篇使用 Java 和 Netty 實現簡單的集群選主過程的示例。

這個示例展示了多個節點通過投票選舉一個新的主節點的過程。Netty 用于節點間的通信,而每個節點則負責發起和響應選舉消息。

集群選主流程

1.選主流程

咱們且不說zookeeper如何選主,單說人類選主,也是采用少數服從多數的原則。人類選主時,中間會經歷如下過程:

  • 如果我沒有熟悉的或者沒找到能力比我強的,首先投給自己一票。
  • 隨著時間推移,可能后面的人介紹了各自的特點和實力,那我可能會改投給別人。
  • 所有人將投票信息放入到統計箱中。
  • 最終票數最多的人是領導者。

同樣的,zookeeper在選主時,也是這樣的流程。假設有五大服務器:

  • 服務器1先給自身投票
  • 后續起來的服務器2也會投自身一票,然后服務器1觀察到服務器2的id比較大,則會改投服務器2
  • 后續起來的服務器3也會投自身一票,然后服務1和服務器2發現服務器3的id比較大,則都會改投服務器3。服務器3被確定為領導者。
  • 服務器4起來后也會投自身一票,然后發現服務器3已經有3票了,立馬改投服務器3。
  • 服務器5與服務器4的操作一樣。

2.選主協議

在選主過程中采用的是超過半數的協議。在選主過程中,會需要如下幾類消息:

  • 投票請求:節點發出自己的投票請求。
  • 接受投票:其余節點作出判斷,如果覺得id較大,則接受投票。
  • 選舉勝出:當選主節點后,廣播勝出消息。

代碼實現

下面模擬3個節點的選主過程,核心步驟如下:

(1) 定義消息類型、消息對象、節點信息

public enum MessageType {
        VOTE_REQUEST, // 投票請求
        VOTE,         // 投票
        ELECTED       // 選舉完成后的勝出消息
}
    
public class ElectionMessage implements Serializable {
    private MessageType type;
    private int nodeId;   // 節點ID
    private long zxId;    // ZXID:類似于ZooKeeper中的邏輯時鐘,用于比較
    private int voteFor;  // 投票給的節點ID
}

public class ElectionNode {
    private int nodeId; // 當前節點ID
    private long zxId;  // 當前節點的ZXID
    private volatile int leaderId; // 當前選舉的Leader ID
    private String host;
    private int port;
    private ConcurrentHashMap<Integer, Integer> voteMap = new ConcurrentHashMap<>(); // 此節點對每個節點的投票情況
    private int totalNodes; // 集群總節點數
}

(2) 每個節點利用Netty啟動Server

public void start() throws Exception {
        EventLoopGroup bossGroup = new NioEventLoopGroup();
        EventLoopGroup workerGroup = new NioEventLoopGroup();
        try {
            ServerBootstrap serverBootstrap = new ServerBootstrap();
            serverBootstrap.group(bossGroup, workerGroup)
                    .channel(NioServerSocketChannel.class)
                    .childHandler(new ChannelInitializer<SocketChannel>() {
                        @Override
                        protected void initChannel(SocketChannel ch) {
                            ch.pipeline().addLast(
                                    new ObjectDecoder(ClassResolvers.cacheDisabled(null)),
                                    new ObjectEncoder(),
                                    new ElectionHandler(ElectionNode.this));
                        }
                    });

            ChannelFuture future = serverBootstrap.bind(port).sync();
            System.out.println("Node " + nodeId + " started on port " + port);

            // 啟動后開始選舉過程
            startElection();
//            future.channel().closeFuture().sync();


        } catch (Exception e) {

        } finally {
//            bossGroup.shutdownGracefully();
//            workerGroup.shutdownGracefully();
        }
    }

(3) 啟動后利用Netty發送投票請求

public void sendVoteRequest(String targetHost, int targetPort) {
        EventLoopGroup group = new NioEventLoopGroup();
        try {
            Bootstrap bootstrap = new Bootstrap();
            bootstrap.group(group)
                    .channel(NioSocketChannel.class)
                    .handler(new ChannelInitializer<SocketChannel>() {
                        @Override
                        protected void initChannel(SocketChannel ch) {
                            ch.pipeline().addLast(
                                    new ObjectDecoder(ClassResolvers.cacheDisabled(null)),
                                    new ObjectEncoder(),
                                    new ElectionHandler(ElectionNode.this));
                        }
                    });

            ChannelFuture future = bootstrap.connect(targetHost, targetPort).sync();
            ElectionMessage voteRequest = new ElectionMessage(ElectionMessage.MessageType.VOTE_REQUEST, nodeId, zxId, nodeId);
            future.channel().writeAndFlush(voteRequest);
//            future.channel().closeFuture().sync();
        } catch (Exception e) {

        } finally {
//            group.shutdownGracefully();
        }
    }

(4) 節點接受到投票請求后,做相關處理

節點在收到消息后,做相關邏輯處理:處理投票請求、處理確認投票、處理選主結果。

處理投票請求:判斷是否是否接受投票信息。只有在主節點沒確定并且zxId較大時,才發送投票消息。如果接受了投票請求的話,則更新本地的投票邏輯,然后給投票節點發送接受投票的消息

處理確認投票:如果投票消息被接受了,則更新本地的投票邏輯。

處理選主結果:如果收到了選主結果的消息,則更新本地的主節點。

public class ElectionHandler extends ChannelInboundHandlerAdapter {
    private final ElectionNode node;

    public ElectionHandler(ElectionNode node) {
        this.node = node;
    }

    @Override
    public void channelRead(ChannelHandlerContext ctx, Object msg) {
        ElectionMessage electionMessage = (ElectionMessage) msg;
        System.out.println("Node " + node.getNodeId() + " received: " + electionMessage);

        if (electionMessage.getType() == ElectionMessage.MessageType.VOTE_REQUEST) {
            // 判斷是否是否接受投票信息。只有在主節點沒確定并且zxId較大時,才發送投票消息
            // 如果接受了投票請求的話,則更新本地的投票邏輯,然后給投票節點發送接受投票的消息
            if (electionMessage.getZxId() >= node.getZxId() && node.getLeaderId() == 0) {
                node.receiveVote(electionMessage.getNodeId());
                ElectionMessage voteMessage = new ElectionMessage(ElectionMessage.MessageType.VOTE, electionMessage.getNodeId(), electionMessage.getZxId(), electionMessage.getNodeId());
                ctx.writeAndFlush(voteMessage);
            } else {
                // 如果已經確定主節點了,直接發送ELECTED消息
                sendLeaderInfo(ctx);
            }
        } else if (electionMessage.getType() == ElectionMessage.MessageType.VOTE) {
            // 如果投票消息被接受了,則更新本地的投票邏輯。
            if (electionMessage.getZxId() >= node.getZxId() && node.getLeaderId() == 0) {
                node.receiveVote(electionMessage.getNodeId());
            } else {
                // 如果已經確定主節點了,直接發送ELECTED消息
                sendLeaderInfo(ctx);
            }
        } else if (electionMessage.getType() == ElectionMessage.MessageType.ELECTED) {
            if (node.getLeaderId() == 0) {
                node.setLeaderId(electionMessage.getVoteFor());
            }
        }
    }

(5) 接受別的節點的投票

這里是比較關鍵的一步,當確定接受某個節點時,則更新本地的投票數,然后判斷投票數是否超過半數,超過半數則確定主節點。同時,再將主節點廣播出去。

此時,其余節點接收到選主確認的消息后,都會更新自己的本地的主節點信息。

public void receiveVote(int nodeId) {
    voteMap.merge(nodeId, 1, Integer::sum);
    // 比較出votes里值,取出最大的那個對應的key
    int currentVotes = voteMap.values().stream().max(Integer::compareTo).get();

    if (currentVotes > totalNodes / 2 && leaderId == 0) {
        setLeaderId(nodeId);
        broadcastElected();
    }
}

(6) 廣播選主結果

/**
 * 廣播選舉結果
 */
private void broadcastElected() {
    for (int i = 1; i <= totalNodes; i++) {
        if (i != nodeId) {
            sendElectedMessage(host, 9000 + i);
        }
    }
}

/**
 * 發送選舉結果
 *
 * @param targetHost
 * @param targetPort
 */
public void sendElectedMessage(String targetHost, int targetPort) {
    EventLoopGroup group = new NioEventLoopGroup();
    try {
        Bootstrap bootstrap = new Bootstrap();
        bootstrap.group(group)
                .channel(NioSocketChannel.class)
                .handler(new ChannelInitializer<SocketChannel>() {
                    @Override
                    protected void initChannel(SocketChannel ch) {
                        ch.pipeline().addLast(
                                new ObjectDecoder(ClassResolvers.cacheDisabled(null)),
                                new ObjectEncoder(),
                                new ElectionHandler(ElectionNode.this));
                    }
                });

        ChannelFuture future = bootstrap.connect(targetHost, targetPort).sync();
        ElectionMessage electedMessage = new ElectionMessage(ElectionMessage.MessageType.ELECTED, leaderId, zxId, leaderId);
        future.channel().writeAndFlush(electedMessage);
//            future.channel().closeFuture().sync();
    } catch (Exception e) {

    } finally {
//            group.shutdownGracefully();
    }
}

(7) 完整代碼

完整代碼:https://gitee.com/yclxiao/specialty/blob/master/javacore/src/main/java/com/ycl/election/ElectionHandler.java

總結

本文主要演示了一個簡易的多Server的選主過程,以上代碼是一個簡單的基于Netty實現的集群選舉過程的示例。在實際場景中,選舉邏輯遠比這個復雜,需要處理更多的網絡異常、重復消息、并發問題等。

責任編輯:趙寧寧 來源: 程序員半支煙
相關推薦

2024-04-03 00:00:00

Redis集群代碼

2024-09-24 10:28:22

2024-03-20 15:12:59

KafkaES中間件

2024-02-20 14:10:55

系統緩存冗余

2024-09-11 22:51:19

線程通訊Object

2023-11-20 10:09:59

2024-01-26 13:16:00

RabbitMQ延遲隊列docker

2024-01-19 14:03:59

Redis緩存系統Spring

2024-04-09 10:40:04

2024-10-22 16:39:07

2015-08-13 10:29:12

面試面試官

2021-12-15 06:58:13

List 集合LinkedHashS

2021-05-20 08:54:16

Go面向對象

2024-02-04 10:08:34

2024-12-25 15:44:15

2021-10-26 10:29:45

掃碼登錄功能

2021-05-20 08:34:03

CDN原理網絡

2024-09-09 15:09:30

2021-05-19 06:07:21

CSS 斜線效果技巧

2023-02-16 08:10:40

死鎖線程
點贊
收藏

51CTO技術棧公眾號

国产精品传媒视频| 久久精品国产99国产精品| 日韩久久精品电影| 男女午夜激情视频| 欧美黑人激情| 成人sese在线| 国产精品色婷婷视频| 欧美日韩免费一区二区| 蜜桃一区二区| 欧美mv和日韩mv的网站| av无码精品一区二区三区| 好操啊在线观看免费视频| 99久久er热在这里只有精品15 | 国产精品xxxx喷水欧美| 欧美精选视频在线观看| 日韩免费视频一区| 成年人在线观看视频免费| 在线观看中文| 欧美高清在线精品一区| 国产精品久久久久久久天堂第1集| 成人免费视频国产免费| 亚洲黄色免费| 久热精品视频在线观看| 国产精品免费无码| 国产福利一区二区精品秒拍| 欧美日韩视频不卡| 日本一道本久久| 2021国产在线| 国产精品久久毛片| 欧美日韩在线一二三| wwwav在线播放| 久久99热99| 国产不卡一区二区在线播放| 在线看成人av| 欧美另类专区| 另类美女黄大片| 激情无码人妻又粗又大| 国模精品一区| 亚洲精品中文字| 999精品免费视频| 7777精品| 欧美本精品男人aⅴ天堂| 极品粉嫩美女露脸啪啪| 成人精品一区二区三区电影| 色哟哟精品一区| 一二三四视频社区在线| 激情在线视频播放| 一区二区三区四区亚洲| 欧美日韩dvd| 中文字幕伦理免费在线视频| 亚洲视频一区二区在线| 亚洲欧美99| 日韩精品黄色| 中文字幕一区二区三区四区不卡 | 久久网站免费观看| 国产一区二区三区网站| 欧美做受xxxxxⅹ性视频| 日日狠狠久久偷偷综合色| 亚洲国产精品小视频| 亚洲一级Av无码毛片久久精品| 欧美一区在线观看视频| 日韩欧美中文字幕公布| 国产大学生av| 国产精品15p| 日韩av在线直播| 中文字幕一区二区三区人妻| 国产成人三级| 这里只有精品视频在线| 国产老头老太做爰视频| 欧美1区2区| 国内免费久久久久久久久久久| 日本一区二区三区免费视频| 国产视频一区欧美| 国产成人一区二区三区电影| 亚洲一卡二卡在线观看| 狠狠色丁香婷综合久久| www.成人av.com| 午夜福利一区二区三区| 久久精品亚洲乱码伦伦中文| 一本色道久久99精品综合| 黄色片网站在线| 亚洲电影中文字幕在线观看| 50路60路老熟妇啪啪| 日韩一区精品| 精品日本一线二线三线不卡| 久久人人爽人人爽人人片| 精品国产视频| 欧美成人精品激情在线观看| 亚洲久久在线观看| 久久精品国产色蜜蜜麻豆| 91精品天堂| 黄色小视频在线免费观看| 国产精品国产自产拍在线| www.日本在线视频| 日韩美女在线看免费观看| 日韩一区二区在线观看视频播放| 人妻体内射精一区二区三区| 欧美精品羞羞答答| 欧美激情一级二级| 久久久国产免费| 国产成人av福利| 日韩精品另类天天更新| 精品精品导航| 在线成人午夜影院| 亚洲精品女人久久久| 亚洲女同中文字幕| 日本久久亚洲电影| 午夜老司机福利| 国产精品乱人伦中文| 成人一对一视频| 热久久最新网址| 国产精品美女网站| 一区二区三欧美| 日韩成人精品视频在线观看| 在这里有精品| 搡老女人一区二区三区视频tv| 国产网址在线观看| 精品一区免费av| 久久久影院一区二区三区| 成人a在线视频免费观看| 色欧美88888久久久久久影院| 国产亚洲色婷婷久久| 国产一区二区三区91| 欧美激情欧美激情| 国产精品久久久国产盗摄| 久久久国产精华| 青青草国产免费| 久久久久久久久久久久电影| 伊人久久精品视频| 久久精品视频1| 成人高清免费观看| 超级碰在线观看| 日韩美女在线| 中文字幕日韩欧美精品在线观看| 精品成人av一区二区在线播放| 国产成人一区在线| 国产香蕉一区二区三区| 欧美网站免费| 这里只有精品视频在线| 91麻豆精品在线| 91免费看视频| 无罩大乳的熟妇正在播放| 成人动态视频| 欧美日韩成人网| 99国产精品久久久久99打野战| 国产精品国产精品国产专区不片| 国产野外作爱视频播放| 日韩伦理一区二区三区| 亚洲97在线观看| 日韩中文字幕免费在线观看| 亚洲图片一区二区| 国内自拍偷拍视频| 亚洲一级黄色| 久久久久久久久久久久久久久久av| 久草在线视频资源| 亚洲国产精品yw在线观看| 国产精品美女毛片真酒店| 不卡的看片网站| 久久久一本二本三本| 最新精品国偷自产在线| 国产v综合ⅴ日韩v欧美大片 | 亚洲一区二区三区精品动漫| 国产91亚洲精品久久久| 日韩中文在线中文网三级| 一本一道人人妻人人妻αv| 亚洲欧洲精品一区二区精品久久久| 中文字幕22页| 中文在线日韩| 国产精品手机在线| 涩涩涩在线视频| 亚洲午夜精品久久久久久久久久久久| 天天综合久久综合| 亚洲欧洲日产国产综合网| 国产裸体视频网站| 在线亚洲免费| 性欧美大战久久久久久久免费观看 | 97免费在线视频| 你懂的好爽在线观看| 欧美性猛交xxxxxxxx| 疯狂试爱三2浴室激情视频| 国产麻豆一精品一av一免费| 免费成人午夜视频| 久久精品99久久无色码中文字幕| 成人在线视频网| 91九色在线看| 永久免费精品影视网站| 国产成人麻豆精品午夜在线| 精品女同一区二区三区在线播放 | 蜜臀av在线观看| 色婷婷精品久久二区二区蜜臂av| fc2ppv在线播放| jlzzjlzz亚洲日本少妇| 中文字幕在线观看第三页| 亚洲最新色图| 日韩欧美精品在线不卡 | 日韩午夜在线观看| 国产精品久久久久久人| 亚洲人成在线观看一区二区| www.超碰97| 国产精一区二区三区| www.国产区| 欧美日韩亚洲一区| 欧美一区二区视频在线| 精品国产三区在线| 日韩免费视频在线观看| 日本在线观看高清完整版| 亚洲欧美中文日韩在线| 亚洲va欧美va| 欧美高清视频不卡网| 国产免费av一区| 亚洲狠狠爱一区二区三区| 一级二级黄色片| 26uuu亚洲综合色欧美 | jizz国产精品| 国产免费一区二区三区在线能观看 | 2021国产精品视频| 亚洲婷婷噜噜| 中文字幕日韩视频| 日韩欧美亚洲系列| 精品99一区二区三区| 国产欧美久久久精品免费| 欧美艳星brazzers| 日韩黄色在线播放| 亚洲伊人色欲综合网| 伊人在线视频观看| 国产精品日产欧美久久久久| 国产精品无码一区二区三区| www.av精品| 欧美人与性动交α欧美精品| 另类中文字幕网| 欧美婷婷精品激情| 可以看av的网站久久看| koreanbj精品视频一区| 亚洲精品麻豆| 日韩精品―中文字幕| 激情自拍一区| 97在线国产视频| 亚洲午夜久久久久久尤物| 日本免费黄色小视频| 久久久久久久久久久妇女| 亚洲精品在线免费| 久久影视一区| 亚洲国产精品一区在线观看不卡| 狠狠综合久久av一区二区蜜桃| 久久久久se| 亚洲a级精品| 欧美人xxxxx| av一区二区在线观看| 亚洲狠狠婷婷综合久久久| 欧洲乱码伦视频免费| 一本久久a久久精品vr综合| 欧美gay男男猛男无套| 伊人天天久久大香线蕉av色| 五月天激情综合网| 玖玖精品在线视频| 欧美激情一级片一区二区| 欧美在线观看视频免费| 亚洲成人直播| 丰满少妇被猛烈进入高清播放| 在线亚洲国产精品网站| 老头吃奶性行交视频| 石原莉奈在线亚洲二区| 我要看一级黄色大片| 狠狠网亚洲精品| 中文字幕天堂av| 久久婷婷综合激情| av网站免费在线看| 国产精品成人一区二区艾草| 久久久久亚洲av无码专区体验| 亚洲成人自拍偷拍| 精品国产一区二区三区四| 91成人免费电影| 国产尤物视频在线观看| 亚洲精品一区二区精华| 黄色电影免费在线看| 日韩中文字幕视频在线| 欧美黑人猛交| 日韩av免费在线| 91麻豆精品| 国产日韩一区欧美| 欧美精品一区二区三区中文字幕 | 日本不卡高清视频| 一级 黄 色 片一| 99久久精品国产观看| 久久久久久久毛片| 亚洲视频免费在线观看| 日韩精品一卡二卡| 欧美色成人综合| 亚洲精品18在线观看| 亚洲欧洲午夜一线一品| 成人video亚洲精品| 91干在线观看| 国产精久久一区二区| 久久国产欧美精品| 香蕉精品视频在线观看| 国产一区二区网| 激情偷乱视频一区二区三区| 好吊色视频一区二区三区| 欧美国产97人人爽人人喊| 久久精品国产亚洲av无码娇色| 一本一道综合狠狠老| av中文字幕在线免费观看| 亚洲理论在线a中文字幕| www视频在线看| 国产成人精品久久久| 亚洲一区网址| 一区二区三区av| 久久在线91| 精品人妻一区二区三区日产| 亚洲天堂a在线| 狠狠躁夜夜躁人人爽视频| 亚洲成人精品久久| 99在线播放| 国产日产欧美a一级在线| 亚洲激情播播| 无码中文字幕色专区| 国产麻豆成人传媒免费观看| 一级特黄曰皮片视频| 欧美日韩精品在线| 亚洲精品久久久久久无码色欲四季| 这里只有精品久久| 国产精品伦理| 久久riav| 一区二区三区福利| 图片区偷拍区小说区| 亚洲色图欧美激情| 中文字幕一区二区三区四区视频| 亚洲精选中文字幕| 交100部在线观看| 国产伦精品一区二区三区视频免费| 88国产精品视频一区二区三区| 亚洲第一狼人区| 国产精品麻豆久久久| 中文字幕+乱码+中文乱码91| 亚洲人成电影网| 性欧美hd调教| 日本高清不卡一区二区三| 久久精品人人做人人爽电影蜜月| 亚洲婷婷在线观看| 亚洲国产欧美另类丝袜| 免费av网站观看| 97视频在线免费观看| 久久综合社区| 男人日女人bb视频| 久久综合九色综合久久久精品综合 | 欧美国产偷国产精品三区| 婷婷六月天在线| 国产精品久久久久久久蜜臀| 亚洲视频在线观看一区二区| 在线视频精品一| 四虎国产精品永久在线国在线| 自拍偷拍一区二区三区| 紧缚奴在线一区二区三区| 国产67194| 精品少妇一区二区三区在线视频 | 国产精品成人va在线观看| 久久不见久久见中文字幕免费| 青青青在线播放| 国产日韩欧美激情| 91极品身材尤物theporn| 久久色在线播放| 亚洲码欧美码一区二区三区| 国产精品又粗又长| 国产午夜精品一区二区三区四区| 中文字幕乱码视频| 久热99视频在线观看| 国产成人精品亚洲线观看| 欧美亚洲另类色图| 国产欧美日本一区二区三区| 国产精品久久久久久久一区二区| 久久99久久亚洲国产| 人体久久天天| 91极品视频在线观看| 一区二区激情小说| 色综合久久网女同蕾丝边| 国产精品久久久久一区二区| 天天射天天综合网| 日本道中文字幕| 欧美在线色视频| 影音先锋在线视频| 久久综合伊人77777麻豆| 捆绑调教一区二区三区| 国产精品成人国产乱| 国产亚洲精品va在线观看| 999精品嫩草久久久久久99| 免费网站永久免费观看| 国产亚洲一区字幕| 国产黄a三级三级看三级| 热久久99这里有精品| 婷婷丁香综合| 魔女鞋交玉足榨精调教| 欧美一区二区三区小说| 中文字幕人成乱码在线观看| 欧美日韩视频免费在线观看| 99久久精品情趣| 国产露脸国语对白在线| 欧美在线一级va免费观看| 亚洲精品二区三区| 一级片手机在线观看| 精品日韩成人av|