溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

如何解決SpringCloud服務(wù)注冊IP錯誤的問題

發(fā)布時間:2021-07-06 09:02:05 來源:億速云 閱讀:512 作者:chen 欄目:開發(fā)技術(shù)

這篇文章主要介紹“如何解決SpringCloud服務(wù)注冊IP錯誤的問題”,在日常操作中,相信很多人在如何解決SpringCloud服務(wù)注冊IP錯誤的問題問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”如何解決SpringCloud服務(wù)注冊IP錯誤的問題”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!

SpringCloud 服務(wù)注冊IP錯誤

1、錯誤原因

在服務(wù)注冊的時候,是使用 spring.cloud.client.ipAddress 這個變量,如果本機(jī)有多個網(wǎng)卡,那么可能會把不是本機(jī)以太網(wǎng)的網(wǎng)卡地址注冊上去。

使用 ipconfig 可以看到,本機(jī)上有多個以太網(wǎng)適配器,而每個以太網(wǎng)適配器,都有一個 IPv4 地址,這時注冊上去的 IP,就是其中一個,卻不一定是正確的那個。

2、處理

2.1、禁用其他網(wǎng)卡

到電腦的 更改適配器 設(shè)置中,將不是本機(jī)以太網(wǎng)的其他網(wǎng)卡禁用

2.2、配置

到電腦的設(shè)備管理器 --> 網(wǎng)絡(luò)適配器 中,可以看到所有的網(wǎng)卡名

在要注冊的服務(wù)中配置一下內(nèi)容:

//忽略指定正則匹配的網(wǎng)卡的配置,我這里配置了VM虛擬機(jī)和Docker的
spring.cloud.inetutils.ignoredInterfaces=['VMware.*','Hyper-V.*']
//指定默認(rèn)IP,可以使IP段
spring.cloud.inetutils.preferredNetworks=['192.168']
spring.cloud.inetutils.use-only-site-local-interfaces=true

SpringCloud以及Nacos服務(wù)注冊IP選擇

微服務(wù)部署后,需要相互調(diào)用,其中服務(wù)A調(diào)用服務(wù)B時發(fā)現(xiàn)無法調(diào)用。其中服務(wù)注冊和發(fā)現(xiàn)以及配置中心使用Nacos

分析:

檢查了多遍代碼后,沒有發(fā)現(xiàn)調(diào)用方式有問題,所以只能是網(wǎng)絡(luò)問題。通過postman直接調(diào)用服務(wù)B,發(fā)現(xiàn)可以調(diào)通,但是使用服務(wù)A不行,于是檢查服務(wù)A在注冊中心注冊的IP,發(fā)現(xiàn)和并不是服務(wù)B啟動機(jī)器的IP。這就是問題所在了。

為什么注冊的IP和真實(shí)IP不符合呢?原因是Nacos客戶端在注冊服務(wù)時會從機(jī)器網(wǎng)卡中選擇一個IP來注冊,當(dāng)機(jī)器存在多個網(wǎng)卡(例如存在虛擬網(wǎng)卡)時,所選則的IP可能不是真是的物理機(jī)的IP,所以,當(dāng)注冊了的是非真實(shí)IP后,另一臺機(jī)器調(diào)用時是不可能調(diào)通的。

解決:

知道問題后,就要解決,查了一下SpringCloud的官方文檔,發(fā)現(xiàn)有一項(xiàng)配置如下:

Sometimes, it is useful to ignore certain named network interfaces so that they can be excluded from Service Discovery registration (for example, when running in a Docker container).

A list of regular expressions can be set to cause the desired network interfaces to be ignored.

You can also force the use of only specified network addresses by using a list of regular expressions.

spring:
  cloud:
 inetutils:
   preferredNetworks:
  - 192.168
  - 10.0

該項(xiàng)配置用于指定首選IP,當(dāng)有多個網(wǎng)卡時,指定該IP地址后(支持正則),客戶端在選擇IP時就會選擇符合preferredNetworks配置的IP地址進(jìn)行注冊。

同樣的,Nacos也可以配置自己的首選IP以及網(wǎng)卡選擇:

spring.cloud.nacos.discovery.ip:
spring.cloud.nacos.discovery.networkInterface

我們選擇其中一個配置就可以,都能達(dá)到相同的效果。

擴(kuò)展:

雖然問題解決了,但是還是要更深入的了解一下這個IP選擇的邏輯。翻了一通源碼發(fā)現(xiàn),其大致邏輯如下:

如何解決SpringCloud服務(wù)注冊IP錯誤的問題

Nacos首先檢查有沒有ip及networkInterface配置,如果有則使用配置的IP,否則檢查networkInterface,并獲取IP,如果兩者都為空,則使用inetUtils.findFirstNonLoopbackHostInfo().getIpAddress()來獲取IP:

如何解決SpringCloud服務(wù)注冊IP錯誤的問題

而findFirstNonLoopbackHostInfo()的部分邏輯如下:

如何解決SpringCloud服務(wù)注冊IP錯誤的問題

它最終會返回一個匹配的IPV4地址,并且排除本機(jī)回環(huán)網(wǎng)絡(luò)(127.0.0.0-127.255.255.255),并且匹配是否是首選網(wǎng)絡(luò)(如果配置了preferredNetworks)。

到此,關(guān)于“如何解決SpringCloud服務(wù)注冊IP錯誤的問題”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識,請繼續(xù)關(guān)注億速云網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬?shí)用的文章!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI