微服務架構 | 3.4 HashiCorp Consul 註冊中心

多氯環己烷 發表於 2022-01-18
微服務


前言

參考資料
《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

Consul  解壓

2.2 執行 Consul 伺服器

  • 在 consul.exe 程式所在目錄下開啟 cmd 命令視窗;
  • 鍵入命令 consul ,顯示下面說明安裝成功;

Consul  安裝成功

  • 此時鍵入命令 consul agent -dev 使用開發模式啟動;

使用開發模式啟動

Consul 首頁


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;
    }
}


最後

新人制作,如有錯誤,歡迎指出,感激不盡!
歡迎關注公眾號,會分享一些更日常的東西!
如需轉載,請標註出處!
微服務架構 | 3.4 HashiCorp Consul 註冊中心