.Net?Core服務(wù)治理Consul健康檢查
繼續(xù)上一篇的話題,順便放上一篇的傳送門:點(diǎn)這里。
健康檢查
經(jīng)過之前的操作,我的consul已經(jīng)支持自動(dòng)擴(kuò)展,并且調(diào)用也很靠譜。但是這里有個(gè)問題,一旦服務(wù)列表里的某個(gè)服務(wù)掛了,consul并不知道,還是會(huì)把實(shí)際無效的地址返回給我,就算重啟consul容器也無法刷新到最新的狀態(tài)。所以,咱們要監(jiān)控服務(wù)可用性,主動(dòng)區(qū)分出不可用服務(wù),這種手段,就稱之為健康檢查。
進(jìn)入編碼環(huán)節(jié)。老規(guī)矩,還是進(jìn)入到之前我封裝好的注冊(cè)方法,在注冊(cè)時(shí)增加健康檢查的內(nèi)容:
client.Agent.ServiceRegister(new AgentServiceRegistration() { ID = $"server {ip}:{port}", Name = "shenzhen-ma", Address = ip, Port = int.Parse(port), Tags = new string[] { weight }, Check = new AgentServiceCheck() { Interval = TimeSpan.FromSeconds(10),//每隔10秒發(fā)起檢查 HTTP = $"http://{ip}:{port}/v1/client/base/index",//檢查請(qǐng)求地址 Timeout = TimeSpan.FromSeconds(5),//超時(shí)時(shí)長(zhǎng)5秒 DeregisterCriticalServiceAfter = TimeSpan.FromSeconds(10)//超過10秒還沒能連接到服務(wù),就開始注銷本服務(wù) } });
變色部分就是健康檢查的配置了。根據(jù)上面的配置,consul會(huì)周期性發(fā)起健康檢查,并且根據(jù)結(jié)果自動(dòng)移除不可用的服務(wù)。
這次我要嚴(yán)謹(jǐn)一些,用真實(shí)的遠(yuǎn)程服務(wù)器來模擬生產(chǎn)環(huán)境。手頭服務(wù)器太多,很多有項(xiàng)目在跑。仔細(xì)翻了翻,發(fā)現(xiàn)還有兩臺(tái)相對(duì)空閑的服務(wù)器,一臺(tái)是win server,另一臺(tái)centos,嘿嘿,正好。centos做consul服務(wù)器,win服務(wù)器用來做下游調(diào)用方。
先把consul搞起來:
進(jìn)去訪問下:
OK了,現(xiàn)在轉(zhuǎn)到另一臺(tái)服務(wù)器跑幾個(gè)客戶端。這里偷個(gè)懶,直接把可運(yùn)行文件拷貝過去,哈哈:
看下consul控制臺(tái):
還是熟悉的shenzhen-ma,兩個(gè)服務(wù)已經(jīng)穩(wěn)穩(wěn)的待在分組列表里了。注意我框起來的位置,它表示服務(wù)已經(jīng)通過了健康檢查。這時(shí)候我把5051這個(gè)程序關(guān)掉,再來看看:
5051狀態(tài)自動(dòng)更新成failing,而且沒過一會(huì)兒,它就會(huì)自動(dòng)移除。5050這時(shí)候去再去訪問,就訪問不到5051了:
再然后偷偷把5051跑起來,重新調(diào)用:
又可以訪問了不是?
新實(shí)例啟動(dòng)自動(dòng)發(fā)現(xiàn),實(shí)例狀態(tài)異常自動(dòng)剔除,下端調(diào)用無需任何調(diào)整,舒坦。起碼我這個(gè)懶人覺得很舒服。
tips:新的服務(wù)默認(rèn)狀態(tài)是failing,注冊(cè)成功后會(huì)馬上發(fā)起一次檢查,成功后才會(huì)變更狀態(tài)。而且服務(wù)注銷沒有那么快,耗時(shí)一般都會(huì)比設(shè)置的時(shí)間長(zhǎng)。
最后一點(diǎn)
關(guān)于consul寫了3篇了,要是都看完,想在項(xiàng)目里用起來是沒問題的,不過要上生產(chǎn)環(huán)境仍然有個(gè)隱患:?jiǎn)吸c(diǎn)故障。你想啊,consul這么能干,萬一它掛了可咋整。。。。所以集群是必要的,而且集群之后的服務(wù)注冊(cè)、調(diào)用自然就不能和單體一樣。這問題三言兩語還說不清,后面再寫吧。
到此這篇關(guān)于.Net Core服務(wù)治理Consul健康檢查的文章就介紹到這了。希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
解讀ASP.NET 5 & MVC6系列教程(1):ASP.NET 5簡(jiǎn)介
這篇文章主要介紹ASP.NET 5簡(jiǎn)介以及對(duì)各個(gè)版本號(hào)進(jìn)行解釋,ASP.NET 5中新的變化,需要的朋友可以參考下。2016-06-06在ASP.NET 2.0中操作數(shù)據(jù)之一:創(chuàng)建一個(gè)數(shù)據(jù)訪問層
本文主要介紹創(chuàng)建數(shù)據(jù)訪問層的具體步驟,從配置數(shù)據(jù)庫(kù)連接到插入,更新和刪除數(shù)據(jù)的具體實(shí)現(xiàn)方法,希望對(duì)大家有所幫助。2016-04-04在ASP.NET中調(diào)用存儲(chǔ)過程方法新解
在ASP.NET中調(diào)用存儲(chǔ)過程方法新解...2006-10-10Microsoft .Net Remoting系列教程之三:Remoting事件處理全接觸
本文主要講解.Net Remoting中的Remoting事件處理,需要的朋友可以參考下。2016-05-05《解剖PetShop》之四:PetShop之ASP.NET緩存
本文主要講解PetShop4.0的ASP.NET緩存,極大的提高的網(wǎng)站的性能,需要的朋友可以參考下。2016-05-05Visual Studio 2017使用EF選擇MySQL數(shù)據(jù)源
這篇文章介紹了Visual Studio 2017使用EF選擇MySQL數(shù)據(jù)源,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-01-01ASP.NET MVC4入門教程(五):從控制器訪問數(shù)據(jù)模型
本文介紹ASP.NET MVC4中在創(chuàng)建控制器的時(shí)候,同時(shí)使用Entity Framework為模型生成增刪改查等方法,方便控制器調(diào)用。2016-04-04在ASP.NET 2.0中操作數(shù)據(jù)之十六:概述插入、更新和刪除數(shù)據(jù)
本文主要介紹ASP.NET中插入、更新和刪除數(shù)據(jù)的原理,ObjectDataSource在頁(yè)面和潛在的數(shù)據(jù)之間扮演一個(gè)代理的角色,配合業(yè)務(wù)邏輯可以執(zhí)行Select()、Insert()、Update()和Delete()方法。2016-05-05