您好,登錄后才能下訂單哦!
這篇文章主要介紹“Netty socket客戶端怎么接收數(shù)據(jù)推送”,在日常操作中,相信很多人在Netty socket客戶端怎么接收數(shù)據(jù)推送問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Netty socket客戶端怎么接收數(shù)據(jù)推送”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
錯誤寫法:
以上寫法 根據(jù)全局成員非靜態(tài)變量connectStatus判斷 是否建立連接時。讀取不到更新后的值。
當修改connectStatus 為全局靜態(tài)變量時 可以讀取到最新的值,但是會導致不能及時的將線程池中的任務 取消掉 會對服務端進行多次連接。從而服務端 推送過來的數(shù)據(jù) 不能接收到。
關于重連注意點:
ChannelFuture future = client.connect(socketIp, port);future.awaitUninterruptibly(); |
初始化連接使用這個
Future.awaitUninterruptibly
當再 channelInactive 進行異步定時重連時 不能加await() 會導致程序阻塞。
上述代碼導致的問題:
遇到得奇葩問題:
當標紅方法 不是靜態(tài)方法,時普通成員方法 這個定時任務不會執(zhí)行。
最優(yōu)寫法:
采用schedule 延遲執(zhí)行,監(jiān)聽返回結果 如果沒有連接成功 則進行遞歸操作;否則停止任務。
到此,關于“Netty socket客戶端怎么接收數(shù)據(jù)推送”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續(xù)學習更多相關知識,請繼續(xù)關注億速云網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。