Zookeeper如何實現(xiàn)分布式服務配置中心詳解
1 Linux安裝并啟動Zookeeper
1.1 安裝
下載鏈接:https://archive.apache.org/dist/zookeeper/
1.1.1 安裝
[root@iZ1608aqb7ntn9Z tmp]# ls apache-zookeeper-3.5.7-bin.tar.gz hsperfdata_root [root@iZ1608aqb7ntn9Z tmp]# tar -zxvf apache-zookeeper-3.5.7-bin.tar.gz apache-zookeeper-3.5.7-bin/docs/ apache-zookeeper-3.5.7-bin/docs/skin/ apache-zookeeper-3.5.7-bin/docs/images/ ...... [root@iZ1608aqb7ntn9Z tmp]# mv apache-zookeeper-3.5.7-bin /usr/local/zookeeper [root@iZ1608aqb7ntn9Z tmp]# cd /usr/local/zookeeper [root@iZ1608aqb7ntn9Z zookeeper]# cd conf/ [root@iZ1608aqb7ntn9Z conf]# ls configuration.xsl log4j.properties zoo_sample.cfg [root@iZ1608aqb7ntn9Z conf]# cp zoo_sample.cfg zoo.cfg [root@iZ1608aqb7ntn9Z conf]# ls configuration.xsl log4j.properties zoo.cfg zoo_sample.cfg [root@iZ1608aqb7ntn9Z conf]# vim zoo.cfg # 修改zoo.cfg配置文件 內(nèi)容為: tickTime=2000 initLimit=10 syncLimit=5 dataDir=/usr/local/zookeeper/data clientPort=2181 # 保存退出 [root@iZ1608aqb7ntn9Z conf]# cd .. [root@iZ1608aqb7ntn9Z zookeeper]# mkdir data [root@iZ1608aqb7ntn9Z zookeeper]# ls bin conf data docs lib LICENSE.txt NOTICE.txt README.md README_packaging.txt
1.2 啟動
[root@iZ1608aqb7ntn9Z zookeeper]# cd bin/ [root@iZ1608aqb7ntn9Z bin]# ./zkServer start ...... [root@iZ1608aqb7ntn9Z bin]# ./zkServer.sh status ZooKeeper JMX enabled by default Using config: /usr/local/zookeeper/bin/../conf/zoo.cfg Client port found: 2181. Client address: localhost. Client SSL: false. Error contacting service. It is probably not running.
在上邊我們發(fā)現(xiàn)了啟動錯誤,查看日志,發(fā)現(xiàn)8080端口被占用,通過查閱Zookeeper3.5的官方文檔,發(fā)現(xiàn)這是Zookeeper3.5的新特性:

所以我們需要再次修改配置文件,修改啟動端口:
在配置文件中加入admin.serverPort=8888
然后再次啟動,查看狀態(tài):
[root@iZ1608aqb7ntn9Z bin]# ./zkServer.sh status ZooKeeper JMX enabled by default Using config: /usr/local/zookeeper3.5.7/bin/../conf/zoo.cfg Client port found: 2181. Client address: localhost. Mode: standalone
發(fā)現(xiàn)啟動成功,接下來我們用客戶端鏈接:
[root@iZ1608aqb7ntn9Z bin]# ./zkCli.sh Connecting to localhost:2181 ...... WatchedEvent state:SyncConnected type:None path:null [zk: localhost:2181(CONNECTING) 0] ls / [zookeeper]
1.3 阿里云安全組放開2181端口
(略)
2 zookeeper配置
[zk: localhost:2181(CONNECTING) 0] ls / [zookeeper] [zk: localhost:2181(CONNECTED) 4] create /config Created /config [zk: localhost:2181(CONNECTED) 6] create /config/hello # config后的名稱要與spring.name的名稱對應 Created /config/hello [zk: localhost:2181(CONNECTED) 7] create /config/hello/student.name zs Created /config/hello/student.name [zk: localhost:2181(CONNECTED) 8] get /config/hello/student.name zs
3 Spring Boot配置
3.1 依賴
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-zookeeper-discovery</artifactId>
<version>2.1.4.RELEASE</version>
<type>pom</type>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-zookeeper-config</artifactId>
<version>2.1.4.RELEASE</version>
<type>pom</type>
<scope>runtime</scope>
</dependency>
</dependencies>
注意:一定要注意Spring Boot和Spring Cloud的版本對應!
3.2 配置文件
application.yml
server: port: 0 # 表示隨機端口 student: name: 1
bootstrap.yml
spring:
cloud:
zookeeper:
connect-string: 8.131.57.161:2181 # zk服務端地址
enabled: true # 啟動遠程配置
application:
name: hello
3.3 項目代碼
/**
* @desc: 控制器
* @author: YanMingXin
* @create: 2021/8/20-16:31
**/
@RestController
public class HelloController {
@Value("${student.name}")
private String name;
@RequestMapping("/hello")
public String getName() {
return name;
}
}
3.4 啟動測試

下面我們來修改下遠程配置,看下是不是真的使用了zookeeper的配置文件:
[zk: localhost:2181(CONNECTED) 9] delete /config/hello/student.name [zk: localhost:2181(CONNECTED) 10] get /config/hello/student.name org.apache.zookeeper.KeeperException$NoNodeException: KeeperErrorCode = NoNode for /config/hello/student.name [zk: localhost:2181(CONNECTED) 11] create /config/hello/student.name ls Created /config/hello/student.name [zk: localhost:2181(CONNECTED) 12] get /config/hello/student.name ls
重新啟動項目:

總結(jié)
到此這篇關(guān)于Zookeeper如何實現(xiàn)分布式服務配置中心的文章就介紹到這了,更多相關(guān)Zookeeper分布式服務配置中心內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JAVA中String類與StringBuffer類的區(qū)別
這篇文章主要為大家詳細介紹了JAVA中String類與StringBuffer類的區(qū)別,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-12-12
BeanPostProcessor在顯示調(diào)用初始化方法前修改bean詳解
這篇文章主要介紹了BeanPostProcessor在顯示調(diào)用初始化方法前修改bean詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-12-12
單點登錄的概念及SpringBoot實現(xiàn)單點登錄的操作方法
在本文中,我們將使用Spring Boot構(gòu)建一個基本的單點登錄系統(tǒng),我們將介紹如何使用Spring Security和JSON Web Tokens(JWTs)來實現(xiàn)單點登錄功能,本文假設(shè)您已經(jīng)熟悉Spring Boot和Spring Security,感興趣的朋友一起看看吧2024-10-10
使用Vue+Spring Boot實現(xiàn)Excel上傳功能
這篇文章主要介紹了使用Vue+Spring Boot實現(xiàn)Excel上傳,需要的朋友可以參考下2018-11-11
使用Java?Executors創(chuàng)建線程池的9種方法
文章主要介紹了?Java?中Executors類創(chuàng)建線程池的?9?種方法,每種方法都詳細闡述了實現(xiàn)原理、源代碼分析、參數(shù)解釋、實現(xiàn)過程、特性和使用場景,感興趣的小伙伴跟著小編一起來看看吧2024-11-11

