亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

【Mrpc】Demo2 基于Zookeeper的服務器感知及負載均衡

2019-11-11 07:48:10
字體:
來源:轉載
供稿:網友

由于服務器經常會維護,把服務實現服務端的地址直接寫在客戶端(包括配置文件里)都是不太好的。比較好的辦法是服務端啟動的時候把自己的地址注冊到ZooKeeper集群中,然后客戶端啟動時即可獲得所有服務器列表,并選擇一個合適的服務器為自己提供服務。

這樣解決了服務端地址的獲取問題,同時也解決了服務端的負載均衡問題。

來看一下相應的代碼。項目源碼已經上傳到http://download.csdn.net/detail/mrbcy/9747568

package tech.mrbcy.mrpc.demo.demo2;import java.io.IOException;import java.util.ArrayList;import java.util.List;import org.apache.zookeeper.CreateMode;import org.apache.zookeeper.KeeperException;import org.apache.zookeeper.WatchedEvent;import org.apache.zookeeper.Watcher;import org.apache.zookeeper.ZooKeeper;import org.apache.zookeeper.Watcher.Event.EventType;import org.apache.zookeeper.ZooDefs.Ids;import org.apache.zookeeper.data.Stat;public class ServerAddrHelper { public static final String DEFAULT_GROUP_NAME = "/MrpcServers"; PRivate String connString; private String groupName; private ZooKeeper zk; private ServerChangeListener listener; private static int sessionTimeout = 2000; public ServerAddrHelper(String connString){ this.connString = connString; this.groupName = DEFAULT_GROUP_NAME; } /** * * @param connString zk連接字符串 * @param groupName 父節點路徑,位于/下,需要帶/ 示例值:"/MrpcServers" */ public ServerAddrHelper(String connString, String groupName){ this.connString = connString; if(!groupName.startsWith("/")){ groupName = "/" + groupName; } this.groupName = groupName; } /** * 向ZooKeeper集群注冊服務器 * @param registPath 服務器節點路徑,示例值"server" * @param address 服務器地址及端口號,用于客戶端連接 * @throws Exception 連接服務器失敗 */ public void registServer(String registPath, String address) throws Exception{ zk = new ZooKeeper(connString,sessionTimeout,null); // 判斷父目錄是否存在,不存在則創建 Stat groupStat = zk.exists(groupName, false); if(groupStat == null){ zk.create(groupName, "Mrpc server list".getBytes(), Ids.OPEN_ACL_UNSAFE, CreateMode.PERSISTENT); } // 注冊服務器 if(!registPath.startsWith("/")){ registPath = "/" + registPath; } String registAddr = zk.create(groupName+registPath, address.getBytes(), Ids.OPEN_ACL_UNSAFE, CreateMode.EPHEMERAL_SEQUENTIAL); System.out.println("Server is starting, reg addr:" + registAddr); } /** * 發現服務器 * @param listener 監聽器,如果不是null,等到服務器列表發生變化時,監聽器會收到通知 * @return * @throws Exception */ public List<String> discoverServers(ServerChangeListener listener) throws Exception{ this.listener = listener; zk = new ZooKeeper(connString,sessionTimeout,new Watcher(){ public void process(WatchedEvent event) { if(event.getType() == EventType.NodeChildrenChanged){ // 服務器列表發生變化 try { List<String> servers = getServerList(); if(ServerAddrHelper.this.listener != null){ ServerAddrHelper.this.listener.onChange(servers); } } catch (Exception e) { e.printStackTrace(); } } } }); return getServerList(); } private List<String> getServerList() throws Exception { zk.getChildren(groupName, true); List<String> children = zk.getChildren(groupName, true); List<String> servers = new ArrayList<String>(); for(String child : children) { byte[] data = zk.getData(groupName+"/"+child, null, null); servers.add(new String(data)); } return servers; }}

一般來講registServer由服務端框架調用,向zk集群注冊自己。discoverServer用客戶端框架調用。取得當前可用的服務器列表。并且提供了服務器列表發生變化時的監聽接口。

另外還實現了一個負載均衡器,使用最簡單的隨機選擇算法來挑選服務器。后續還可以進行改進,比如根據服務端當前的負載來選擇服務器。代碼如下:

package tech.mrbcy.mrpc.demo.demo2;import java.net.InetSocketAddress;import java.util.List;import java.util.Random;public class ServerLoadBalancer { /** * 選擇一個服務器 * @param servers 服務器列表 示例值:133.122.5.88:8888 或 anode2:5884 * @return 連接服務器地址 */ public static InetSocketAddress chooseServer(List<String> servers){ if(servers == null || servers.size() == 0){ return null; } // 隨機選擇一個服務器 String serverAddr = servers.get(0); if(servers.size() > 1){ int index = new Random().nextInt(servers.size()); serverAddr = servers.get(index); } String[] addrAndPort = serverAddr.split(":"); if(addrAndPort.length != 2){ throw new RuntimeException("不合法的server地址:" + serverAddr); } return new InetSocketAddress(addrAndPort[0], Integer.parseInt(addrAndPort[1])); }}

最后給出一個測試類的代碼。其他的詳細信息請看上傳的項目代碼吧。

package tech.mrbcy.mrpc.demo.demo2;import java.net.InetSocketAddress;import java.util.List;import org.junit.Test;public class MockClient { private InetSocketAddress serverAddress; @Test public void testClient(){ ServerAddrHelper serverHelper = new ServerAddrHelper("amaster:2181,anode1:2181,anode2:2181"); ServerAddrHelper helper = new ServerAddrHelper("amaster:2181,anode1:2181,anode2:2181"); try { serverHelper.registServer("ServiceImplServer", "localhost:10000"); List<String> serverList = helper.discoverServers(new ServerChangeListener() { public void onChange(List<String> servers) { System.out.println("服務器列表發生變化,當前服務器列表為:"); System.out.println(servers); changeToServer(servers); } }); System.out.println(serverList); if(serverList == null || serverList.size() == 0){ System.out.println("沒有可用的服務器"); } changeToServer(serverList); Thread.sleep(1000); serverHelper.registServer("ServiceImplServer", "localhost:10001"); Thread.sleep(1000); serverHelper.registServer("ServiceImplServer", "localhost:10002"); // 這期間可以手動刪除已經連接的服務器,測試服務器斷線的情況 Thread.sleep(50000); } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); } } private void changeToServer(List<String> servers) { if(servers == null || servers.size() == 0){ return; } // 未指定服務器地址或原服務器已失效,遷移到新的服務器 boolean valid = false; if(servers.size() > 0 && serverAddress != null){ for(String server:servers){ if(server.equals(serverAddress.getHostString() + ":" + serverAddress.getPort())){ valid = true; break; } } } if(serverAddress == null || !valid){ serverAddress = ServerLoadBalancer.chooseServer(servers); System.out.println("未指定服務器地址或原服務器已失效,遷移到新的服務器:" + serverAddress.getHostString() + ":" + serverAddress.getPort()); } }}

輸出結果如下:

Server is starting, reg addr:/MrpcServers/ServiceImplServer0000000030[localhost:10000]未指定服務器地址或原服務器已失效,遷移到新的服務器:localhost:10000Server is starting, reg addr:/MrpcServers/ServiceImplServer0000000031服務器列表發生變化,當前服務器列表為:[localhost:10001, localhost:10000]Server is starting, reg addr:/MrpcServers/ServiceImplServer0000000032服務器列表發生變化,當前服務器列表為:[localhost:10001, localhost:10002, localhost:10000]服務器列表發生變化,當前服務器列表為:[localhost:10001, localhost:10002]未指定服務器地址或原服務器已失效,遷移到新的服務器:localhost:10002
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
555www成人网| 国产成人精品一区二区在线| 亚洲欧美在线一区| 热99精品只有里视频精品| 福利二区91精品bt7086| 欧美韩国理论所午夜片917电影| 亚洲第一区在线| 中文字幕九色91在线| 欧美综合激情网| 成人免费高清完整版在线观看| 久久久成人的性感天堂| 成人国产精品免费视频| 国产精品看片资源| 欧美在线精品免播放器视频| 欧美夫妻性生活视频| 久久久精品国产一区二区| 欧美日韩xxx| 欧美一级bbbbb性bbbb喷潮片| 亚洲性日韩精品一区二区| 国产午夜精品一区理论片飘花| 国产亚洲aⅴaaaaaa毛片| 国产精品美女主播在线观看纯欲| 成人免费网站在线看| 亚洲字幕一区二区| 亚洲精品国产美女| 777精品视频| 亚洲自拍中文字幕| 精品国偷自产在线视频| 久热在线中文字幕色999舞| 精品国产依人香蕉在线精品| 日韩精品视频免费专区在线播放| 91色琪琪电影亚洲精品久久| 欧美性猛交xxxx偷拍洗澡| 亚洲精品在线视频| 91国在线精品国内播放| 久久久久久91| 97国产精品免费视频| 欧美国产日韩中文字幕在线| 亚洲免费电影一区| 久久免费福利视频| 久久婷婷国产麻豆91天堂| 国产亚洲精品高潮| 亚洲欧美日韩精品久久奇米色影视| 97超级碰碰碰久久久| 亚洲午夜未删减在线观看| 国产精品久久视频| 成人a在线视频| 55夜色66夜色国产精品视频| www.亚洲男人天堂| 亚洲国内高清视频| 亚洲成人黄色网| 亚洲欧美一区二区精品久久久| 成人av在线天堂| 高清亚洲成在人网站天堂| 一本久久综合亚洲鲁鲁| 北条麻妃在线一区二区| 亚洲国产欧美一区二区三区久久| 欧美在线视频免费观看| 欧美大码xxxx| 奇米四色中文综合久久| 欧美日韩国产一中文字不卡| 国产精品久久久久久久久久免费| 国产精品久久久久久久久久三级| 日韩一区二区精品视频| 欧美激情一区二区三区成人| 人人做人人澡人人爽欧美| 日韩经典中文字幕| 日韩暖暖在线视频| 自拍偷拍亚洲一区| 成人中文字幕在线观看| 日韩精品在线影院| 一区二区在线视频播放| 国产精品福利观看| 国产精品视频午夜| 91精品国产高清自在线看超| 亚洲免费视频一区二区| 日韩电影大全免费观看2023年上| 日韩亚洲精品电影| 亚洲一区二区三区xxx视频| 日本不卡视频在线播放| 国产日本欧美视频| 国产成人精品优优av| 亚洲精品日韩欧美| 国产aⅴ夜夜欢一区二区三区| 亚洲欧美综合另类中字| 国内精品模特av私拍在线观看| 亲子乱一区二区三区电影| 日韩精品一二三四区| 亚洲毛片在线观看| 亚洲成人精品视频在线观看| 国内精品久久久久久影视8| 三级精品视频久久久久| 欧美小视频在线| 国产噜噜噜噜久久久久久久久| 午夜精品国产精品大乳美女| 日韩一区二区三区国产| 亚洲精品美女在线观看| 欧美黑人视频一区| 日韩中文字幕免费视频| 欧美xxxx做受欧美| 精品高清一区二区三区| 欧美日韩亚洲精品一区二区三区| 91在线观看免费网站| 久热99视频在线观看| 国产精品久久久久久久久久久久久久| 成人做爰www免费看视频网站| 日韩在线观看网址| 精品一区二区亚洲| 国产精品白丝jk喷水视频一区| 欧美一区二区三区精品电影| 亚洲欧美国产va在线影院| 欧美日韩中文字幕| 91精品久久久久久久久久入口| 久久久久国产精品一区| 两个人的视频www国产精品| 久久久成人精品| 日韩av在线看| 亚洲精品美女久久久久| 欧美午夜激情小视频| 亚洲成人av片在线观看| 欧美在线视频观看| 国产亚洲美女精品久久久| 成人精品视频久久久久| 17婷婷久久www| 性欧美亚洲xxxx乳在线观看| 欧美成人剧情片在线观看| 国产日韩换脸av一区在线观看| 欧美香蕉大胸在线视频观看| 亚洲国产一区二区三区四区| 欧美高清不卡在线| 国产有码在线一区二区视频| 国产精品视频一区国模私拍| 日本一区二三区好的精华液| 日韩欧美在线视频免费观看| 亚洲综合日韩中文字幕v在线| xxx成人少妇69| 亚洲码在线观看| 国产99视频精品免视看7| 久久国产精品影视| 久久青草福利网站| 欧美猛少妇色xxxxx| 欧美激情第6页| 亚洲女人被黑人巨大进入| 国产啪精品视频网站| 精品视频一区在线视频| 亚洲三级av在线| 亚洲天堂av高清| 92版电视剧仙鹤神针在线观看| 在线激情影院一区| 亚洲第一精品自拍| 中文字幕亚洲自拍| 亚洲精品久久久久久久久久久久久| 国产一区二区三区在线免费观看| 亚洲精品www久久久| 亚洲香蕉成视频在线观看| 欧美激情喷水视频| 色综合久久88| 国产精品老女人视频| 中文日韩在线观看| 日韩免费在线视频| 国产成人精品亚洲精品| 亚洲国语精品自产拍在线观看| 成人精品久久av网站| 亚洲日韩中文字幕在线播放|