目錄
前言
參考資料:
《Spring Microservices in Action》
《Spring Cloud Alibaba 微服務原理與實戰》
《B站 尚矽谷 SpringCloud 框架開發教程 周陽》
《Consul 官網》
Consul 是一套開源的分散式服務發現和配置管理系統,由 HashiCorp 公司用 Go 語言開發。它提供了微服務系統中的服務治理、配置中心、控制匯流排等功能。這些功能中的每一個都可以根據需要單獨使用,也可以一起使用以構建全方位的服務網格,總之 Consul 提供了一種完整的服務網格解決方案;
1. Consul 基礎知識
1.1 Consul 是什麼
- Consul 是一套開源的分散式服務發現和配置管理系統,由 HashiCorp 公司用 Go 語言開發;
- 提供了微服務系統中的服務治理、配置中心、控制匯流排等功能。這些功能中的每一個都可以根據需要單獨使用,也可以一起使用以構建全方位的服務網格,總之 Consul 提供了一種完整的服務網格解決方案;
- 它具有很多優點。包括:基於 raft 協議,比較簡潔; 支援健康檢查,同時支援 HTTP 和 DNS 協議支援跨資料中心的 WAN 叢集提供圖形介面;跨平臺,支援 Linux、Mac、Windows
1.2 Consul 的特點
- 服務發現:提供 HTTP 和 DNS 兩種發現方式;
- 健康監測:支援多種方式:HTTP、TCP、Docker、Shell 指令碼定製化監控;
- KV 儲存:Key、Value的儲存方式;
- 多資料中心:支援多資料中心;
- 視覺化 Web 介面;
2. 安裝並執行 Consul 伺服器
基於 Win10 下的 Consul 伺服器安裝;
2.1 下載 Consul
-
下載解壓後:
2.2 執行 Consul 伺服器
- 在 consul.exe 程式所在目錄下開啟 cmd 命令視窗;
- 鍵入命令
consul
,顯示下面說明安裝成功;
- 此時鍵入命令
consul agent -dev
使用開發模式啟動;
- 訪問連線可以進入 Consul 首頁:http://localhost:8500;
3. 使用 Consul 管理服務提供者
使用 Consul 構建服務提供者大致與 Nacos 和 Zookeeper 相同;Nacos 與 Zookeeper 的構建方式詳情請見《3.2 Alibaba Nacos 註冊中心》與《3.3 Apache Zookeeper 註冊中心》;
3.1 引入 pom.xml 依賴
<!--SpringCloud consul-server -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-consul-discovery</artifactId>
</dependency>
3.2 修改 boostrap.yml 配置檔案
# consul 服務提供者埠
server:
port: 8006
spring:
application:
name: consul-provider
# consul 註冊中心地址
cloud:
consul:
host: localhost
port: 8500
discovery:
#hostname: 127.0.0.1
service-name: ${spring.application.name}
3.3 在主啟動類上新增註解
- @EnableDiscoveryClient:使用其他元件(Nacos、zookeeper、Consul)作為註冊中心;
3.4 編寫業務類,並在 controller 層開放介面
這裡編寫一個簡單介面僅作為示例;
@RestController
public class providerController{
@Value("${server.port}")
private String serverPort;
@RequestMapping(value = "/provider/consul")
public String providerConsul(){
return "springcloud with consul: "+serverPort+"\t"+ UUID.randomUUID().toString();
}
}
4. 使用 Consul 管理服務消費者
使用 Consul 構建服務消費者大致與 Nacos 和 Zookeeper 相同;Nacos 與 Zookeeper 的構建方式詳情請見《3.2 Alibaba Nacos 註冊中心》與《3.3 Apache Zookeeper 註冊中心》;
4.1 引入 pom.xml 依賴
- 同提供者;
<!--SpringCloud consul-server -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-consul-discovery</artifactId>
</dependency>
4.2 修改 boostrap.yml 配置檔案
- 基本上同提供者;
# consul 服務消費者埠號
server:
port: 80
spring:
application:
name: consul-consumer
# consul 註冊中心地址
cloud:
consul:
host: localhost
port: 8500
discovery:
#hostname: 127.0.0.1
service-name: ${spring.application.name}
4.3 在主啟動類上新增註解
- 同提供者;
- @EnableDiscoveryClient:使用其他元件(Nacos、zookeeper、Consul)作為註冊中心;
4.4 編寫業務類
- 由於我們使用 Ribbon + RestTemplate 的負載均衡策略,因此需要在 IoC 容器中新增一個 RestTemplate JavaBean;
- 詳情請見《4.1 基於 Ribbon 的負載均衡詳解》;
- 該 Bean 可以在主啟動類中新增;也可以在主啟動類所在包或子包的 config 包中新增,如下:
@Configuration
public class ApplicationContextBean{
@Bean
@LoadBalanced
public RestTemplate getRestTemplate(){
return new RestTemplate();
}
}
- 我們在 controller 層開放介面給客戶端,並在該介面裡呼叫提供者的 API;
@RestController
public class ComsumerConsulController{
public static final String INVOKE_URL = "http://consul-provider";
@Autowired
private RestTemplate restTemplate;
@RequestMapping(value = "/consumer/consul")
public String paymentInfo(){
String result = restTemplate.getForObject(INVOKE_URL+"/provider/consul", String.class);
System.out.println("消費者呼叫提供者獲取服務--->result:" + result);
return result;
}
}