Eureka停更了?試試Zookpper和Consul


在Spring Cloud Netflix中使用Eureak作為注冊中心,但是Eureka2.0停止更新,Eureka1.0 進入了維護狀態。就像win7一樣,同樣可以用,但是官方對於新出現的問題並不能及時修復,所以我們就需要使用替代品。目前可用的注冊中心替代品主要有:Zookeeper、Consul、Nacos等,這里主要講前兩個,Nacos是Spring Cloud Alilibaba中的組件,后期會說到。

使用Zookeeper作為注冊中心

一、安裝Zookeeper並啟動服務

​ 這一步非本文重點,請自行百度,很簡單的

二、將原有的微服務注冊進Zookeeper

  • 使用過Dubbo的小伙伴對Zookeeper一定不陌生。使用Eureka時,我們是創建一個新的SpringBoot Web項目(如果是Eureka集群的話,就要創建多個項目),然后將其他微服務注冊進去,而Zookeeper卻不用新建項目,只需要通過修改配置和簡單的編碼就可以進行注冊
  • 為了和之前的項目沖突,我們先將之前的項目復制兩個新的項目zookeeper-provider-8001zookeeper-consumer-80
先修改zookeeper-provider-8001這個提供者項目
  • 在pom.xml中引入依賴
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-zookeeper-discovery</artifactId>
    <exclusions>
        <exclusion>
            <!--為什么要排除這個依賴?-->
            <groupId>org.apache.zookeeper</groupId>
            <artifactId>zookeeper</artifactId>
        </exclusion>
    </exclusions>
</dependency>
<dependency>
    <!--然后又引入這個依賴?-->
    <groupId>org.apache.zookeeper</groupId>
    <artifactId>zookeeper</artifactId>
    <version>3.4.13</version>
</dependency>

​ 一個小細節,為什么要排除這個依賴,然后引入一個新的依賴?這波騷操作?

1. 主要是在zookeeper-discovery中的zookeeper版本是3.4.8 
2. 而這個版本一定要和我們在服務器安裝的zookeeper版本一致,不然你在注冊的時候,會報錯。當然,如果你在服務器本來安裝的是3.4.8就不用這么麻煩了。
  • 在application.yml中配置上zookeeper的地址
server:
  port: 8001

spring:
  application:
#  這個應用的名稱,用來注冊在注冊中心的名稱
    name: zookeeper-provider
  cloud:
    zookeeper:
#    如果是zookeeper集群,在這個地址后邊加上就可以,用逗號分開
      connect-string: 192.168.25.131:2181
  • 在啟動類中添加注解
@SpringBootApplication
@EnableDiscoveryClient //注意這個注解是SpringCloud包中的
public class ApplicationDemo {
    public static void main(String[] args) {
        SpringApplication.run(ApplicationDemo.class, args);
    }
}
  • 啟動這個項目,然后在服務器中查看下zookeeper的節點

使用Zookeeper作為Spring Cloud注冊中心

同樣的方法,修改消費者項目zookeeper-consumer-80
  • pom.xml(和上邊一樣引入zookeeper依賴)

  • appliction.yml

server:
  port: 80
spring:
  cloud:
    zookeeper:
      connect-string: 192.168.25.131:2181
  • 和Eureka不同的是,我們同時也要將消費者注冊進Zookeeper中
@SpringBootApplication
@EnableDiscoveryClient
public class ApplicationDemo {
    public static void main(String[] args) {
        SpringApplication.run(ApplicationDemo.class, args);
    }
}
  • 我們使用的是Ribbon用服務名進行訪問的方式,所以還要修改它的controller類
@GetMapping("consumer/hello/{id}")
    public String hello(@PathVariable("id") String id){
        //遠程調用provider中的接口
        return restTemplate.getForObject("http://zookeeper-provider/provider/hello/"+id,String.class);
    }
  • 然后啟動這個項目,使用瀏覽器訪問http://localhost/consumer/hello/999沒問題

使用Consul作為注冊中心

查看它的中文文檔

Consul是使用go語言開發,是一個服務網格(微服務間的 TCP/IP,負責服務之間的網絡調用、限流、熔斷和監控)解決方案,它是一個一個分布式的,高度可用的系統,而且開發使用都很簡便。它提供了一個功能齊全的控制平面,主要特點是:服務發現、健康檢查、鍵值存儲、安全服務通信、多數據中心。

