步驟如下:
**1. 構建消費端模塊:cloud-comsumerzk-order80**
**2. 當前模塊添加 zookeeper-discovery 依賴**
```xml
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-zookeeper-discovery</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
</dependency>
...
</dependencies>
```
**3. 在當前模塊的`application.yml`配置 zookeeper 相關**
```yml
server:
port: 80
spring:
application:
name: cloud-comsumer-order
cloud:
zookeeper:
#zookeeper地址
connect-string: 192.168.1.17:2181
```
**4. 在當前啟動類上標注注解`@EnableDiscoveryClient`**
```java
@SpringBootApplication
@EnableDiscoveryClient
public class OrderZKMain80 {
public static void main(String[] args) {
SpringApplication.run(OrderZKMain80.class, args);
}
}
```
**5. 在當前模塊注入 RestTemplate 組件方便訪問服務端**
```java
@Configuration
public class ApplicationContextConfig {
@Bean
@LoadBalanced
public RestTemplate getRestTemplate() {
return new RestTemplate();
}
}
```
**6. 當前模塊的 controller 層**
```java
@RestController
@RequestMapping("/comsumer")
public class OrderController {
@Resource
private RestTemplate restTemplate;
//cloud-payment-service 為服務端的 spring.application.name 配置
public static final String PAYENT_URL = "http://cloud-payment-service";
@GetMapping("/payment/zk")
public String getpaymentInfo() {
String res = restTemplate.getForObject(PAYENT_URL + "/payment/zk", String.class);
return res;
}
}
```
**7. 測試**
(1)啟動 Zookeeper。
```shell
# zkServer.sh start
# jps
2621 QuorumPeerMain --出現該進行則啟動成功
```
記住需要到 Linux 中關閉防火墻,外面應用才可以訪問到 Zookeeper。
```shell
-- 關閉防火墻
# systemctl stop firewalld
--查看防火墻是否關閉
# firewall-cmd --state
not running
-- 禁止防火墻開機自啟動
# systemctl disable firewalld.service
```
(2)啟動服務端模塊、消費端模塊。
訪問消費端模塊:http://localhost:80/comsumer/payment/zk 。得到如下響應。
```
serverPort:8004
```
(3)到 Zookeeper 中查看消費端的注冊信息。
```shell
--切換到 Zookeeper 的安裝目錄
# cd /opt/install/zookeeper
--啟動 zookeeper 客戶端工具
# bin/zkCli.sh
--查看 zookeeper 節點
[zk: localhost:2181(CONNECTED) 16] ls /
[services, zookeeper]
[zk: localhost:2181(CONNECTED) 17] ls /services
[cloud-comsumer-order, cloud-payment-service]
[zk: localhost:2181(CONNECTED) 18] ls /services/cloud-comsumer-order
[476aad5c-4f02-44b2-b42d-741bea0ed116]
--獲取節點信息
[zk: localhost:2181(CONNECTED) 19] get /services/cloud-comsumer-order/476aad5c-4f02-44b2-b42d-741bea0ed116
{"name":"cloud-comsumer-order","id":"476aad5c-4f02-44b2-b42d-741
```
完整的注冊信息如下:
```json
{
"name":"cloud-comsumer-order",
"id":"476aad5c-4f02-44b2-b42d-741bea0ed116",
"address":"USER-20210829ES",
"port":80,
"sslPort":null,
"payload":{
"@class":"org.springframework.cloud.zookeeper.discovery.ZookeeperInstance",
"id":"application-1",
"name":"cloud-comsumer-order",
"metadata":{
}
},
"registrationTimeUTC":1637399316399,
"serviceType":"DYNAMIC",
"uriSpec":{
"parts":[
{
"value":"scheme",
"variable":true
},
{
"value":"://",
"variable":false
},
{
"value":"address",
"variable":true
},
{
"value":":",
"variable":false
},
{
"value":"port",
"variable":true
}
]
}
}
```
- 微服務
- 微服務是什么?
- 微服務架構
- 微服務優缺點
- 微服務技術棧
- 微服務框架對比
- SpringCloud
- SpringCloud是什么
- SpringCloud與SpringBoot對比
- SpringCloud與Dubbo對比
- Rest微服務案例
- 總體介紹
- 父工程構建步驟
- 公共模塊構建步驟
- 服務端模塊構建步驟
- 消費端模塊構建步驟
- Eureka服務注冊與發現
- Eureka是什么
- Eureka原理
- Eureka注冊服務中心構建
- 向Eureka注冊已有微服務
- Eureka的自我保護機制
- Eureka服務發現
- Eureka集群配置
- Eureka與Zookeeper對比
- Ribbon負載均衡
- Ribbon是什么
- Ribbon負載均衡演示
- 構建服務端模塊
- 構建消費端模塊
- Ribbon核心組件IRule
- 自定義負載均衡策略
- Ribbon均衡策略優先級
- 輪詢策略算法
- OpenFeign負載均衡
- OpenFeign是什么
- 負載均衡演示
- 日志打印功能
- 導出功能
- Hystrix斷路器
- Hystrix是什么
- 服務熔斷
- Hystrix服務端構建
- 服務熔斷演示
- 服務熔斷類型
- HystrixProperty配置匯總
- 服務降級
- Hystrix客戶端構建
- 服務降級演示
- fallbackFactory
- 熔斷與降級
- 服務監控
- 網關服務Zuul
- Zuul是什么
- Zuul路由服務構建
- 設置訪問映射規則
- Config分布式配置中心
- Config分布式配置中心是什么
- Config服務端與Git通信
- Config客戶端獲取配置
- Config客戶端動態刷新
- Bus消息總線
- Bus消息總線是什么
- Bus消息總線原理
- 廣播通知設計思想
- 廣播通知演示
- 定點通知演示
- Stream消息驅動
- 為什么要引入Stream
- Stream消息驅動是什么
- Stream設計思想
- Stream流程和注解
- Stream案例演示
- 重復消費問題
- 消息持久化
- Sleuth分布式鏈路跟蹤
- Sleuth是什么
- 搭建鏈路監控
- SpringCloud Alibaba
- Nacos注冊與配置中心
- Nacos是什么
- 安裝并運行Nacos
- Nacos注冊中心
- 服務端入住Nacos
- 消費端入住Nacos
- Nacos負載均衡演示
- 服務注冊中心對比
- Nacos的AP和CP轉化
- Nacos配置中心
- 基礎配置演示
- Nacos分類配置
- Nacos集群搭建
- Sentinel實現熔斷與限流
- Sentinel是什么
- Sentinel環境搭建
- Sentinel監控微服務演示
- Sentinel流控規則
- 流量監控的作用
- 設置流控規則
- Sentinel降級規則
- 熔斷降級作用
- 設置降級規則
- Sentinel熱點限流
- 什么是熱點
- 設置熱點限流
- Sentinel系統限流
- @SentinelResource
- @SentinelResource屬性
- @SentinelResource限流演示
- @SentinelResource熔斷演示
- 規則持久化
- 熔斷框架比較
- Seata分布式事務
- 分布式事務問題
- Seata是什么
- Seata分布式事務過程
- Seata環境搭建
- 演示示例
- 業務說明
- 數據庫環境準備
- 微服務環境準備
- 測試
- Consul服務注冊與發現
- Consul是什么
- Consul能做什么
- 環境搭建
- Windows平臺
- 服務端入住Consul
- 消費端入住Consul
- 注冊中心對比
- Zookeeper服務注冊與發現
- Zookeeper是什么
- 環境搭建
- 服務端入住Zookeeper
- 消費端入住Zookeeper
- 網關服務Gateway
- Gateway是什么
- Gateway能做什么
- Gateway對比Zuul
- 三大核心概念
- Gateway工作流
- 環境搭建
- 網關路由配置方式
- 配置文件配置
- 代碼中配置
- 動態路由
- Predicate斷言
- 斷言是什么
- 常用斷言
- Filter過濾器
- 過濾器是什么
- 過濾器種類
- 自定義過濾器