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