




下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
第go語言心跳超時的實現(xiàn)示例目錄一、背景二、心跳超時的實現(xiàn)2.1通過selectcase(設(shè)計概念比較多)2.2通過time.sleep(簡單有效)三、個人的實現(xiàn)觀感
一、背景
本文描述的是客戶端接收心跳信息的超時實現(xiàn)。心跳超時,或者接受信息超過限定時間在分布式系統(tǒng)中出現(xiàn)的次數(shù)比較多。常見的就有hadoop中節(jié)點超時,或者日志中出現(xiàn)timeout的字樣。
在學(xué)習(xí)go語言中,我也根據(jù)go語言的機(jī)制實現(xiàn)了心跳超時的這個問題。踩過坑,趟過水。
二、心跳超時的實現(xiàn)
2.1通過selectcase(設(shè)計概念比較多)
這種方法實現(xiàn)心跳,需要對go語言中的channel和selectcase機(jī)制有所了解。select代碼段中沒有包含default條件時,會一直阻塞到有通道操作。
需要注意的是?。。?!select語言只會阻塞一次,且執(zhí)行一次。如果需要多次判斷,或者可能有多個case條件需要滿足,那就需要增加for語句。
首先需要知道的是select是專為channel設(shè)計的,所以說每個case表達(dá)式都必須是包含操作通道的表達(dá)式。下面這段代碼是描述了隨機(jī)抽取一個channel發(fā)消息,正常情況下,不會觸發(fā)超時。為了觸發(fā)超時,注釋掉通道發(fā)送數(shù)據(jù)操作。超時五秒,則觸發(fā)超時。
packagemain
import(
"fmt"
"math/rand"
"time"
funcmain(){
//準(zhǔn)備好三個通道。
intChannels:=[3]chanint{
make(chanint,1),
make(chanint,1),
make(chanint,1),
//隨機(jī)選擇一個通道,并向它發(fā)送元素值。
index:=rand.Intn(3)
fmt.Printf("Theindex:%d\n",index)
//??取消這行代碼的注視,超時條件的選擇就會觸發(fā)。
//intChannels[index]-index
//哪一個通道中有可取的元素值,哪個對應(yīng)的分支就會被執(zhí)行。
select{
case-intChannels[0]:
fmt.Println("Thefirstcandidatecaseisselected.")
case-intChannels[1]:
fmt.Println("Thesecondcandidatecaseisselected.")
caseelem:=-intChannels[2]:
fmt.Printf("Thethirdcandidatecaseisselected,theelementis%d.\n",elem)
case-time.After(5*time.Second):
fmt.Println("timedout")
2.2通過time.sleep(簡單有效)
通過time.sleep()實現(xiàn)超時操作,是比較巧妙的。一般來說心跳超時是一個雙方交互的行為。
下面畫一個圖來描述一下。
為了方便理解,定義雙方都使用共同時間。
下面是代碼。
基本的邏輯是:
1、先給客戶端設(shè)置一個下次超時的時間
2、客戶端每次收到心跳的時候,更新這個時間
3、開啟一個獨立的線程,一致判斷當(dāng)前客戶端是否超時。
ps:結(jié)合時效和性能,可以間隔一定的時間來進(jìn)行判斷。
packagemain
import(
"fmt"
"sync"
"time"
typeClientstruct{
locksync.Mutex//加鎖
nextTimeOutTimetime.Time//下次超時時間
consttenSec=10
刷新每次的心跳超時機(jī)制
func(client*Client)freshTimeOutTime(){
client.lock.Lock()
deferclient.lock.Unlock()
client.nextTimeOutTime=time.Now().Add(tenSec*time.Second)
//開啟一個gp,每隔500ms判斷有沒有超時
func(client*Client)judgeTimeOut(){
for{
time.Sleep(500*time.Millisecond)
fmt.Printf("%v在判斷是否超時\n",client.nextTimeOutTime)
iftime.Now().After(client.nextTimeOutTime){
fmt.Printf("%v超時了\n",client.nextTimeOutTime)
//客戶端收到以后,修改下次心跳超時時間
func(client*Client)receiveHeart(){
client.freshTimeOutTime()
//開啟一個模擬ping客戶端的線程
funcpingClient(client*Client){
fortrue{
time.Sleep(11*time.Second)
fmt.Printf("%v請求發(fā)送時間\n",time.Now())
client.receiveHeart()
funcmain(){
cl
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 數(shù)據(jù)保護(hù)法在審計中的應(yīng)用試題及答案
- 中級審計師提升路徑與試題及答案的重視
- 優(yōu)化復(fù)習(xí)計劃審計師試題及答案
- 入團(tuán)考試營造氛圍試題及答案
- 中級會計學(xué)習(xí)班試題及答案
- 2025年入團(tuán)學(xué)習(xí)心得試題及答案
- 2025年建造師考試的職場價值與試題及答案
- 2025年中級會計外部考試試題及答案
- 2025年入團(tuán)考試突破重點試題及答案
- 中級會計實務(wù)操作的試題及答案
- -小學(xué)英語人稱代詞與物主代詞講解課件(共58張課件).課件
- DB46T 650-2024鐵皮石斛林下栽培技術(shù)規(guī)程
- 美甲入門理論基礎(chǔ)知識培訓(xùn)課程課件
- 小學(xué)科學(xué)青島版六三制四年級下冊第六單元《電的本領(lǐng)》教案(共3課)(2021新版)
- 孟萬金編制的中國大學(xué)生積極心理品質(zhì)量表+評分方式
- 選擇性育種對犬類行為遺傳的影響
- 人民調(diào)解培訓(xùn)
- 寧波市施工圖設(shè)計常見問題及質(zhì)量通病
- 第三單元 八音和鳴(一) 課件 2024-2025學(xué)年湘教版初中音樂七年級上冊
- 校服授權(quán)生產(chǎn)協(xié)議合同范本
- 碼頭維修保養(yǎng)投標(biāo)方案(技術(shù)方案)
評論
0/150
提交評論