




下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
第go語(yǔ)言心跳超時(shí)的實(shí)現(xiàn)示例目錄一、背景二、心跳超時(shí)的實(shí)現(xiàn)2.1通過selectcase(設(shè)計(jì)概念比較多)2.2通過time.sleep(簡(jiǎn)單有效)三、個(gè)人的實(shí)現(xiàn)觀感
一、背景
本文描述的是客戶端接收心跳信息的超時(shí)實(shí)現(xiàn)。心跳超時(shí),或者接受信息超過限定時(shí)間在分布式系統(tǒng)中出現(xiàn)的次數(shù)比較多。常見的就有hadoop中節(jié)點(diǎn)超時(shí),或者日志中出現(xiàn)timeout的字樣。
在學(xué)習(xí)go語(yǔ)言中,我也根據(jù)go語(yǔ)言的機(jī)制實(shí)現(xiàn)了心跳超時(shí)的這個(gè)問題。踩過坑,趟過水。
二、心跳超時(shí)的實(shí)現(xiàn)
2.1通過selectcase(設(shè)計(jì)概念比較多)
這種方法實(shí)現(xiàn)心跳,需要對(duì)go語(yǔ)言中的channel和selectcase機(jī)制有所了解。select代碼段中沒有包含default條件時(shí),會(huì)一直阻塞到有通道操作。
需要注意的是!!!!select語(yǔ)言只會(huì)阻塞一次,且執(zhí)行一次。如果需要多次判斷,或者可能有多個(gè)case條件需要滿足,那就需要增加for語(yǔ)句。
首先需要知道的是select是專為channel設(shè)計(jì)的,所以說每個(gè)case表達(dá)式都必須是包含操作通道的表達(dá)式。下面這段代碼是描述了隨機(jī)抽取一個(gè)channel發(fā)消息,正常情況下,不會(huì)觸發(fā)超時(shí)。為了觸發(fā)超時(shí),注釋掉通道發(fā)送數(shù)據(jù)操作。超時(shí)五秒,則觸發(fā)超時(shí)。
packagemain
import(
"fmt"
"math/rand"
"time"
funcmain(){
//準(zhǔn)備好三個(gè)通道。
intChannels:=[3]chanint{
make(chanint,1),
make(chanint,1),
make(chanint,1),
//隨機(jī)選擇一個(gè)通道,并向它發(fā)送元素值。
index:=rand.Intn(3)
fmt.Printf("Theindex:%d\n",index)
//??取消這行代碼的注視,超時(shí)條件的選擇就會(huì)觸發(fā)。
//intChannels[index]-index
//哪一個(gè)通道中有可取的元素值,哪個(gè)對(duì)應(yīng)的分支就會(huì)被執(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(簡(jiǎn)單有效)
通過time.sleep()實(shí)現(xiàn)超時(shí)操作,是比較巧妙的。一般來說心跳超時(shí)是一個(gè)雙方交互的行為。
下面畫一個(gè)圖來描述一下。
為了方便理解,定義雙方都使用共同時(shí)間。
下面是代碼。
基本的邏輯是:
1、先給客戶端設(shè)置一個(gè)下次超時(shí)的時(shí)間
2、客戶端每次收到心跳的時(shí)候,更新這個(gè)時(shí)間
3、開啟一個(gè)獨(dú)立的線程,一致判斷當(dāng)前客戶端是否超時(shí)。
ps:結(jié)合時(shí)效和性能,可以間隔一定的時(shí)間來進(jìn)行判斷。
packagemain
import(
"fmt"
"sync"
"time"
typeClientstruct{
locksync.Mutex//加鎖
nextTimeOutTimetime.Time//下次超時(shí)時(shí)間
consttenSec=10
刷新每次的心跳超時(shí)機(jī)制
func(client*Client)freshTimeOutTime(){
client.lock.Lock()
deferclient.lock.Unlock()
client.nextTimeOutTime=time.Now().Add(tenSec*time.Second)
//開啟一個(gè)gp,每隔500ms判斷有沒有超時(shí)
func(client*Client)judgeTimeOut(){
for{
time.Sleep(500*time.Millisecond)
fmt.Printf("%v在判斷是否超時(shí)\n",client.nextTimeOutTime)
iftime.Now().After(client.nextTimeOutTime){
fmt.Printf("%v超時(shí)了\n",client.nextTimeOutTime)
//客戶端收到以后,修改下次心跳超時(shí)時(shí)間
func(client*Client)receiveHeart(){
client.freshTimeOutTime()
//開啟一個(gè)模擬ping客戶端的線程
funcpingClient(client*Client){
fortrue{
time.Sleep(11*time.Second)
fmt.Printf("%v請(qǐng)求發(fā)送時(shí)間\n",time.Now())
client.receiveHeart()
funcmain(){
cl
溫馨提示
- 1. 本站所有資源如無(wú)特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年文化概論考試簡(jiǎn)明扼要的試題及答案
- 節(jié)約用電主題倡議書
- 科學(xué)備考執(zhí)業(yè)藥師試題及答案
- 行政管理團(tuán)隊(duì)合作試題與答案解析
- 行政管理專科語(yǔ)文應(yīng)試提升方案試題及答案
- 行政法學(xué)理論體系與試題答案分享
- 自考行政管理自我評(píng)估工具試題及答案
- 行政管理與青年文化市場(chǎng)的動(dòng)態(tài)試題及答案
- 步兵知識(shí)教案及課件下載
- 冠心病健康教育與防治策略
- 張家界2025年張家界市公安局招聘360名警務(wù)輔助人員筆試歷年參考題庫(kù)附帶答案詳解
- 【大數(shù)跨境】2025年保溫杯出海市場(chǎng)洞察報(bào)告
- 《掌握專利申請(qǐng)流程》課件
- 腎內(nèi)科健康科普護(hù)理
- 礦業(yè)技術(shù)服務(wù)合同協(xié)議
- 第1課 中華文明的起源與早期國(guó)家 課件 人教版必修上冊(cè)中外歷史綱要
- 小學(xué)男生生理衛(wèi)生健康教育講座
- 2025-2030中國(guó)核電用鋼行業(yè)市場(chǎng)發(fā)展分析及發(fā)展前景與投資戰(zhàn)略研究報(bào)告
- 護(hù)理核心制度培訓(xùn)與質(zhì)量提升
- 語(yǔ)言學(xué)概論知到課后答案智慧樹章節(jié)測(cè)試答案2025年春湖州師范學(xué)院
- 2025年中國(guó)萬(wàn)壽菊干花顆粒行業(yè)市場(chǎng)發(fā)展前景及發(fā)展趨勢(shì)與投資戰(zhàn)略研究報(bào)告
評(píng)論
0/150
提交評(píng)論