您好,登錄后才能下訂單哦!
這篇文章主要介紹“windows下如何搭建Consul集群”的相關(guān)知識(shí),小編通過(guò)實(shí)際案例向大家展示操作過(guò)程,操作方法簡(jiǎn)單快捷,實(shí)用性強(qiáng),希望這篇“windows下如何搭建Consul集群”文章能幫助大家解決問(wèn)題。
Consul 是 HashiCorp 公司的一個(gè)用于實(shí)現(xiàn)分布式系統(tǒng)的服務(wù)發(fā)現(xiàn)與配置工具。Consul內(nèi)置了服務(wù)注冊(cè)與發(fā)現(xiàn)框 架、分布一致性協(xié)議實(shí)現(xiàn)、健康檢查、Key/Value存儲(chǔ)、多數(shù)據(jù)中心方案。由于出現(xiàn)得晚些,Consul具有功能完善、部署簡(jiǎn)單、使用方便等特點(diǎn)。
Consul由Go語(yǔ)言開(kāi)發(fā),因此也繼承了Go語(yǔ)言跨平臺(tái),易安裝的特點(diǎn)。
這里以Windows平臺(tái)為例,我這里下載的是64位版本,解壓后就一個(gè)exe程序,直接以如下命令啟動(dòng):
consul agent-dev
這里有兩個(gè)參數(shù): agent表面啟動(dòng)了一個(gè)服務(wù)實(shí)例, -dev則是以快速開(kāi)發(fā)的方式啟動(dòng)這個(gè)實(shí)例。這個(gè)參數(shù)包含了大多數(shù)常用的功能,可以比較方便我們演示后面的功能,但它不對(duì)服務(wù)進(jìn)行序列化,因此是不能應(yīng)用于生產(chǎn)環(huán)境的。
啟動(dòng)后,可以看到如下提示信息:
> consul agent –dev ==> Starting Consul agent... ==> Consul agent running! Version: 'v1.4.0' Node ID: 'e59c9885-c8df-608a-f870-dab9078f5c0d' Node name: 'Develop-PC1' Datacenter: 'dc1' (Segment: '<all>') Server: true (Bootstrap: false) Client Addr: [127.0.0.1] (HTTP: 8500, HTTPS: -1, gRPC: 8502, DNS: 8600) Cluster Addr: 127.0.0.1 (LAN: 8301, WAN: 8302) Encrypt: Gossip: false, TLS-Outgoing: false, TLS-Incoming: false
Consul自帶一個(gè)界面美觀,功能強(qiáng)大的,開(kāi)箱即用的Web界面。通過(guò)該界面我們可以查看所有的服務(wù)以及節(jié)點(diǎn),查看所有的健康監(jiān)測(cè)及其當(dāng)前的狀態(tài),以及讀取和設(shè)置鍵/值數(shù)據(jù)。
該界面被映射到/ui上,和HTTP API使用相同的端口。默認(rèn)就是http://localhost:8500/ui。
如果你要在其它機(jī)器上訪問(wèn)該Web界面,可以加上-client參數(shù)指定綁定的IP。
consul agent -dev -bind=192.168.2.210 -client 0.0.0.0
consul支持配置文件的方式靜態(tài)配置服務(wù),首先我們定義一個(gè)json格式的配置文件:
{ "service": { "name": "web", "tags": [ "rails" ], "port": 80 } }
配置文件主要指定的是服務(wù)名稱,地址,端口等信息。
然后用-config-dir指定配置文件目錄啟動(dòng)consul,consul會(huì)自動(dòng)加載該目錄下的所有json文件,每個(gè)文件作為一個(gè)靜態(tài)配置服務(wù)。
> consul agent -dev -bind=192.168.0.211 -config-dir ./services
==> Starting Consul agent... ==> Consul agent running! ... 2018/12/05 11:43:23 [DEBUG] agent: Node info in sync 2018/12/05 11:43:23 [DEBUG] agent: Service "web" in sync 2018/12/05 11:43:23 [DEBUG] agent: Node info in sync 2018/12/05 11:43:25 [DEBUG] agent: Skipping remote check "serfHealth" since it is managed automatically 2018/12/05 11:43:25 [DEBUG] agent: Service "web" in sync 2018/12/05 11:43:25 [DEBUG] agent: Node info in sync
從輸出信息中可以看到名為"web"的服務(wù)已經(jīng)同步進(jìn)來(lái)。
也可以在web界面上看到該服務(wù):
除了靜態(tài)配置外,使用的最多的還是服務(wù)主動(dòng)注冊(cè)的方案。consul提供了一系列rest接口使得我們可以方便的注冊(cè)自己的服務(wù)。
接口地址:http://localhost:8500/v1/agent/service/register
操作方式:PUT
{ "ID": "redis1", "Name": "redis", "Tags": [ "primary", "v1" ], "Address": "127.0.0.1", "Port": 8000, "EnableTagOverride": false, "Check": { "DeregisterCriticalServiceAfter": "90m", "Script": "/usr/local/bin/check_redis.py", "HTTP": "http://localhost:5000/health", "Interval": "10s" } }
接口地址:http://localhost:8500/v1/agent/service/deregister/redis1
操作方式:PUT
接口地址: http://localhost:8500/v1/catalog/service/web
操作方式: GET
接口地址: http://localhost:8500/v1/catalog/service/web?passing
操作方式: GET
consul的集群拓?fù)浼軜?gòu)如下圖所示:
它主要具有如下兩種狀態(tài)的節(jié)點(diǎn):
Server: 有完整功能的代理,這些功能包括參與Raft選舉,維護(hù)集群狀態(tài),響應(yīng)RPC查詢,與其他數(shù)據(jù)中心交互WAN gossip和轉(zhuǎn)發(fā)查詢給leader或者遠(yuǎn)程數(shù)據(jù)中心。
Client:一個(gè)Client是一個(gè)轉(zhuǎn)發(fā)所有RPC到server的代理。這個(gè)client是相對(duì)無(wú)狀態(tài)的。client唯一執(zhí)行的后臺(tái)活動(dòng)是加入LAN gossip池。這有一個(gè)最低的資源開(kāi)銷(xiāo)并且僅消耗少量的網(wǎng)絡(luò)帶寬。
consul的集群搭建本身涉及的內(nèi)容比較多,具體可參看文章Consul 集群部署。本文這里就介紹一個(gè)最簡(jiǎn)單的拓?fù)淝闆r:1server + nclient的場(chǎng)景。
啟動(dòng)Server的指令一般如下:
consul agent -data-dir=./data -node=node0 -bind=192.168.0.211 -datacenter=dc1 -ui -client=0.0.0.0 -server -bootstrap-expect 1
這里用到了不少參數(shù),這里就簡(jiǎn)單的介紹下:
-data-dir=./data 必須,指定數(shù)據(jù)文件存儲(chǔ)路徑
-node=node0 必須,指定了節(jié)點(diǎn)的名稱,該名稱在整個(gè)網(wǎng)絡(luò)中必須唯一。
-bind=192.168.0.211 多Ip地址機(jī)器上必須,指定了綁定的Ip地址
-datacenter=dc1 可選,指定了所屬的數(shù)據(jù)中心,默認(rèn)為dc1
-ui 可選,是否啟用web服務(wù)器
-client=0.0.0.0 可選,指定了可以訪問(wèn)的客戶端范圍,默認(rèn)是127.0.0.1
-server 必須,表明了該節(jié)點(diǎn)是server節(jié)點(diǎn)
-bootstrap-expect 1 可選
有了上述知識(shí)后,在最簡(jiǎn)單的場(chǎng)景下,一般可以簡(jiǎn)化為如下形式:
consul agent -data-dir ./data -node=node0 -bind=192.168.0.211 -ui -server
啟動(dòng)Client的指令一般如下:
consul agent -data-dir=./data -node=node1 -bind=192.168.0.210 -datacenter=dc1 -ui -client=0.0.0.0 -join 192.168.0.211
同樣,基于前面的介紹,我們也可以把啟動(dòng)客戶端指令簡(jiǎn)化如下:
consul agent -data-dir=./data -node=node1 -bind=192.168.0.210 -ui -join 192.168.0.211
相比啟動(dòng)Server的指令,少了一個(gè)-server,表明它是一個(gè)客戶端agent,同是,多了一個(gè)-join 192.168.0.211,表明了它需要連接到那個(gè)server。這個(gè)參數(shù)也可以不配置,通過(guò)命令行consul join 192.168.0.211手動(dòng)加入。
啟動(dòng)了client后,就可以通過(guò)consul members
指令查看成員了:
> consul members Node Address Status Type Build Protocol DC Segment node0 192.168.0.211:8301 alive server 1.4.0 2 dc1 <all> node1 192.168.0.210:8301 alive client 1.4.0 2 dc1 <default>
也可以通過(guò)Http接口查看:
http://localhost:8500/v1/catalog/nodes
[ { "ID": "4314607d-629c-24a0-9e6c-d787efebe8c9", "Node": "node0", "Address": "192.168.0.211", "Datacenter": "dc1", "TaggedAddresses": { "lan": "192.168.0.211", "wan": "192.168.0.211" }, "Meta": { "consul-network-segment": "" }, "CreateIndex": 5, "ModifyIndex": 6 }, { "ID": "0a59426a-1723-6389-8681-0a16b54965e4", "Node": "node1", "Address": "192.168.0.210", "Datacenter": "dc1", "TaggedAddresses": { "lan": "192.168.0.210", "wan": "192.168.0.210" }, "Meta": { "consul-network-segment": "" }, "CreateIndex": 456, "ModifyIndex": 457 } ]
同樣,也可以在web界面查看:
關(guān)于“windows下如何搭建Consul集群”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí),可以關(guān)注億速云行業(yè)資訊頻道,小編每天都會(huì)為大家更新不同的知識(shí)點(diǎn)。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。