前言:在上一章节中我们说明了一些关于Eureka自我保护模式,而且自上一章节起关于Eureka的知识已经讲的差不多了,不过因为Eureka已经停更了,为了安全考虑,我们要用还在更新维护的注册中心来取代Eureka,而本章节则是关于如何使用Zookeeper来代替Eureka
Eureka停更说明:https://github.com/Netflix/eureka/wiki
大意就是Eureka2.0停更了,如果要继续使用Eureka,所产生的风险一切自负

准备环境:
需要先安装Zookeeper,如果没有安装的同学可以参考以下文章来进行安装
https://blog.csdn.net/m0_64284147/article/details/132260865



效果图:

例:
- "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 http://maven.apache.org/xsd/maven-4.0.0.xsd">
- <parent>
- <artifactId>springcloud01artifactId>
- <groupId>com.ken.springcloudgroupId>
- <version>1.0-SNAPSHOTversion>
- parent>
- <modelVersion>4.0.0modelVersion>
-
- <artifactId>provider-payment8004artifactId>
-
- <dependencies>
-
- <dependency>
- <groupId>org.springframework.bootgroupId>
- <artifactId>spring-boot-starter-webartifactId>
- dependency>
-
- <dependency>
- <groupId>org.springframework.bootgroupId>
- <artifactId>spring-boot-devtoolsartifactId>
- <scope>runtimescope>
- <optional>trueoptional>
- dependency>
-
- <dependency>
- <groupId>org.projectlombokgroupId>
- <artifactId>lombokartifactId>
- <optional>trueoptional>
- dependency>
- <dependency>
- <groupId>org.springframework.bootgroupId>
- <artifactId>spring-boot-starter-testartifactId>
- <scope>testscope>
- dependency>
-
- <dependency>
- <groupId>com.ken.springcloudgroupId>
- <artifactId>api-commonsartifactId>
- <version>${project.version}version>
- dependency>
-
- <dependency>
- <groupId>org.springframework.cloudgroupId>
- <artifactId>spring-cloud-starter-zookeeper-discoveryartifactId>
- dependency>
- dependencies>
-
- project>

效果图:

- #服务端口号
- server:
- port: 8004
-
- #服务名称
- spring:
- application:
- name: cloud-payment-service
- cloud:
- zookeeper:
- #zookeeper所在服务的ip和Client的端口号
- connect-string: 192.168.194.130:2181

效果图:

- package com.ken.springcloud;
-
- import org.springframework.boot.SpringApplication;
- import org.springframework.boot.autoconfigure.SpringBootApplication;
- import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
-
- @SpringBootApplication
- //该注解用于向使用consul或zookeeper作为注册中心时注册服务
- @EnableDiscoveryClient
- public class PaymentMain8004 {
- public static void main(String[] args) {
- SpringApplication.run(PaymentMain8004.class, args);
- }
- }
效果图:


效果图:

- package com.ken.springcloud.controller;
-
- import lombok.extern.slf4j.Slf4j;
- import org.springframework.beans.factory.annotation.Value;
- import org.springframework.web.bind.annotation.GetMapping;
- import org.springframework.web.bind.annotation.RestController;
-
- import java.util.UUID;
-
- @RestController
- @Slf4j
- public class PaymentController {
-
- @Value("${server.port}")
- private String serverPort;
-
- @GetMapping("/payment/zk")
- public String paymentzk() {
- return "springcloud with zookeeper:" + serverPort + "\t" + UUID.randomUUID();
- }
-
- }
./zkServer.sh start
效果图:

./zkCli.sh
效果图:

ls /
可以发现现在zookeeper里的节点就只有一个
效果图:
![]()
效果图:

ls /
可以发现多出了一个services的节点
效果图:
![]()
ls /services
可以看到services节点的里有个名为cloud-payment-service的服务,这个服务就是我们的provider-payment8004服务,这证明provider-payment8004成功注册进了zookeeper里
效果图:
![]()

在地址栏输入http://localhost:8004/payment/zk并回车调用接口,可以看到数据返回成功

ls /services/cloud-payment-service
效果图:
![]()
get /services/cloud-payment-service/636ff382-1979-4bcb-a0a2-e1aec44e79ce
效果图:

格式化后的json串:
其他:
1、注册进zookeeper的服务是临时节点
在把服务关停后,zookeeper检测不到服务的心跳后过一会就会把服务剔除,重新启动服务后又会恢复,但这时候服务的流水号就会改变
效果图:
