SpringCloud使用Zookeeper作為注冊(cè)中心
服務(wù)注冊(cè)
引入相關(guān)依賴:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.4.5</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.example</groupId>
<artifactId>zkdemo</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>zkdemo</name>
<description>Demo project for Spring Boot</description>
<properties>
<java.version>1.8</java.version>
<spring-cloud.version>2020.0.2</spring-cloud.version>
</properties>
<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>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring-cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
配置文件application.yml:
spring:
cloud:
zookeeper:
# Zookeeper服務(wù)器地址,集群則以逗號(hào)分隔
connect-string: localhost:2181
application:
name: zkdemo
# 使用隨機(jī)端口
server:
port: 0
主程序類ZkdemoApplication:
@SpringBootApplication
public class ZkdemoApplication {
public static void main(String[] args) {
SpringApplication.run(ZkdemoApplication.class, args);
}
}
由于配置了使用隨機(jī)端口,這里直接啟動(dòng)三個(gè)ZkdemoApplication運(yùn)行三個(gè)zkdemo服務(wù)示例。
啟動(dòng)成功后,在zookeeper中查看節(jié)點(diǎn)的變化,會(huì)發(fā)現(xiàn)在根節(jié)點(diǎn)下多出來(lái)一個(gè)services節(jié)點(diǎn),services節(jié)點(diǎn)下是以服務(wù)名稱命名的服務(wù)節(jié)點(diǎn),服務(wù)節(jié)點(diǎn)下是該服務(wù)的實(shí)例節(jié)點(diǎn)。
[zk: localhost:2181(CONNECTED) 96] ls -R / / /services /services/zkdemo /services/zkdemo/2030bca0-db25-411d-b1f5-84c790bd1d6f /services/zkdemo/208834cf-e7e4-496e-a5c0-afcbb78e120f /services/zkdemo/2c4177e1-20fd-4c66-9ee0-eaf21253039d
實(shí)例節(jié)點(diǎn)中存儲(chǔ)了服務(wù)名稱、ip地址、端口號(hào)、實(shí)例ID等相關(guān)信息:
[zk: localhost:2181(CONNECTED) 97] get /services/zkdemo/208834cf-e7e4-496e-a5c0-afcbb78e120f
{"name":"zkdemo","id":"208834cf-e7e4-496e-a5c0-afcbb78e120f","address":"localhost","port":64514,"sslPort":null,"payload":{"@class":"org.springframework.cloud.zookeeper.discovery.ZookeeperInstance","id":"zkdemo","name":"zkdemo","metadata":{"instance_status":"UP"}},"registrationTimeUTC":1619424602784,"serviceType":"DYNAMIC","uriSpec":{"parts":[{"value":"scheme","variable":true},{"value":"://","variable":false},{"value":"address","variable":true},{"value":":","variable":false},{"value":"port","variable":true}]}}
[zk: localhost:2181(CONNECTED) 98] get /services/zkdemo/2030bca0-db25-411d-b1f5-84c790bd1d6f
{"name":"zkdemo","id":"2030bca0-db25-411d-b1f5-84c790bd1d6f","address":"localhost","port":64401,"sslPort":null,"payload":{"@class":"org.springframework.cloud.zookeeper.discovery.ZookeeperInstance","id":"zkdemo","name":"zkdemo","metadata":{"instance_status":"UP"}},"registrationTimeUTC":1619424361059,"serviceType":"DYNAMIC","uriSpec":{"parts":[{"value":"scheme","variable":true},{"value":"://","variable":false},{"value":"address","variable":true},{"value":":","variable":false},{"value":"port","variable":true}]}}
[zk: localhost:2181(CONNECTED) 99] get /services/zkdemo/2c4177e1-20fd-4c66-9ee0-eaf21253039d
{"name":"zkdemo","id":"2c4177e1-20fd-4c66-9ee0-eaf21253039d","address":"localhost","port":64475,"sslPort":null,"payload":{"@class":"org.springframework.cloud.zookeeper.discovery.ZookeeperInstance","id":"zkdemo","name":"zkdemo","metadata":{"instance_status":"UP"}},"registrationTimeUTC":1619424510719,"serviceType":"DYNAMIC","uriSpec":{"parts":[{"value":"scheme","variable":true},{"value":"://","variable":false},{"value":"address","variable":true},{"value":":","variable":false},{"value":"port","variable":true}]}}
通過(guò)ephemeralOwner字段可以看出,services節(jié)點(diǎn)和服務(wù)節(jié)點(diǎn)為持久節(jié)點(diǎn),實(shí)例節(jié)點(diǎn)為臨時(shí)節(jié)點(diǎn):
[zk: localhost:2181(CONNECTED) 100] stat /services cZxid = 0x118 ctime = Mon Apr 26 16:06:02 CST 2021 mZxid = 0x118 mtime = Mon Apr 26 16:06:02 CST 2021 pZxid = 0x119 cversion = 1 dataVersion = 0 aclVersion = 0 ephemeralOwner = 0x0 dataLength = 0 numChildren = 1 [zk: localhost:2181(CONNECTED) 101] stat /services/zkdemo cZxid = 0x119 ctime = Mon Apr 26 16:06:02 CST 2021 mZxid = 0x119 mtime = Mon Apr 26 16:06:02 CST 2021 pZxid = 0x11e cversion = 3 dataVersion = 0 aclVersion = 0 ephemeralOwner = 0x0 dataLength = 0 numChildren = 3 [zk: localhost:2181(CONNECTED) 102] stat /services/zkdemo/2030bca0-db25-411d-b1f5-84c790bd1d6f cZxid = 0x11a ctime = Mon Apr 26 16:06:02 CST 2021 mZxid = 0x11a mtime = Mon Apr 26 16:06:02 CST 2021 pZxid = 0x11a cversion = 0 dataVersion = 0 aclVersion = 0 ephemeralOwner = 0x100000122cf000d dataLength = 514 numChildren = 0
當(dāng)某個(gè)實(shí)例出現(xiàn)故障停止時(shí),對(duì)應(yīng)的臨時(shí)節(jié)點(diǎn)也會(huì)被刪除。當(dāng)服務(wù)節(jié)點(diǎn)下所有實(shí)例節(jié)點(diǎn)被刪除時(shí),服務(wù)節(jié)點(diǎn)也會(huì)被刪除。當(dāng)services節(jié)點(diǎn)下的所有服務(wù)節(jié)點(diǎn)被刪除時(shí),services節(jié)點(diǎn)也會(huì)被刪除。
服務(wù)發(fā)現(xiàn)
通過(guò)DiscoveryClient從注冊(cè)中心獲取對(duì)應(yīng)服務(wù)的實(shí)例列表:
@SpringBootTest
class ZkdemoApplicationTests {
@Autowired
private DiscoveryClient discoveryClient;
@Test
public void serviceUrl() {
List<ServiceInstance> list = discoveryClient.getInstances("zkdemo");
list.stream().forEach(obj -> System.out.println(obj.getUri().toString()));
}
}
輸出結(jié)果:
http://localhost:64401 http://localhost:64475 http://localhost:64514
服務(wù)調(diào)用這里就不演示了,可以使用Feign或RestTemplate進(jìn)行調(diào)用。
以上就是SpringCloud使用Zookeeper作為注冊(cè)中心的詳細(xì)內(nèi)容,更多關(guān)于Zookeeper作為注冊(cè)中心的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
利用Mybatis向PostgreSQL中插入并查詢JSON字段
這篇文章主要介紹了利用Mybatis向PostgreSQL中插入并查詢JSON字段,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-07-07
Spring中@RestControllerAdvice注解的使用詳解
這篇文章主要介紹了Spring中@RestControllerAdvice注解的使用詳解,@RestControllerAdvice是一個(gè)組合注解,由@ControllerAdvice、@ResponseBody組成,而@ControllerAdvice繼承了@Component,需要的朋友可以參考下2024-01-01
RedisTemplate.opsForHash()用法簡(jiǎn)介并舉例說(shuō)明
redistemplate.opsforhash是RedisTemplate模板類中的一個(gè)方法,用于獲取操作哈希數(shù)據(jù)類型的接口,這篇文章主要給大家介紹了關(guān)于RedisTemplate.opsForHash()用法簡(jiǎn)介并舉例說(shuō)明的相關(guān)資料,需要的朋友可以參考下2024-06-06
JDK14新特性之switch表達(dá)式的實(shí)現(xiàn)
這篇文章主要介紹了JDK14新特性之switch表達(dá)式的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05
java創(chuàng)建一個(gè)類實(shí)現(xiàn)讀取一個(gè)文件中的每一行顯示出來(lái)
下面小編就為大家?guī)?lái)一篇java創(chuàng)建一個(gè)類實(shí)現(xiàn)讀取一個(gè)文件中的每一行顯示出來(lái)的實(shí)例。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-01-01
Springboot 整合 Dubbo/ZooKeeper 實(shí)現(xiàn) SOA 案例解析
這篇文章主要介紹了Springboot 整合 Dubbo/ZooKeeper 詳解 SOA 案例,需要的朋友可以參考下2017-11-11
Java 實(shí)現(xiàn)多線程切換等待喚醒交替打印奇偶數(shù)
這篇文章主要介紹了Java 實(shí)現(xiàn)多線程切換等待喚醒交替打印奇偶數(shù) ,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-05-05