一、安裝Consul

這個安裝要比Zookeeper簡單,我只說下windows安裝操作,其他的查看官網https://www.consul.io/

​ 如果你下載很慢的話,我在項目代碼中上傳了這個安裝包。看文未獲取代碼地址。

  • 在官網上下載安裝包,windows的下載解壓后就是一個.exe文件。使用cmd打開當前目錄(在當前目錄下按住Shift+鼠標右鍵,選擇Open commond window here 或者在地址欄中輸入cmd然后回車)然后運行如下命令:
consul agent -dev
  • Consul和Eureka是有圖形化界面的,啟動Consul后直接用瀏覽器打開localhost:8500就可以看到。

    使用Consul作為注冊中心

二、將原有微服務注冊進Consul

​ 同樣,我們復制兩個新項目consul-provider-8001 和 consul-consumer-80。

​ 而且和Zookeeeper一樣,提供者和消費者都要注冊進去。只貼出修改的代碼,其他的參見源代碼

  • pom.xml
<!--只是添加了這一個依賴,其他的依賴不變,如消費者需要的ribbon等-->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-consul-discovery</artifactId>
</dependency>
  • application.yml(提供者和服務者除了端口號和application.name外,其他的不變)
server:
  port: 8001

spring:
  application:
#  這個應用的名稱,用來注冊在注冊中心的名稱
    name: consul-provider
  cloud:
    consul:
      host: localhost
      port: 8500
      discovery:
#      這個就是要注冊進consul中的服務名,直接使用了上邊定義的微服務名
        service-name: ${spring.application.name}
  • 在主啟動類上添加注解(提供者和服務者都需要)
@SpringBootApplication
@EnableDiscoveryClient
public class ApplicationDemo {
    public static void main(String[] args) {
        SpringApplication.run(ApplicationDemo.class, args);
    }
}
  • 注意修改Controller中的遠程調用服務名
@GetMapping("consumer/hello/{id}")
    public String hello(@PathVariable("id") String id){
        //遠程調用provider中的接口
        return restTemplate.getForObject("http://consul-provider/provider/hello/"+id,String.class);
    }
  • 然后啟動這個項目,先在瀏覽器中輸入localhost:8500看一下我們的注冊中心是否有這兩個微服務。然后再次進行測試。
  • 但是我們啟動后,在Consul后台發現我們服務是注冊進去了,但是報錯了。這是因為Consul和其他的注冊中心不一樣,它要檢查這個SpringBoot的健康值,就是要訪問每個服務的"/health"接口。所以我們要在每一個微服務中引入SpringBoot的健康檢查的依賴(之前用過這個的小伙伴就很熟悉了)
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
  • 這里有一個小插曲,就算當我們引入這個包后我們的http://localhost:8001/health返回還是down,也就是說我們的健康檢查還是不通過.。因為我們使用的SpringBoot和Spring Cloud版本的問題。我還沒找到解決方案。但是我們可以關閉Consul對當前服務的健康檢查,添加如下配置:
spring:
  application:
#  這個應用的名稱,用來注冊在注冊中心的名稱
    name: consul-consumer
  cloud:
    consul:
      host: localhost
      port: 8500
      discovery:
#      這個就是要注冊進consul中的服務名,直接使用了上邊定義的微服務名
        service-name: ${spring.application.name}
#        取消Consule對當前服務的健康檢查
        register-health-check: false

最后,能在Consul控制台看到這個

使用Consul作為注冊中心

上邊這個錯誤標志忽略就好了。然后我們就可以使用瀏覽器和之前一樣進行服務的訪問了

總結:

  1. 這兩個注冊中心在和Spring Cloud整合時,它們的理念和步驟是一樣的。

    引依賴——》修改application.yml將這個微服務注冊進注冊中心——》在主啟動類中添加注解

  2. 和Eureka不同就是,在注冊中心能同時看到提供者和消費者

  3. 后期在Spring Cloud Alilibaba中,我們會使用Nacos(阿里自研的)作為注冊中心

項目代碼及更多學習教程

請關注微信公眾號,回復“SpringCloud”獲取。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM