Eureka服務註冊機制

我們一直在使用Eureka進行註冊服務,然而你有可能很少關心服務在註冊到Eureka Server時是採用的主機名的方式?還是IP地址的方式?

構建項目

我們把之前章節SpringCloud組件:將微服務提供者註冊到Eureka服務中心的源碼複製一份修改項目名稱爲hengboy-spring-cloud-eureka-register-away,並簡單的對application.yml配置文件進行修改,如下所示:

# 服務名稱
spring:
  application:
    name: hengboy-spring-cloud-eureka-register-away

# 服務提供者端口號
server:
  port: 20001

# 配置Eureka Server 信息
eureka:
  client:
    service-url:
      defaultZone: http://localhost:10000/eureka/
  # 自定義實例編號
  instance:
    instance-id: ${spring.application.name}:${server.port}:@project.version@

在上面配置中,並沒有對註冊方式進行任何修改,如果現在啓動當然就是採用的默認方式進行註冊,接下來我們來看看默認的方式是採用的哪種?

查看默認方式

我們仍然使用SpringCloud組件:搭建Eureka服務註冊中心源碼作爲服務註冊中心(Eureka Server)來完成本章的測試工作。

測試步驟:

  1. 啓動服務註冊中心
  2. 啓動本章項目
  3. 訪問http://localhost:10000打開服務註冊中心管理界面
  4. 點擊服務列表服務,查看地址欄地址

當我們點擊hengboy-spring-cloud-eureka-register-away:20001:v1.0服務名稱後會跳轉到服務的監控信息界面,不過我們並沒有添加監控相關的依賴或者配置,所以這裏跳轉後是404訪問不到頁面,即使是這樣我們還是可以看到跳轉的網址是http://192.168.1.75:20001/actuator/info,這也證實了一點Eureka ClientEureka Server進行註冊的時候默認採用的是IP Address方式。

那麼如果你想採用主機名的方式進行註冊服務,該怎麼配置呢?請繼續閱讀。

配置使用主機名

我們如果採用主機名的方式進行註冊服務,只需要修改application.yml配置文件內的eureka.instance.hostname配置信息即可,如下所示:

# 配置Eureka Server 信息
eureka:
  client:
    service-url:
      defaultZone: http://localhost:10000/eureka/
  # 自定義實例編號
  instance:
    instance-id: ${spring.application.name}:${server.port}:@project.version@
    # 配置使用主機名註冊服務
    hostname: node1

node1是我本機配置的其中一個主機名

  • OS X/Linux系統下修改主機名

我是採用的MAC OS X系統作爲運行環境,所以修改/etc/hosts文件對應的添加主機名IP地址的映射即可,如下所示:

##
# Host Database
#
# localhost is used to configure the loopback interface
# when the system is booting.  Do not change this entry.
##
127.0.0.1       localhost
255.255.255.255 broadcasthost
::1             localhost
127.0.0.1       node1
127.0.0.1       node2
  • Windows系統下修改主機名

如果你是採用的Windows系統作爲運行環境,你可以修改C:\Windows\System32\drivers\etc\hosts文件內容並添加映射關係。

修改完成主機名後,一定不要忘記是需要讓主機名生效的,修改完成後最有效的辦法是重啓你的計算機可以生效主機名

接下來我們需要按照下面的步驟進行測試主機名方式註冊是否已經生效?

  1. 重啓本章項目
  2. 刷新Eureka Server管理平臺界面
  3. 點擊服務名稱查看跳轉地址

我們可以發現跳轉的路徑由原本默認的http://192.168.1.75:20001/actuator/info方式修改成了http://node1:20001/actuator/info,可以看到已經是使用了主機名的方式進行的註冊服務!!!

配置優先使用IP

如果你在部署的時候某種原因導致的無法使用主機名方式進行部署,當然你可以選擇不配置eureka.instance.hostname參數,如果你配置後仍然想使用IP Address方式進行服務註冊,這時我們可以通過eureka.instance.prefer-ip-address參數來進行設置,如果該參數設置爲true,則優先使用IP Address進行服務註冊
配置如下所示:

# 配置Eureka Server 信息
eureka:
  client:
    service-url:
      defaultZone: http://localhost:10000/eureka/
  # 自定義實例編號
  instance:
    instance-id: ${spring.application.name}:${server.port}:@project.version@
    # 配置使用主機名註冊服務
    hostname: node1
    # 優先使用IP地址方式進行註冊服務
    prefer-ip-address: true

具體的測試過程與上述配置使用主機名一致,可以進行嘗試運行測試。

既然我們可以優先使用IP進行註冊服務,我們想根據指定的IP地址進行註冊該怎麼配置呢?

配置使用指定IP

配置使用指定IP也比較簡單,我們可以進行設置eureka.instance.ip-address參數的值來進行修改註冊的IP 地址
我們基於上面步驟的配置文件進行修改內容如下所示:

# 配置Eureka Server 信息
eureka:
  client:
    service-url:
      defaultZone: http://localhost:10000/eureka/
  # 自定義實例編號
  instance:
    instance-id: ${spring.application.name}:${server.port}:@project.version@
    # 配置使用主機名註冊服務
    hostname: node1
    # 優先使用IP地址方式進行註冊服務
    prefer-ip-address: true
    # 配置使用指定IP
    ip-address: 127.0.0.1

配置文件修改完成後,進行如下步驟進行測試是否失效:

  1. 重啓本章項目
  2. 刷新Eureka Server管理平臺界面
  3. 點擊服務名稱,查看跳轉地址信息

我們發現跳轉地址欄的地址已經使用了我們配置的ip-address參數,地址爲:http://127.0.0.1:20001/actuator/info

注意:如果配置ip-address參數後並沒有開啓prefer-ip-address: true,那麼仍然使用主機名或者默認的註冊方式。

總結

我們通過幾種不同的服務註冊方式來全面講解了Eureka Client在註冊到服務註冊中心時使用的主機信息,這幾種註冊方式也是存在一定的優先級順序的,這一知識點我們在下一章結合Eureka源碼進行分別全面剖析這幾種註冊方式以及優先級順序

源碼位置

本章源碼已經上傳到恆宇少年的碼雲,請結合源碼進行學習,感謝閱讀。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章