Zookeeper是一个分布式协调工具,可以实现注册中心功能
安装Zookeeper
data:image/s3,"s3://crabby-images/20808/20808f7a8acf467958ed09fbd76cad2cce72eb38" alt=""
随便 就用最新版本吧
data:image/s3,"s3://crabby-images/f517d/f517d92857db87ff16b7af976f269531aeda88f1" alt=""
data:image/s3,"s3://crabby-images/25dcd/25dcd6062d5494d0aa54b6a87a9d579afac7e274" alt=""
data:image/s3,"s3://crabby-images/0588d/0588d636fabce8d97c76b74826d0fe9f06dcfe5b" alt=""
进入Zookeeper 包目录
cd /usr/local/develop/
解压
tar -zxvf apache-zookeeper-3.9.1-bin.tar.gz -C /usr/local/develop
进入配置文件
cd /usr/local/develop/apache-zookeeper-3.9.1-bin/conf
复制文件
cp zoo_sample.cfg zoo.cfg
data:image/s3,"s3://crabby-images/dd803/dd80364b7f298323336969833298b5b5ebfa7acf" alt=""
编辑文件
vim zoo.cfg
data:image/s3,"s3://crabby-images/3ab6e/3ab6eefe09814e0595303a53e3e35eb4c472d576" alt=""
mkdir /usr/local/develop/apache-zookeeper-3.9.1-bin/data 这个没必要 会自动创建
cd /usr/local/develop/apache-zookeeper-3.9.1-bin/bin
启动Zookeeper
./zkServer.sh start
data:image/s3,"s3://crabby-images/c8058/c80582c46a6cef2e72e05eea2fb030a11e392450" alt=""
安装JDK
data:image/s3,"s3://crabby-images/4ac99/4ac99c127dd7566ae5e1230b1afab91f4897d260" alt=""
解压
tar -zxvf /usr/local/develop/jdk-8u191-linux-x64.tar.gz -C /usr/local/develop
配置JAVA_HOME
export JAVA_HOME=/usr/local/develop/jdk1.8.0_191
export PATH=JAVA_HOME/bin:PATH
export CLASSPATH=.:$JAVA_HOME/lib
data:image/s3,"s3://crabby-images/db279/db27900394540158372a12c72be19b87eac017b6" alt=""
让环境变量生效
source /etc/profile
java -version 查看jdk版本 至此JDK安装完成
which java 查看调用的是安装在哪里的java
data:image/s3,"s3://crabby-images/7bcb7/7bcb7ce818d4b344dd43ab3d6fe4aaf363c101ee" alt=""
进入Zookeeper启动目录
cd /usr/local/develop/apache-zookeeper-3.9.1-bin/bin
启动
./zkServer.sh start
停止
./zkServer.sh stop
配置Zookeeper为系统服务
vim /etc/systemd/system/zookeeper.service
data:image/s3,"s3://crabby-images/72d4e/72d4eb0d0d67d28ff41b1fa6a5dab9378b3313b4" alt=""
[Unit]
Description=Apache ZooKeeper server
After=network.target
[Service]
Type=forking
ExecStart=/usr/local/develop/apache-zookeeper-3.9.1-bin/bin/zkServer.sh start
ExecStop=/usr/local/develop/apache-zookeeper-3.9.1-bin/bin/zkServer.sh stop
User=root
Group=root
Restart=on-failure
Environment="JAVA_HOME=/usr/local/develop/jdk1.8.0_191"
[Install]
WantedBy=multi-user.target
是配置生效
systemctl daemon-reload
开机自启 看自己实际需要
systemctl enable zookeeper.service
systemctl start zookeeper.service 启动
systemctl stop zookeeper.service 停止
systemctl restart zookeeper.service 重启
systemctl status zookeeper.service 查看状态
admin.serverPort=8888
指定了ZooKeeper的管理服务器端口。这个管理服务器提供了一个简单的HTTP接口,用于获取ZooKeeper服务的状态和性能指标等信息。通过访问这个端口,你可以获取到ZooKeeper实例的各种管理信息,比如运行状态、连接数、节点数量等。
默认情况下,ZooKeeper的管理界面并不提供一个全面的Web界面来浏览这些信息,而是提供了一个简单的HTTP服务,通过发送HTTP请求到这个端口,可以获取到JSON格式的状态信息。
IP:8888/commands/stat
data:image/s3,"s3://crabby-images/634ee/634eed46903704a133ecffc7ff129fe50d630204" alt=""
关闭Zookeeper服务
systemctl stop zookeeper.service
systemctl start zookeeper.service
Docker安装Zookeeper
docker run -d --name zookeeper --privileged=true -p 2181:2181 -v /mydata/zookeeper/data:/data -v /mydata/zookeeper/conf:/conf -v /mydata/zookeeper/logs:/datalog zookeeper:3.5.7
后面补
创建支付模块(生产者)
data:image/s3,"s3://crabby-images/054c4/054c467527c04489dbea5ccbebad73f6746ec472" alt=""
重新构建支付模块
data:image/s3,"s3://crabby-images/80781/8078174f8c0e305c26c685ffc25adc46c240e60e" alt=""
data:image/s3,"s3://crabby-images/5d237/5d237b63e201ee3a36fe26e6d1eedc17fbf867d5" alt=""
data:image/s3,"s3://crabby-images/94516/945164f42e9f2061e070f8b09bd9d6737e4f9722" alt=""
pom.xml
<?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 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<artifactId>SpringCloud</artifactId>
<groupId>org.example</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>cloud-provider-payment8084</artifactId>
<properties>
<maven.compiler.source>8</maven.compiler.source>
<maven.compiler.target>8</maven.compiler.target>
</properties>
<dependencies>
<dependency>
<groupId>org.example</groupId>
<artifactId>cloud-api-commons</artifactId>
<version>${project.version}</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.springframework.boot/spring-boot-starter-web -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!-- https://mvnrepository.com/artifact/org.springframework.boot/spring-boot-starter-web -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<!-- https://mvnrepository.com/artifact/org.springframework.cloud/spring-cloud-starter-zookeeper-discovery -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-zookeeper-discovery</artifactId>
</dependency>
<!-- https://mvnrepository.com/artifact/org.springframework.boot/spring-boot-devtools -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<scope>runtime</scope>
<optional>true</optional>
</dependency>
<!-- https://mvnrepository.com/artifact/org.projectlombok/lombok -->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
<!-- https://mvnrepository.com/artifact/org.springframework.boot/spring-boot-starter-test -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
</project>
application.yml
server:
port: 8084
spring:
application:
name: cloud-provider-payment
cloud:
zookeeper:
connect-string: xxx.xx.xxx.x:2181
启动类
data:image/s3,"s3://crabby-images/b87b8/b87b86ea455c300efc6fe6f4242b2032c7328d0c" alt=""
控制器
package com.exempla.pay01.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.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import java.util.UUID;
/**
* @author hrui
* @date 2024/3/2 6:07
*/
@RestController
@Slf4j
@RequestMapping("/payment")
public class PaymentController {
@Value("${server.port}")
private String serverPort;
@GetMapping(value = "/zk")
public String paymentzk(){
return "springcloud with zookeeper:"+serverPort+"\t"+ UUID.randomUUID().toString();
}
}
启动8084 注册进Zookeeper lombok找不到 加个版本
记得Zookeeper服务器开通安全组
有可能版本冲突 解决办法
data:image/s3,"s3://crabby-images/88e3e/88e3ee9cf2da7e7467571b5e5871e6322bb822ba" alt=""
cd /usr/local/develop/apache-zookeeper-3.9.1-bin/bin
./zkCli.sh
ls /
data:image/s3,"s3://crabby-images/106ed/106ed9a3d535d85ac610c758eb2d84a0c902cc53" alt=""
ls /services
data:image/s3,"s3://crabby-images/3e290/3e290a789b90324caaa73c71253ca6a1d8cda2dc" alt=""
ls /services/cloud-provider-payment
data:image/s3,"s3://crabby-images/e4126/e4126dc9e5eba60075e869996fe2b4f5f3f1634d" alt=""
ls /services/cloud-provider-payment/04bbfd46-50e0-462a-bd22-b8083cc445cf
data:image/s3,"s3://crabby-images/99fd5/99fd542716132acf3eb7551fe96470182c25abe9" alt=""
get /services/cloud-provider-payment/04bbfd46-50e0-462a-bd22-b8083cc445cf
data:image/s3,"s3://crabby-images/66889/6688932fd5a3d46f2ddf5e4d43fa87e183a0425a" alt=""
上面这个JSON串 就是微服务注册相关的信息
data:image/s3,"s3://crabby-images/83d87/83d875fc3853761d8a016397316217e316e26a9c" alt=""
quit
data:image/s3,"s3://crabby-images/e4def/e4def2be8640556a3e3b1573c64cdf49d7131e0a" alt=""
也可以
访问接口 可以
localhost:8084/payment/zkhttp://localhost:8084/payment/zk
创建订单模块(消费者)
pom.xml
<dependencies>
<dependency>
<groupId>com.atguigu.springcloud</groupId>
<artifactId>cloud-api-commons</artifactId>
<version>${project.version}</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.springframework.boot/spring-boot-starter-web -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!-- https://mvnrepository.com/artifact/org.springframework.boot/spring-boot-starter-web -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<!-- https://mvnrepository.com/artifact/org.springframework.cloud/spring-cloud-starter-zookeeper-discovery -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-zookeeper-discovery</artifactId>
</dependency>
<!-- https://mvnrepository.com/artifact/org.springframework.boot/spring-boot-devtools -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<scope>runtime</scope>
<optional>true</optional>
</dependency>
<!-- https://mvnrepository.com/artifact/org.projectlombok/lombok -->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
<!-- https://mvnrepository.com/artifact/org.springframework.boot/spring-boot-starter-test -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
启动类
data:image/s3,"s3://crabby-images/38075/38075b35c3bbe2e82fca02ed4a5525113d47edcf" alt=""
application.yml
server:
port: 80
spring:
application:
name: cloud-consumer-order
cloud:
zookeeper:
connect-string: xxx.xx.xx.x:2181
配置RestTemplate和负载均衡
data:image/s3,"s3://crabby-images/ae8e6/ae8e6ae6a06d3afdb42c10cf1801f069d085e892" alt=""
控制器
data:image/s3,"s3://crabby-images/44173/4417363e980c3b5fe47a85bf9c50ace901b5f77d" alt=""
启动服务
data:image/s3,"s3://crabby-images/65c3d/65c3ddd5b45ee1251c359d782d1829779e3e646e" alt=""
data:image/s3,"s3://crabby-images/238b2/238b2a0ce8a13c871379123f671897ea3fdf3d62" alt=""
关于@EnableDiscoveryClient 注解 早期版本确实生产者和消费者启动类要加 后来就不需要了
data:image/s3,"s3://crabby-images/5c69c/5c69c3249fa50e7c1ede5ac8f92dc7f6e841c251" alt=""
data:image/s3,"s3://crabby-images/565ba/565ba9b496d8018afb1ef149e10c507498e23ba4" alt=""