一句话总结
1. Eureka已停止更新
2. Zookeeper能替换Eureka,用于服务注册与发现,实现负载均衡和容错
springboot 整合zookeeper
1、在新建支付服务8004的pom.xml中添加依赖
1. Zookeeper安装于Linux上,关闭了防火墙
2. 虚拟机上的Linux能与本地ping通,进行通信
注意 添加的zookeeper版本要与自己安装在服务器上的一致。——本地会自带版本,引发错误
怎么在控制台读错误的信息?
1. 与自己公司名或项目名相关的行
2. 如果是函数入口报错,这是固定写法,说明错误在配置上
《! pom.xml 》
<dependencies>
<dependency>
<groupId>org.xzq.springcloud</groupId>
<artifactId>cloud-api-commons</artifactId>
<version>${project.version}</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!--SpringBoot整合Zookeeper客户端-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-zookeeper-discovery</artifactId>
<exclusions>
<!--先排除自带的zookeeper3.5.3-->
<exclusion>
<groupId>org.apache.zookeeper</groupId>
<artifactId>zookeeper</artifactId>
</exclusion>
</exclusions>
</dependency>
<!--添加zookeeper3.4.6版本 -->
<dependency>
<groupId>org.apache.zookeeper</groupId>
<artifactId>zookeeper</artifactId>
<version>3.4.6</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<scope>runtime</scope>
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
2、在8004中配置application.yml文件
《! 服务端口号和应用名是必不可少的》——测试,能在Linux的/目录下看到service/ cloud-provider-payment
server:
port: 8004
spring:
application:
name: cloud-provider-payment
cloud:
zookeeper:
connect-string: 118.178.91.123:2181
3、编写控制层代码
@RestController
@RequestMapping("/payment")
public class PaymentController {
@Value("${server.port}")
private String SERVER_PORT;
@RequestMapping("/zk")
public String paymentZK() {
return "springcloud with zookeeper :" + SERVER_PORT + "\t" + UUID.randomUUID().toString();
}
}
问题:zookeeper中的节点是持久还是临时的?
答:临时的。一旦一段时间没有心跳,Zookeeper会立刻删除节点。