日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

Spring Cloud Alibaba源码 - 16 Nacos 注册中心源码解析

發(fā)布時(shí)間:2025/3/21 javascript 73 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Spring Cloud Alibaba源码 - 16 Nacos 注册中心源码解析 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

文章目錄

  • 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 。

  • 先創(chuàng)建一個(gè)數(shù)據(jù),名字隨意
  • 執(zhí)行 distribution/conf 目錄下的 nacos-mysql.sql 腳本
  • 修改 console\src\main\resources 目錄下的 application.properties 文件里的mysql配置
  • ### If use MySQL as datasource: spring.datasource.platform=mysql### Count of DB: db.num=1### Connect URL of DB: db.url.0=jdbc:mysql://127.0.0.1:3306/nacos?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true&useUnicode=true&useSSL=false&serverTimezone=UTC db.user.0=root db.password.0=artisan
  • 運(yùn)行console模塊里的 com.alibaba.nacos.Nacos.java , 需要增加啟動(dòng)vm參數(shù)端口號(hào)和實(shí)例運(yùn)行路徑nacos.home(對(duì)應(yīng)的目錄需要自己提前創(chuàng)建好),每臺(tái)server的nacos.home目錄里需要?jiǎng)?chuàng)建一個(gè)conf文件夾,里面放一個(gè)cluster.conf文件,文件里需要把所有集群機(jī)器ip和端口寫入進(jìn)去
  • 127.0.0.1:6000 127.0.0.1:6001 127.0.0.1:6002


    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)容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。