SpringCloud zookeeper作為注冊中心使用介紹
前言
本章講解spring cloud使用zookeeper作為注冊中心,該怎么配置以及使用,安裝zookeeper的文章可以在Zookeeper安裝里面去安裝。
1、服務(wù)生產(chǎn)者
創(chuàng)建生產(chǎn)者子工程項目provider-zookeeper8001,添加依賴pom
<dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> <version>2.6.11</version> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-actuator</artifactId> <version>2.6.11</version> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-zookeeper-discovery</artifactId> </dependency> </dependencies>
創(chuàng)建配置文件application.yml,添加zookeeper配置以及項目端口等
spring:
application:
name: provider
cloud:
zookeeper:
connect-string: localhost:2181
server:
port: 8001
添加項目啟動類
@EnableDiscoveryClient @SpringBootApplication public class ProviderZookeeper8001Application { public static void main(String[] args) { SpringApplication.run(ProviderZookeeper8001Application.class,args); } }
這里zookeeper的注冊聲明注解與Eureka是有區(qū)別的,不能照搬Eureka
PS:有些人可能會遇到zookeeper的版本對應(yīng)的問題,如果遇到了,可以將自動配置的依賴進行處理,先去掉spring-cloud-starter-zookeeper-discovery的zookeeper依賴,再引入自己的zookeeper依賴版本來進行對應(yīng),我這里因為全部是最新的版本,所以沒有遇到這個問題。
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-zookeeper-discovery</artifactId> <exclusions> <exclusion> <artifactId>zookeeper</artifactId> <groupId>org.apache.zookeeper</groupId> </exclusion> </exclusions> </dependency> <!--添加zookeeper依賴,版本選擇自己的zookeeper對應(yīng)的版本即可--> <dependency> <groupId>org.apache.zookeeper</groupId> <artifactId>zookeeper</artifactId> <version>3.4.9</version> </dependency>
創(chuàng)建服務(wù)提供者的服務(wù)
@RestController @RequestMapping("/provider") public class ProviderController { @Value("${server.port}") private String port; @GetMapping("/getPort") public String getPort(){ return "請求的生產(chǎn)者的端口:" + port; } }
2、服務(wù)消費者
創(chuàng)建服務(wù)消費者,注冊到zookeeper,創(chuàng)建項目三板斧-添加pom依賴、新增配置文件、新增啟動類。
pom
<dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> <version>2.6.11</version> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-actuator</artifactId> <version>2.6.11</version> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-zookeeper-discovery</artifactId> <!-- <exclusions> <exclusion> <artifactId>zookeeper</artifactId> <groupId>org.apache.zookeeper</groupId> </exclusion> </exclusions>--> </dependency> <!--添加zookeeper,添加自己的zookeeper版本即可--> <!--<dependency> <groupId>org.apache.zookeeper</groupId> <artifactId>zookeeper</artifactId> <version>3.4.9</version> </dependency>--> </dependencies>
application.yml
spring:
application:
name: consumer
cloud:
zookeeper:
connect-string: localhost:2181
server:
port: 8002
ConsumerZookeeper8002Application.class
@SpringBootApplication @EnableDiscoveryClient public class ConsumerZookeeper8002Application { public static void main(String[] args) { SpringApplication.run(ConsumerZookeeper8002Application.class,args); } }
創(chuàng)建服務(wù)消費者接口
@RestController @RequestMapping("/consumer") public class ConsumerController { @Autowired private RestTemplate loadBalancedRestTemplate; @GetMapping("/zk/getProviderPort") public String getProviderPort(){ String result = loadBalancedRestTemplate.getForObject("http://provider/provider/getPort",String.class); return result; } }
這次我們測試負載均衡的功能,啟動consumer項目,provider項目啟動兩個,一個8001,一個8000,來測試我們是否成功部署了多個服務(wù)提供者且可以正常負載。
點擊設(shè)置,選擇ProviderZookeeper8001Application的Single Instance only勾選去掉,先啟動一個8000端口,修改端口號為8001再啟動第二個,一個項目啟動多個程序自行百度有多種方案,idea版本不一樣可能會有區(qū)別。
訪問http://localhost:8002/consumer/zk/getProviderPort可以發(fā)現(xiàn),8000端口與8001端口先后出現(xiàn),至此我們使用zookeeper作為注冊中心就完成了。
如果zookeeper是集群部署,那么填寫配置spring.cloud.zookeeper.connect-string使用集群的多個地址,用英文逗號分割,例如10.1.1.1:2181,10.1.1.2:2181,10.1.1.3:2181
到此這篇關(guān)于SpringCloud zookeeper作為注冊中心使用介紹的文章就介紹到這了,更多相關(guān)SpringCloud zookeeper內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- SpringCloud中的Eureka注冊中心詳細解讀
- springcloud本地服務(wù)不注冊到注冊中心的解決方案
- SpringCloud注冊中心之consul詳細講解使用方法
- SpringCloud?Eureka服務(wù)注冊中心應(yīng)用入門詳解
- SpringBoot項目改為SpringCloud項目使用nacos作為注冊中心的方法
- Java之SpringCloud nocos注冊中心講解
- 淺析SpringCloud Alibaba-Nacos 作為注冊中心示例代碼
- Springcloud-nacos實現(xiàn)配置和注冊中心的方法
- springcloud實現(xiàn)注冊中心Eureka
- SpringCloud兩種注冊中心的實現(xiàn)
相關(guān)文章
SpringBoot整合Redis實現(xiàn)熱點數(shù)據(jù)緩存的示例代碼
這篇文章主要介紹了SpringBoot中整合Redis實現(xiàn)熱點數(shù)據(jù)緩存,本文以IDEA?+?SpringBoot作為?Java中整合Redis的使用?的測試環(huán)境,結(jié)合實例代碼給大家詳細講解,需要的朋友可以參考下2023-03-03使用dom4j遞歸解析節(jié)點內(nèi)還含有多個節(jié)點的xml
這篇文章主要介紹了使用dom4j遞歸解析節(jié)點內(nèi)還含有多個節(jié)點的xml,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-09-09JAVA實現(xiàn)DOC轉(zhuǎn)PDF的示例代碼
Word作為目前主流的文本編輯軟件之一,功能十分強大,但是在傳輸?shù)臅r候不穩(wěn)定,那么如何從DOC轉(zhuǎn)PDF,本文就來介紹一下,感興趣的可以了解一下2021-08-08Maven繼承父工程時的relativePath標簽解析用法小結(jié)
relativePath 的作用是為了找到父級工程的pom.xml,本文主要介紹了Maven繼承父工程時的relativePath標簽解析用法小結(jié),具有一定的參考價值,感興趣的可以了解一下2024-03-03springboot2.6.3讀取不到nacos上的配置文件問題
這篇文章主要介紹了springboot2.6.3讀取不到nacos上的配置文件問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-07-07