javascript
Spring Cloud Alibaba源码 - 16 Nacos 注册中心源码解析
文章目錄
- Nacos & Ribbon & Feign 核心微服務(wù)架構(gòu)圖
- Nacos核心功能
- 源碼下載 & 啟動(dòng)
- 【standalone模式】
- 【cluster模式】
- Nacos服務(wù)注冊(cè)表結(jié)構(gòu)
- 源碼流程圖
Nacos & Ribbon & Feign 核心微服務(wù)架構(gòu)圖
核心原理如下
微服務(wù)系啟動(dòng)時(shí)將自己的相關(guān)的元數(shù)據(jù)信息注冊(cè)到注冊(cè)中心,同時(shí)暴漏對(duì)外調(diào)用的HTTP接口
服務(wù)消費(fèi)者基于Feign調(diào)用服務(wù)提供者對(duì)外發(fā)布的接口,先對(duì)調(diào)用的本地接口加上@FeignClient注解,Feign會(huì)針對(duì)加了該注解的接口生成動(dòng)態(tài)代理,服務(wù)消費(fèi)者會(huì)針對(duì)Feign生成的動(dòng)態(tài)代碼方法調(diào)用方法時(shí),會(huì)在底層生成Http協(xié)議格式的請(qǐng)求,類似/stock/deduct?productId=999
Feign最終會(huì)調(diào)用Ribbon從本地的Nacos注冊(cè)表的緩存里根據(jù)服務(wù)名取出服務(wù)提供者所在的機(jī)器列表,然后進(jìn)行負(fù)載均衡并選擇一臺(tái)幾區(qū)出來,對(duì)選出來的機(jī)器IP和端口拼接之前的url ,生成類似調(diào)用http接口地址http:/192.168.1222.22:7000/stock/deduct?productId=999,最后基于HttpClient調(diào)用請(qǐng)求。
Nacos核心功能
-
服務(wù)注冊(cè)
Nacos Client會(huì)通過發(fā)送REST請(qǐng)求的方式向Nacos Server注冊(cè)自己的服務(wù),提供自身的元數(shù)據(jù),比如ip地址、端口等信息。Nacos Server接收到注冊(cè)請(qǐng)求后,就會(huì)把這些元數(shù)據(jù)信息存儲(chǔ)在一個(gè)雙層的內(nèi)存Map中。
-
服務(wù)心跳
在服務(wù)注冊(cè)后,Nacos Client會(huì)維護(hù)一個(gè)定時(shí)心跳來持續(xù)通知Nacos Server,說明服務(wù)一直處于可用狀態(tài),防止被剔除。默認(rèn)5s發(fā)送一次心跳。
-
服務(wù)健康檢查
Nacos Server會(huì)開啟一個(gè)定時(shí)任務(wù)用來檢查注冊(cè)服務(wù)實(shí)例的健康情況,對(duì)于超過15s沒有收到客戶端心跳的實(shí)例會(huì)將它的healthy屬性置為false(客戶端服務(wù)發(fā)現(xiàn)時(shí)不會(huì)發(fā)現(xiàn)),如果某個(gè)實(shí)例超過30秒沒有收到心跳,直接剔除該實(shí)例(被剔除的實(shí)例如果恢復(fù)發(fā)送心跳則會(huì)重新注冊(cè))
-
服務(wù)發(fā)現(xiàn)
服務(wù)消費(fèi)者(Nacos Client)在調(diào)用服務(wù)提供者的服務(wù)時(shí),會(huì)發(fā)送一個(gè)REST請(qǐng)求給Nacos Server,獲取上面注冊(cè)的服務(wù)清單,并且緩存在Nacos Client本地,同時(shí)會(huì)在Nacos Client本地開啟一個(gè)定時(shí)任務(wù)定時(shí)拉取服務(wù)端最新的注冊(cè)表信息更新到本地緩存
-
服務(wù)同步
Nacos Server集群之間會(huì)互相同步服務(wù)實(shí)例,用來保證服務(wù)信息的一致性。
源碼下載 & 啟動(dòng)
https://nacos.io/zh-cn/docs/system-configurations.html
- nacos源碼導(dǎo)入要求maven 3.2.5以上版本
【standalone模式】
-
運(yùn)行console模塊里的 com.alibaba.nacos.Nacos.java
-
Nacos.java 啟動(dòng)需要增加啟動(dòng)vm參數(shù),注意nacos.home目錄要改成你自己源碼對(duì)應(yīng)的distribution模塊目錄 -Dnacos.standalone=true -Dnacos.home=D:\IdeaProjects\nacos-1.1.4\distribution
啟動(dòng)后訪問 http://localhost:8848/nacos/index.html
【cluster模式】
nacos 集群模式需要 需要配置mysql 。
Nacos服務(wù)注冊(cè)表結(jié)構(gòu)
// Map<namespace, Map<group::serviceName, Service>> private Map<String, Map<String, Service>> serviceMap = new ConcurrentHashMap<>();源碼流程圖
呶 ,圖都給你畫好了,https://www.processon.com/view/link/6201bbaf1e08530f015e6cc5
總結(jié)
以上是生活随笔為你收集整理的Spring Cloud Alibaba源码 - 16 Nacos 注册中心源码解析的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Spring Cloud Alibaba
- 下一篇: Spring Cloud Alibaba