今天就跟大家聊聊有關(guān)如何從零搭建ocelot網(wǎng)關(guān)和consul集群,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。
成都創(chuàng)新互聯(lián)是專(zhuān)業(yè)的德州網(wǎng)站建設(shè)公司,德州接單;提供網(wǎng)站制作、網(wǎng)站設(shè)計(jì),網(wǎng)頁(yè)設(shè)計(jì),網(wǎng)站設(shè)計(jì),建網(wǎng)站,PHP網(wǎng)站建設(shè)等專(zhuān)業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行德州網(wǎng)站開(kāi)發(fā)網(wǎng)頁(yè)制作和功能擴(kuò)展;專(zhuān)業(yè)做搜索引擎喜愛(ài)的網(wǎng)站,專(zhuān)業(yè)的做網(wǎng)站團(tuán)隊(duì),希望更多企業(yè)前來(lái)合作!
微服務(wù)中有關(guān)鍵的幾項(xiàng)技術(shù),其中網(wǎng)關(guān)和服務(wù)服務(wù)發(fā)現(xiàn),服務(wù)注冊(cè)相輔相成。
首先解釋幾個(gè)需要的術(shù)語(yǔ)
網(wǎng)關(guān) Gateway(API GW / API 網(wǎng)關(guān)),顧名思義,是企業(yè) IT 在系統(tǒng)邊界上提供給外部訪問(wèn)內(nèi)部接口服務(wù)的統(tǒng)一入口,簡(jiǎn)化了外部由于多服務(wù)協(xié)同完成任務(wù)時(shí)的繁瑣配置。網(wǎng)關(guān)組件有Kong,ocelot,
服務(wù)發(fā)現(xiàn):通過(guò)網(wǎng)關(guān)訪問(wèn)內(nèi)部各個(gè)微服務(wù),網(wǎng)關(guān)要找到所需服務(wù)的過(guò)程稱(chēng)為服務(wù)發(fā)現(xiàn)
服務(wù)注冊(cè):既然有服務(wù)發(fā)現(xiàn),前提是要把所需服務(wù)提前“錄入”,這個(gè)錄入的過(guò)程稱(chēng)為服務(wù)注冊(cè)。服務(wù)注冊(cè)可配置文件(人肉方式不推薦),也可用服務(wù)注冊(cè)組件如Consul或者Eureka等等(推薦)
官網(wǎng)下載Consul程序,https://www.consul.io/downloads.html
下載下來(lái)就是一個(gè)可執(zhí)行文件Consul.exe
Consul有兩種代理模式,一種server,一種client,官方建議Server端達(dá)到3臺(tái)以上才可高可用,但不要太多,太多會(huì)給集群間數(shù)據(jù)同步造成壓力,client數(shù)量不限。
多個(gè)server端之間會(huì)選擇出一個(gè)leader,當(dāng)一個(gè)server的leader宕機(jī)則會(huì)從其他server端”投票“選擇新的leader
這里server我們用2臺(tái)實(shí)驗(yàn)
192.168.74.55
192.168.74.54
1臺(tái)Client
192.168.74.161
consul啟動(dòng)有兩種方式一種是命令行,一種是配置文件的方式。
命令行方式啟動(dòng)一個(gè)consul的server端
consul agent -server -ui -bootstrap-expect 2 -data-dir opt/consul/data -node ServerMaster -bind 192.168.74.55 -client 192.168.74.55
關(guān)鍵參數(shù)說(shuō)明
-server:server模式啟動(dòng)
-ui :開(kāi)啟ui界面(consul.exe內(nèi)部帶了GUI圖形界面操作)
-bootstrap-expect 2:server端到2個(gè)時(shí)集群生效
-data-dir:consul產(chǎn)生的文件路徑(consul自己會(huì)產(chǎn)生一下數(shù)據(jù)存儲(chǔ)的位置)
-node:此節(jié)點(diǎn)名稱(chēng)
-bind:集群內(nèi)部通信地址,默認(rèn)0.0.0.0
-client:此節(jié)點(diǎn)綁定的通訊地址
以上只是關(guān)鍵參數(shù),以下是完整參數(shù)說(shuō)明:
但是命令啟動(dòng)很繁瑣,所以推薦下面的配置文件的方式啟動(dòng)
在consul同文件夾下建立一個(gè)server.json的配置文件
為了快速啟動(dòng),再建立一個(gè)bat批處理文件runconsul.bat
consul agent -config-dir server.jsonpause
雙擊runconsul.bat啟動(dòng)consul
在192.168.74.54服務(wù)器開(kāi)啟一個(gè)server端繼續(xù)以上操作。
命令方式啟動(dòng)
consul agent -server -ui -data-dir opt/consul/data -node Server01 -bind 192.168.74.54 -client 192.168.74.54 -join=192.168.74.55
-join將192.168.74.54加入到192.168.74.55服務(wù)器
配置文件方式:
在192.168.74.161服務(wù)器開(kāi)啟一個(gè)consul的client端
命令方式:
consul agent -ui -data-dir opt/consul/data -node ServerSlave -bind 192.168.74.161 -client 192.168.74.161 -join 192.168.74.55
配置文件方式:
簡(jiǎn)單Consul集群到這里就搭建成功,只要訪問(wèn)三臺(tái)服務(wù)器任意一個(gè)都可數(shù)據(jù)同步,演示:
服務(wù)注冊(cè)關(guān)鍵代碼
首先新建一個(gè)ConsulClient的類(lèi)庫(kù)
ConsulRegister.csproj所需組件如下:
再新建一個(gè).netcore的webapi項(xiàng)目WebA,并且引用ConsulRegister項(xiàng)目
在WebA項(xiàng)目中的Startup.cs文件中加入Consul服務(wù)
在WebA項(xiàng)目的appsettings.json配置文件中加入以下Consul服務(wù)端配置
這里服務(wù)注冊(cè)就算完成
接下來(lái)繼續(xù)Ocelot借助于Consul實(shí)現(xiàn)服務(wù)發(fā)現(xiàn)
新建項(xiàng)目Ocelot.Gateway
將以下依賴(lài)加入Ocelot.Gateway.csproj中:
新建ocelot.json文件
修改Startup.cs文件如下:
發(fā)布WebA后復(fù)制兩份分別啟動(dòng)
dotnet WebA.dll --urls="http://0.0.0.0:2001"
dotnet WebA.dll --urls="http://0.0.0.0:2002"
到這里相當(dāng)于2001和2002程序簡(jiǎn)單集群了一下
可以發(fā)現(xiàn)日志中有 http://192.168.74.161:2002/HealthCheck調(diào)用信息:
這其實(shí)是consul進(jìn)行健康檢查進(jìn)行的調(diào)用。
啟動(dòng)多個(gè)程序后,打開(kāi)瀏覽器打開(kāi)Consuld界面會(huì)發(fā)現(xiàn)注冊(cè)了兩個(gè)服務(wù)
這里ocelot網(wǎng)關(guān)和consul的服務(wù)注冊(cè)和發(fā)現(xiàn)就算初步集成。
如果生成環(huán)境是windows的情況,將consul做成windwos服務(wù)即可
sc create "ConsulServer" binPath="F:\XXX\consul.exe agent -config-dir XXX.json"
生產(chǎn)環(huán)境是linux則借助systemd做成守護(hù)進(jìn)程即可
看完上述內(nèi)容,你們對(duì)如何從零搭建ocelot網(wǎng)關(guān)和consul集群有進(jìn)一步的了解嗎?如果還想了解更多知識(shí)或者相關(guān)內(nèi)容,請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝大家的支持。