首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 软件管理 > 软件架构设计 >

MINA2处置转发的一种解决方式

2012-09-10 
MINA2处理转发的一种解决方式场景:服务端开了两个SOCKET服务,分别对应两种客户端,假定分别无客户端A,客户

MINA2处理转发的一种解决方式
  场景:服务端开了两个SOCKET服务,分别对应两种客户端,假定分别无客户端A,客户端B。客户端A是短连接,发完消息得到反馈就结束,客户端B登陆上服务端之后就一直保持长连接。需求是:A发消息之后,进行业务处理,然后将处理的结果要发给客户端B。
  目前考虑建立一起全局的ConcurrentHashMap,将客户端B的长连接中的IoSession放入ConcurrentHashMap中,客户端A处理完成之后,找到ConcurrentHashMap中的IoSession,然后调用write(msg)方法。

//sessionCurHashMap为全局变量,是一个ConcurrentHashMapIoSession sendSession = (IoSession) sessionCurHashMap.get("key");WriteFuture future = sendSession.write("转发数据"); // 发送数据future.awaitUninterruptibly(); // 等待发送数据操作完成if(future.isWritten()) {     // 数据已经被成功发送System.out.println("数据已经被成功发送");} else {     // 数据发送失败System.out.println("数据发送失败");}

 

热点排行