中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

如何從零搭建ocelot網關和consul集群

發布時間:2021-12-10 16:52:57 來源:億速云 閱讀:393 作者:柒染 欄目:大數據

今天就跟大家聊聊有關如何從零搭建ocelot網關和consul集群,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。

介紹

微服務中有關鍵的幾項技術,其中網關和服務服務發現,服務注冊相輔相成。

首先解釋幾個需要的術語

網關 Gateway(API GW / API 網關),顧名思義,是企業 IT 在系統邊界上提供給外部訪問內部接口服務的統一入口,簡化了外部由于多服務協同完成任務時的繁瑣配置。網關組件有Kong,ocelot,

服務發現:通過網關訪問內部各個微服務,網關要找到所需服務的過程稱為服務發現

服務注冊:既然有服務發現,前提是要把所需服務提前“錄入”,這個錄入的過程稱為服務注冊。服務注冊可配置文件(人肉方式不推薦),也可用服務注冊組件如Consul或者Eureka等等(推薦)

搭建Consul集群(Windows)

官網下載Consul程序,https://www.consul.io/downloads.html

下載下來就是一個可執行文件Consul.exe

Consul有兩種代理模式,一種server,一種client,官方建議Server端達到3臺以上才可高可用,但不要太多,太多會給集群間數據同步造成壓力,client數量不限。

多個server端之間會選擇出一個leader,當一個server的leader宕機則會從其他server端”投票“選擇新的leader

實踐

這里server我們用2臺實驗

192.168.74.55

192.168.74.54

1臺Client

192.168.74.161

consul啟動有兩種方式一種是命令行,一種是配置文件的方式。

命令行方式啟動一個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

關鍵參數說明

-server:server模式啟動

-ui :開啟ui界面(consul.exe內部帶了GUI圖形界面操作)

 -bootstrap-expect 2:server端到2個時集群生效

-data-dir:consul產生的文件路徑(consul自己會產生一下數據存儲的位置)

-node:此節點名稱

-bind:集群內部通信地址,默認0.0.0.0

-client:此節點綁定的通訊地址

以上只是關鍵參數,以下是完整參數說明:  

 如何從零搭建ocelot網關和consul集群

但是命令啟動很繁瑣,所以推薦下面的配置文件的方式啟動

在consul同文件夾下建立一個server.json的配置文件

如何從零搭建ocelot網關和consul集群

為了快速啟動,再建立一個bat批處理文件runconsul.bat

consul agent -config-dir server.jsonpause

雙擊runconsul.bat啟動consul

在192.168.74.54服務器開啟一個server端繼續以上操作。

命令方式啟動

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服務器

配置文件方式:

如何從零搭建ocelot網關和consul集群

在192.168.74.161服務器開啟一個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

配置文件方式:

如何從零搭建ocelot網關和consul集群

效果 

簡單Consul集群到這里就搭建成功,只要訪問三臺服務器任意一個都可數據同步,演示:

如何從零搭建ocelot網關和consul集群

如何從零搭建ocelot網關和consul集群

 netcore集成Consul服務注冊

服務注冊關鍵代碼

首先新建一個ConsulClient的類庫

如何從零搭建ocelot網關和consul集群

ConsulRegister.csproj所需組件如下:

如何從零搭建ocelot網關和consul集群

如何從零搭建ocelot網關和consul集群

如何從零搭建ocelot網關和consul集群

如何從零搭建ocelot網關和consul集群

再新建一個.netcore的webapi項目WebA,并且引用ConsulRegister項目

在WebA項目中的Startup.cs文件中加入Consul服務

如何從零搭建ocelot網關和consul集群

在WebA項目的appsettings.json配置文件中加入以下Consul服務端配置

如何從零搭建ocelot網關和consul集群

這里服務注冊就算完成

Ocelot網關搭建

接下來繼續Ocelot借助于Consul實現服務發現

新建項目Ocelot.Gateway

如何從零搭建ocelot網關和consul集群

將以下依賴加入Ocelot.Gateway.csproj中:

如何從零搭建ocelot網關和consul集群

新建ocelot.json文件

如何從零搭建ocelot網關和consul集群

修改Startup.cs文件如下:

如何從零搭建ocelot網關和consul集群

發布WebA后復制兩份分別啟動

dotnet WebA.dll --urls="http://0.0.0.0:2001"

dotnet WebA.dll --urls="http://0.0.0.0:2002"

到這里相當于2001和2002程序簡單集群了一下

可以發現日志中有 http://192.168.74.161:2002/HealthCheck調用信息:

如何從零搭建ocelot網關和consul集群

這其實是consul進行健康檢查進行的調用。

啟動多個程序后,打開瀏覽器打開Consuld界面會發現注冊了兩個服務

如何從零搭建ocelot網關和consul集群

 如何從零搭建ocelot網關和consul集群

如何從零搭建ocelot網關和consul集群

這里ocelot網關和consul的服務注冊和發現就算初步集成。

如果生成環境是windows的情況,將consul做成windwos服務即可

sc create "ConsulServer" binPath="F:\XXX\consul.exe agent -config-dir XXX.json"

生產環境是linux則借助systemd做成守護進程即可 

看完上述內容,你們對如何從零搭建ocelot網關和consul集群有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

老河口市| 安吉县| 穆棱市| 武冈市| 天峨县| 潮安县| 清新县| 娄烦县| 唐河县| 仙桃市| 奎屯市| 石狮市| 湟源县| 临汾市| 恩施市| 公主岭市| 五寨县| 姚安县| 龙南县| 贡山| 漳浦县| 张掖市| 永康市| 锡林郭勒盟| 珠海市| 卢龙县| 淅川县| 曲水县| 兰溪市| 沙雅县| 五常市| 承德县| 绥棱县| 合江县| 信宜市| 汕头市| 犍为县| 怀化市| 壤塘县| 太白县| 中超|