一、服務(wù)注冊中心的由來
創(chuàng)新互聯(lián)專業(yè)為企業(yè)提供淮上網(wǎng)站建設(shè)、淮上做網(wǎng)站、淮上網(wǎng)站設(shè)計、淮上網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計與制作、淮上企業(yè)網(wǎng)站模板建站服務(wù),10余年淮上做網(wǎng)站經(jīng)驗,不只是建網(wǎng)站,更提供有價值的思路和整體網(wǎng)絡(luò)服務(wù)。
假如沒有服務(wù)注冊中心,我們會干些什么事情呢?
在傳統(tǒng)行業(yè)的項目架構(gòu)中以下的方案最為常見了:
這種架構(gòu)開發(fā)、部署都是最簡單的,一般適用于中小企業(yè)訪問量并不是太多的情況下,各個系統(tǒng)服務(wù)一臺機器就搞定了。系統(tǒng)之間的調(diào)用也是拿到對方的IP+PORT直接連接。
接下來可能因為應(yīng)用B開始訪問量大了,單臺機器已經(jīng)不能滿足我們的需求,于是一些反向代理工具應(yīng)運而出,其中比較常見的有Apache、Nigix,架構(gòu)演變?yōu)椋?/p>
相比之前的應(yīng)用B的單臺機器訪問,這種nginx代理的方式減輕了服務(wù)器的壓力,但是可能會出現(xiàn)Nginx掛了,那么整個服務(wù)也不可用,于是又來了這么一套架構(gòu):
這樣看方案算是完美了吧。然后事情并不是想象的那么一帆風(fēng)順,這還只是應(yīng)用A調(diào)用一個應(yīng)用B,如果應(yīng)用A調(diào)用的可能是應(yīng)用B、C、D、E...,這種完全就不知道他后面到底還想干嘛,這種架構(gòu)看似可以,但是絕對會累死運維的(nginx的配置將會非?;靵y,直接導(dǎo)致運維不干了)。
服務(wù)注冊中心干些什么事情呢?
上面提到的那種靠人力(主要是運維干的事情)比較繁瑣,還不好維護,有這么幾點不方便:應(yīng)用服務(wù)的地址變了、雙十一搞活動服務(wù)器新增等等。那么我們可以有這么的一種架構(gòu):
服務(wù)注冊中心主要是維護各個應(yīng)用服務(wù)的ip+port列表,并保持與各應(yīng)用服務(wù)的通訊,在一定時間間隔內(nèi)進行心跳檢測,如果心跳不能到達則對服務(wù)IP列表進行剔除,并同時通知給其它應(yīng)用服務(wù)進行更新。同樣要是有新增的服務(wù)進來,應(yīng)用服務(wù)會向注冊中心進行注冊,服務(wù)注冊中心將通知給其它應(yīng)用進行更新。每個應(yīng)用都有需要調(diào)用對應(yīng)應(yīng)用服務(wù)的地址列表,這樣在進行調(diào)用時只要處理客戶負載雜均衡即可。
二、微服務(wù)注冊中心
1.Zookeeper
ZooKeeper是一個分布式的,開放源碼的分布式應(yīng)用程序協(xié)調(diào)服務(wù),是Google的Chubby一個開源的實現(xiàn),是Hadoop和Hbase的重要組件。它是一個為分布式應(yīng)用提供一致性服務(wù)的軟件,提供的功能包括:配置維護、域名服務(wù)、分布式同步、組服務(wù)等。
上面的話直接摘抄百度百科的內(nèi)容,國內(nèi)很多公司做分布式開發(fā)最初的選型大部分都是采用dubbo框架。dubbo框架注冊中心主要使用zookeeper。zookeeper服務(wù)端與客戶端的底層通訊為netty。zookeeper采用CAP理論中的CP,一般集群部署最少需要3臺機器。
2.Euraka
先來看一下euraka的架構(gòu)圖:
Register:服務(wù)注冊
當(dāng)Eureka客戶端向Eureka Server注冊時,它提供自身的元數(shù)據(jù),比如IP地址、端口,運行狀況指示符URL,主頁等。
Renew:服務(wù)續(xù)約
Eureka客戶會每隔30秒發(fā)送一次心跳來續(xù)約。 通過續(xù)約來告知Eureka Server該Eureka客戶仍然存在,沒有出現(xiàn)問題。 正常情況下,如果Eureka Server在90秒沒有收到Eureka客戶的續(xù)約,它會將實例從其注冊表中刪除。 建議不要更改續(xù)約間隔。
Fetch Registries:獲取注冊列表信息
Eureka客戶端從服務(wù)器獲取注冊表信息,并將其緩存在本地??蛻舳藭褂迷撔畔⒉檎移渌?wù),從而進行遠程調(diào)用。該注冊列表信息定期(每30秒鐘)更新一次。每次返回注冊列表信息可能與Eureka客戶端的緩存信息不同, Eureka客戶端自動處理。如果由于某種原因?qū)е伦粤斜硇畔⒉荒芗皶r匹配,Eureka客戶端則會重新獲取整個注冊表信息。 Eureka服務(wù)器緩存注冊列表信息,整個注冊表以及每個應(yīng)用程序的信息進行了壓縮,壓縮內(nèi)容和沒有壓縮的內(nèi)容完全相同。Eureka客戶端和Eureka 服務(wù)器可以使用JSON / XML格式進行通訊。在默認的情況下Eureka客戶端使用壓縮JSON格式來獲取注冊列表的信息。
Cancel:服務(wù)下線
Eureka客戶端在程序關(guān)閉時向Eureka服務(wù)器發(fā)送取消請求。 發(fā)送請求后,該客戶端實例信息將從服務(wù)器的實例注冊表中刪除。該下線請求不會自動完成,它需要調(diào)用以下內(nèi)容:
DiscoveryManager.getInstance().shutdownComponent();
Eviction 服務(wù)剔除
在默認的情況下,當(dāng)Eureka客戶端連續(xù)90秒沒有向Eureka服務(wù)器發(fā)送服務(wù)續(xù)約,即心跳,Eureka服務(wù)器會將該服務(wù)實例從服務(wù)注冊列表刪除,即服務(wù)剔除。
自我保護機制:
既然Eureka Server會定時剔除超時沒有續(xù)約的服務(wù),那就有可能出現(xiàn)一種場景,網(wǎng)絡(luò)一段時間內(nèi)發(fā)生了 異常,所有的服務(wù)都沒能夠進行續(xù)約,Eureka Server就把所有的服務(wù)都剔除了,這樣顯然不太合理。所以,就有了 自我保護機制,當(dāng)短時間內(nèi),統(tǒng)計續(xù)約失敗的比例,如果達到一定閾值,則會觸發(fā)自我保護的機制,在該機制下, Eureka Server不會剔除任何的微服務(wù),等到正常后,再退出自我保護機制。自我保護開關(guān)(eureka.server.enableself-preservation: false)
3.Consul
consul推薦的架構(gòu)圖:
Consul不像Euraka的部署那么簡單,他是go語言開發(fā)的,需要運維單獨部署,有提供java的客戶端連接,采用的是CAP的CP。
4.Nacos
Euraka是Spring Cloud Netflix早期版本中推薦使用的,后來euraka1.0版本不再維護,euraka2.0已經(jīng)閉源,導(dǎo)致很多新項目基于Spring Cloud Netflix 開發(fā)的選型變遷為Consul.
Nacos是阿里開源的服務(wù)注冊中心,它可以與spring cloud aliaba集成使用。
Nacos的官方介紹:
Nacos 致力于幫助您發(fā)現(xiàn)、配置和管理微服務(wù)。Nacos 提供了一組簡單易用的特性集,幫助您實現(xiàn)動態(tài)服務(wù)發(fā)現(xiàn)、服務(wù)配置管理、服務(wù)及流量管理。
Nacos 幫助您更敏捷和容易地構(gòu)建、交付和管理微服務(wù)平臺。 Nacos 是構(gòu)建以“服務(wù)”為中心的現(xiàn)代應(yīng)用架構(gòu)(例如微服務(wù)范式、云原生范式)的服務(wù)基礎(chǔ)設(shè)施。
Nacos 地圖
Nacos 生態(tài)圖
如 Nacos 全景圖所示,Nacos 無縫支持一些主流的開源生態(tài),例如
Spring Cloud
Apache Dubbo and Dubbo Mesh TODO
Kubernetes and CNCF TODO
三、服務(wù)注冊與發(fā)現(xiàn)技術(shù)選型
以下是來自網(wǎng)上的一個分享:
除了上述的幾種以外,筆者更推薦使用Nacos作為服務(wù)注冊中心。
推薦理由:
Nacos服務(wù)注冊表結(jié)構(gòu)Mapnamespace, Mapgroup::serviceName, Service采用多層次Map結(jié)構(gòu),控制的顆粒度更細,支持金絲雀模式發(fā)布,心跳同步機制也更快速,服務(wù)更新更及時。
入門認知篇
《新經(jīng)濟藍圖及導(dǎo)讀》
出版年份:2016年
推薦語: 這本書側(cè)重寫了區(qū)塊鏈前景的展望,書中除了作者原書的翻譯,還增加了一些導(dǎo)讀部分,案例豐富全面,講解詳細又不失理論高度,如果對區(qū)塊鏈、互聯(lián)網(wǎng)金融感興趣,千萬不要錯過。維優(yōu)元界( )的CEO初夏虎(Eric)也參與了本書的翻譯。
《區(qū)塊鏈:從數(shù)字貨幣到信用社會》
出版年份:2016年
推薦語:本書系統(tǒng)地對區(qū)塊鏈的歷史和現(xiàn)狀、起源與發(fā)展以及問題和未來發(fā)展方向進行了總結(jié)梳理,結(jié)合進階區(qū)塊鏈、如何應(yīng)用區(qū)塊鏈、政府監(jiān)管等進行案例分析,系統(tǒng)而又淺顯。
《區(qū)塊鏈: 重塑經(jīng)濟與世界》
出版時間:2016 年
推薦語:區(qū)塊鏈的入門科普書籍,從區(qū)塊鏈源頭到未來,從目前的應(yīng)用進展到未來應(yīng)用藍圖,作者為業(yè)界一線成員和專家學(xué)者,匯聚實戰(zhàn)和理論,具有很大的參考性。
投資篇
《如何投資數(shù)字貨幣》
出版時間:2017 年
推薦語:開篇以基礎(chǔ)知識作為鋪墊,接著第二部分介紹了投資交易方法,第三部分是投資理念,最后結(jié)合比特時代,狗狗幣等案例介紹了區(qū)塊鏈的發(fā)展和應(yīng)用??梢宰屚顿Y者通過本書快速的了解數(shù)字貨幣投資。
《虛擬貨幣投資實戰(zhàn)技巧》
出版年份:2017 年
推薦語:致力于把各種價格分析技術(shù)和傳統(tǒng)市場的操作理論用于虛擬貨幣市場,結(jié)合K線進行技術(shù)分析。技術(shù)黨和短線愛好者不可放過的經(jīng)典書籍。
《區(qū)塊鏈社會 解碼區(qū)塊鏈全球應(yīng)用與投資案例》
出版時間:2016 年
推薦語:介紹了區(qū)塊鏈這一新興技術(shù)在全球各行業(yè)的各種應(yīng)用,并介紹了區(qū)塊鏈技術(shù)的基本原理,共識機制以及發(fā)展脈絡(luò),獨家披露了全球258個區(qū)塊鏈行業(yè)內(nèi)投資案例的詳細數(shù)據(jù)。在投資上具有較強的價值參考。
技術(shù)篇
《精通比特幣》
出版時間:2015 年
推薦語:從比特幣原理到錢包挖礦再到競爭幣等涉及的名詞,針對于不同的用戶群體從多個角度來闡釋各關(guān)鍵技術(shù)概念。 圍繞比特幣進行區(qū)塊鏈科普。
《區(qū)塊鏈技術(shù)指南》
出版時間:2016 年
推薦語:從技術(shù)視角適來揭秘區(qū)塊鏈,從入門基礎(chǔ)知識到技術(shù)構(gòu)建,幫助初學(xué)者入門,在最后回顧了區(qū)塊鏈和IT之間的發(fā)展和未來的展望。
《C#區(qū)塊鏈編程》
出版時間:2016 年
推薦語:本書主要面向程序員。結(jié)合API編程告訴你加密貨幣的原理、使用方法,以及如何開發(fā)與之相關(guān)的軟件,對于非程序員讀者們,本書前幾章作為對比特幣的深入介紹依然適用。(書籍pdf下載:)
golang學(xué)習(xí)比較簡單,不過任何一門語言都不是孤立存在的,在這里簡要說明一下golang開發(fā)的學(xué)習(xí)路線
1.golang基礎(chǔ),包括go語言安裝,go語言語法,流程控制語句,函數(shù),方法,面向?qū)ο蟾拍睿W(wǎng)絡(luò)編程,并發(fā)編程等
2.golang開發(fā)框架,包括beego,gin,Iris,Echo等
3.微服務(wù)開發(fā)
4.深入的話還可以學(xué)習(xí)算法部分。如果要接觸區(qū)塊鏈相關(guān)技術(shù)的話,還需要學(xué)習(xí)區(qū)塊鏈的加密算法等相關(guān)知識
5.如果要結(jié)合go實現(xiàn)應(yīng)用的話,肯定離不開各種數(shù)據(jù)庫,比如關(guān)系型數(shù)據(jù)庫oracle、mysql,或者各類非關(guān)系型數(shù)據(jù)庫等等
6.如果需要開發(fā)界面的話,還需要學(xué)習(xí)網(wǎng)頁編程如html,javascript,vue,elementUI,bootstrap等網(wǎng)頁開發(fā)技術(shù)和框架。
7.在以上學(xué)習(xí)的基礎(chǔ)上還可以向架構(gòu)方面深入學(xué)習(xí)。
鏈喬教育在線祝您學(xué)有所成。