springboot應(yīng)用訪問zookeeper的流程
本文講解了如果通過springboot快速開發(fā)web服務(wù),并讀取zookeeper的過程,為后續(xù)的“在docker下部署dubbo服務(wù)“做準(zhǔn)備工作,本文相關(guān)的操作都在mac上進(jìn)行的,文中有些目錄和windows有些區(qū)別,請(qǐng)各位注意對(duì)應(yīng)自己的電腦做對(duì)應(yīng)的修改。
本地部署zookeeper
首先去官網(wǎng)下載zookeeper包,推薦使用穩(wěn)定版3.3.6
下載后在本地解壓,進(jìn)入zookeeper-3.3.6/conf目錄下,將zoo_sample.cfg文件改名為zoo.cfg,再用文本編輯器打開這個(gè)文件,修改如下紅框位置的內(nèi)容,改成本地一個(gè)可以訪問的已有目錄:
打開命令行窗口,進(jìn)入zookeeper-3.3.6/bin目錄,windows下執(zhí)行zkServer.cmd status,mac和linux下執(zhí)行./zkServer.sh status,該命令是查看當(dāng)前zookeeper的狀態(tài),由于還沒有啟動(dòng)zookeeper,我們會(huì)看到如下錯(cuò)誤信息:
現(xiàn)在啟動(dòng)zookeeper吧,windows下執(zhí)行zkServer.cmd start,mac和linux下執(zhí)行./zkServer.sh start,啟動(dòng)信息如下:
這時(shí)候輸入zkServer.cmd status,看到的結(jié)果如下:
可以看到zookeeper正在以standalone模式運(yùn)行中;
現(xiàn)在我們用客戶端命令來試試服務(wù),windows下執(zhí)行zkCli.cmd, mac和linux下執(zhí)行./zkCli.sh,連接上服務(wù)端:
執(zhí)行create /node1 abc創(chuàng)建一個(gè)znode,對(duì)應(yīng)的value是"abc",再執(zhí)行g(shù)et /node1可以查看/node_1的value,如下圖:
關(guān)于zookeeper的安裝和驗(yàn)證就寫到這里了,接下來我們開始開發(fā)應(yīng)用來訪問這個(gè)zookeeper節(jié)點(diǎn)的數(shù)據(jù)。
開發(fā)基于spring boot的應(yīng)用
打開IntelliJ IDEA CE,創(chuàng)建名為zookeeperdemo的Maven工程,指定模板,如下圖:
工程創(chuàng)建后要做的就是修改pom,增加庫的依賴,已經(jīng)添加配置文件,寫java代碼,具體的源碼請(qǐng)?jiān)谖业膅it上下載,鏈接
源碼在以下位置:
源碼下載下來后,可以通過Intellij IEDA導(dǎo)入,導(dǎo)入的時(shí)候以下紅框中的選項(xiàng)需要選中,這樣才能導(dǎo)入maven工程:
整個(gè)工程非常簡單,首先是pom文件,依賴的父工程要用spring-boot-starter-parent:
還要添加對(duì)springboot的依賴,以及build時(shí)使用springboot對(duì)應(yīng)的插件:
在resource目錄增加application.properties文件配置一些重要的參數(shù),例如日志目錄,web server端口等,如下圖:
最后是寫java代碼,由于只是個(gè)demo,這里的代碼非常簡單,一個(gè)入口,一個(gè)controller,入口如下:
controller如下,是一個(gè)簡單的rest響應(yīng),鏈接zookeeper取得znode節(jié)點(diǎn)的值然后返回,注意由于申明了RestController,所以返回的內(nèi)容非頁面而是字符串:
至此,編碼結(jié)束,來試試吧,如下圖新建一個(gè)命令:
選擇maven:
命令內(nèi)容為clean package -U -Dmaven.test.skip=true spring-boot:run,如下:
命令創(chuàng)建完成后,點(diǎn)擊“run“執(zhí)行:
此時(shí)打開瀏覽器,輸入http://localhost:2222/zkget即可得到我們?cè)趜ookeeper上設(shè)置的/node_1的value,如下圖:
至此,基于spring boot框架訪問zookeeper的demo開發(fā)以及結(jié)束,后面我們嘗試通過Dockerfile的方式制作zookeeper的鏡像,然后通過docker的容器提供zookeeper的服務(wù)。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- 淺談Java(SpringBoot)基于zookeeper的分布式鎖實(shí)現(xiàn)
- 使用dubbo+zookeeper+spring boot構(gòu)建服務(wù)的方法詳解
- SpringBoot中dubbo+zookeeper實(shí)現(xiàn)分布式開發(fā)的應(yīng)用詳解
- SpringBoot集成Curator實(shí)現(xiàn)Zookeeper基本操作的代碼示例
- SpringBoot系列教程之dubbo和Zookeeper集成方法
- SpringBoot整合Dubbo+Zookeeper實(shí)現(xiàn)RPC調(diào)用
- SpringBoot整合Zookeeper詳細(xì)教程
- Java Spring Boot 集成Zookeeper
- SpringBoot讀取ZooKeeper(ZK)屬性的方法實(shí)現(xiàn)
相關(guān)文章
Java數(shù)據(jù)結(jié)構(gòu)之簡單的連接點(diǎn)(link)實(shí)現(xiàn)方法示例
這篇文章主要介紹了Java數(shù)據(jù)結(jié)構(gòu)之簡單的連接點(diǎn)(link)實(shí)現(xiàn)方法,涉及java指針指向節(jié)點(diǎn)的相關(guān)使用技巧,需要的朋友可以參考下2017-10-10@Transaction,@Async在同一個(gè)類中注解失效的原因分析及解決
這篇文章主要介紹了@Transaction,@Async在同一個(gè)類中注解失效的原因分析及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-12-12MP(MyBatis-Plus)實(shí)現(xiàn)樂觀鎖更新功能的示例代碼
這篇文章主要介紹了MP(MyBatis-Plus)實(shí)現(xiàn)樂觀鎖更新功能的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01java.lang.IncompatibleClassChangeError異常的問題解決
本文主要介紹了java.lang.IncompatibleClassChangeError異常的問題解決,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-06-06java 實(shí)現(xiàn)微信服務(wù)器下載圖片到自己服務(wù)器
這篇文章主要介紹了 java 實(shí)現(xiàn)微信服務(wù)器下載圖片到自己服務(wù)器的相關(guān)資料,需要的朋友可以參考下2017-05-05