我們的場景如下:有一個使用 Netty 編寫的 TCP 服務器。有多個客戶端與服務器建立連接。建立連接后,可以在兩個方向上發送消息。為了能夠將消息傳遞給正確的收件人,我需要在處理程序之外維護通道。我知道ChannelGroup這讓我可以輕松實現廣播服務器(向所有客戶端發送一條消息)?,F在的需求是如何寫入特定的通道。我正在考慮使用ChannelGroup特定于客戶端的 id 映射(將Map<ClientId, ChannelId>客戶端 id 映射到通道 id)來豐富它。通過這種方式,有了客戶端 ID,我就可以輕松獲取頻道并寫入內容?,F在我的問題是:ChannelHandlerContext一般來說,寫via和via有什么區別Channel?(因為ChannelGroup給了我Channelnot ChannelHandlerContext)。維持 的小組是不是一個壞主意ChannelHandlerContext?(換句話說,我們為什么沒有ChannelHandlerContextGroup)?還有其他建議如何做嗎?
1 回答

繁星coding
TA貢獻1797條經驗 獲得超4個贊
1)Channel與ChannelHandler上下文上的操作之間的區別在于,例如,當使用時,Channel.write(...)
它將開始遍歷while ChannelPipeline
(從尾部到頭部),而使用ChannelHandlerContext.write(...)
它將開始遍歷屬于給ChannelPipeline
定的ChannelHandlerContext
中的具體位置,因為它與之前添加的ChannelPipeline
“相關” 。ChannelHandler
2)這不是一個壞主意,但大多數時候使用的用戶ChannelGroup
想要使用Channel.write(...)
(見上文)
3)使用ChannelGroup
orMap
即可。使用時,請確保關閉后將Map
刪除Channel
/ 。 ChannelHandlerContext
Map
Channel
添加回答
舉報
0/150
提交
取消