SpringCloud zookeeper作為注冊(cè)中心使用介紹
前言
本章講解spring cloud使用zookeeper作為注冊(cè)中心,該怎么配置以及使用,安裝zookeeper的文章可以在Zookeeper安裝里面去安裝。
1、服務(wù)生產(chǎn)者
創(chuàng)建生產(chǎn)者子工程項(xiàng)目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配置以及項(xiàng)目端口等
spring:
application:
name: provider
cloud:
zookeeper:
connect-string: localhost:2181
server:
port: 8001
添加項(xiàng)目啟動(dòng)類
@EnableDiscoveryClient
@SpringBootApplication
public class ProviderZookeeper8001Application {
public static void main(String[] args) {
SpringApplication.run(ProviderZookeeper8001Application.class,args);
}
}這里zookeeper的注冊(cè)聲明注解與Eureka是有區(qū)別的,不能照搬Eureka
PS:有些人可能會(huì)遇到zookeeper的版本對(duì)應(yīng)的問(wèn)題,如果遇到了,可以將自動(dòng)配置的依賴進(jìn)行處理,先去掉spring-cloud-starter-zookeeper-discovery的zookeeper依賴,再引入自己的zookeeper依賴版本來(lái)進(jìn)行對(duì)應(yīng),我這里因?yàn)槿渴亲钚碌陌姹?,所以沒(méi)有遇到這個(gè)問(wèn)題。
<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對(duì)應(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 "請(qǐng)求的生產(chǎn)者的端口:" + port;
}
}2、服務(wù)消費(fèi)者
創(chuàng)建服務(wù)消費(fèi)者,注冊(cè)到zookeeper,創(chuàng)建項(xiàng)目三板斧-添加pom依賴、新增配置文件、新增啟動(dòng)類。
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ù)消費(fèi)者接口
@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;
}
}這次我們測(cè)試負(fù)載均衡的功能,啟動(dòng)consumer項(xiàng)目,provider項(xiàng)目啟動(dòng)兩個(gè),一個(gè)8001,一個(gè)8000,來(lái)測(cè)試我們是否成功部署了多個(gè)服務(wù)提供者且可以正常負(fù)載。
點(diǎn)擊設(shè)置,選擇ProviderZookeeper8001Application的Single Instance only勾選去掉,先啟動(dòng)一個(gè)8000端口,修改端口號(hào)為8001再啟動(dòng)第二個(gè),一個(gè)項(xiàng)目啟動(dòng)多個(gè)程序自行百度有多種方案,idea版本不一樣可能會(huì)有區(qū)別。


訪問(wèn)http://localhost:8002/consumer/zk/getProviderPort可以發(fā)現(xiàn),8000端口與8001端口先后出現(xiàn),至此我們使用zookeeper作為注冊(cè)中心就完成了。


如果zookeeper是集群部署,那么填寫配置spring.cloud.zookeeper.connect-string使用集群的多個(gè)地址,用英文逗號(hào)分割,例如10.1.1.1:2181,10.1.1.2:2181,10.1.1.3:2181
到此這篇關(guān)于SpringCloud zookeeper作為注冊(cè)中心使用介紹的文章就介紹到這了,更多相關(guān)SpringCloud zookeeper內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- SpringCloud中的Eureka注冊(cè)中心詳細(xì)解讀
- springcloud本地服務(wù)不注冊(cè)到注冊(cè)中心的解決方案
- SpringCloud注冊(cè)中心之consul詳細(xì)講解使用方法
- SpringCloud?Eureka服務(wù)注冊(cè)中心應(yīng)用入門詳解
- SpringBoot項(xiàng)目改為SpringCloud項(xiàng)目使用nacos作為注冊(cè)中心的方法
- Java之SpringCloud nocos注冊(cè)中心講解
- 淺析SpringCloud Alibaba-Nacos 作為注冊(cè)中心示例代碼
- Springcloud-nacos實(shí)現(xiàn)配置和注冊(cè)中心的方法
- springcloud實(shí)現(xiàn)注冊(cè)中心Eureka
- SpringCloud兩種注冊(cè)中心的實(shí)現(xiàn)
相關(guān)文章
SpringMVC+Mybatis實(shí)現(xiàn)的Mysql分頁(yè)數(shù)據(jù)查詢的示例
本篇文章主要介紹了SpringMVC+Mybatis實(shí)現(xiàn)的Mysql分頁(yè)數(shù)據(jù)查詢的示例,具有一定的參考價(jià)值,有興趣的可以了解一下2017-08-08
淺談Java讀寫注冊(cè)表的方式Preferences與jRegistry
這篇文章主要介紹了淺談Java讀寫注冊(cè)表的方式Preferences與jRegistry,分享了相關(guān)代碼示例,小編覺(jué)得還是挺不錯(cuò)的,具有一定借鑒價(jià)值,需要的朋友可以參考下2018-02-02
java抓取網(wǎng)頁(yè)或文件中的郵箱號(hào)碼
這篇文章主要為大家詳細(xì)介紹了java如何抓取網(wǎng)頁(yè)或文件中的郵箱號(hào)碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-03-03
SpringMVC?bean實(shí)現(xiàn)加載控制方法詳解
SpringMVC是一種基于Java,實(shí)現(xiàn)了Web?MVC設(shè)計(jì)模式,請(qǐng)求驅(qū)動(dòng)類型的輕量級(jí)Web框架,即使用了MVC架構(gòu)模式的思想,將Web層進(jìn)行職責(zé)解耦。基于請(qǐng)求驅(qū)動(dòng)指的就是使用請(qǐng)求-響應(yīng)模型,框架的目的就是幫助我們簡(jiǎn)化開發(fā),SpringMVC也是要簡(jiǎn)化我們?nèi)粘eb開發(fā)2022-08-08
詳解Spring Boot加載properties和yml配置文件
本篇文章主要介紹了詳解Spring Boot加載properties和yml配置文件,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-04-04
Java?數(shù)據(jù)交換?Json?和?異步請(qǐng)求?Ajax詳解
Json(JavaScript Object Notation)是一種輕量級(jí)的數(shù)據(jù)交換格式,采用鍵值對(duì)的形式來(lái)表示數(shù)據(jù),它廣泛應(yīng)用于Web開發(fā)中,特別適合于前后端數(shù)據(jù)傳輸和存儲(chǔ),這篇文章主要介紹了Java數(shù)據(jù)交換Json和異步請(qǐng)求Ajax,需要的朋友可以參考下2023-09-09

