1个serv goroutine需要和5000以上可变数量的client goroutine通过chan通信,client作为send发送数据量较大,请问serv与client能通过chan[ ] string 来通信吗?serv端如何监控这个 chan slice呢?貌似select无法完成?如果只能用一个异步chan来完成,在serv端for range chan时是否能保证一个client所发送消息的有序被处理?性能上有什么好的建议?谢谢
每个会话启动routine,该routine负责接受或发送客户端的消息,收到消息后再附加客户端的标识,一起传给消息处理。消息处理采用chan;消息处理可以为一个或多个routine。大致这样。
#7
更多评论
如果采取chan slice来一一对应client,请问serv端有何好的方法能触发读取?谢谢,还有请问for range chan的退出条件是chan关闭吗?
#2