主要邏輯:
使用netty實(shí)現(xiàn)長連接,主要靠心跳來維持服務(wù)器端及客戶端連接。
主要的實(shí)現(xiàn)邏輯如下:
服務(wù)器端:(HeartBeatRespHandler)
1, 服務(wù)器在網(wǎng)絡(luò)空閑操作一定時(shí)間后,服務(wù)端失敗心跳計(jì)數(shù)器加1。
2, 如果收到客戶端的ping心跳包,則清零失敗心跳計(jì)數(shù)器,如果連續(xù)n次未收到客戶端的ping心跳包,則關(guān)閉鏈路,釋放資源,等待客戶端重連。
客戶端:(HeartBeatReqHandler)
1, 客戶端網(wǎng)絡(luò)空閑在一定時(shí)間內(nèi)沒有進(jìn)行寫操作時(shí),則發(fā)送一個(gè)ping心跳包。
2, 如果服務(wù)器端未在發(fā)送下一個(gè)心跳包之前回復(fù)pong心跳應(yīng)答包,則失敗心跳計(jì)數(shù)器加1。
3, 如果客戶端連續(xù)發(fā)送n(此處根據(jù)具體業(yè)務(wù)進(jìn)行定義)次ping心跳包,服務(wù)器端均未回復(fù)pong心跳應(yīng)答包,則客戶端斷開連接,間隔一定時(shí)間進(jìn)行重連操作,直至連接服務(wù)器成功。