求一个思路的实现
[img]http://dl.iteye.com/upload/attachment/0074/4781/3d258b50-bffd-3605-840a-b0dd3f2525cb.jpg[/img]
多个用户请求一个servlet的sleep方法,然后都在这里不断循环,不让起返回,保持一段时间的http连接。
李四向张2发送数据,请求这个servlet的的update方法、要求张二的线程退出。
这个该如何实现?
可以使用java.util里面的exchange对象来多线程交换数据。
创建一个单例,然后属性map,key为用户ID,value业务数据。
一、用户1、2、3请求上来,往map里面放数据,这个时候请求不返回(注意超时时间控制,而且每个用户最多保持2个http长连接,这个是Http规范)。
二、当用户4上来,带上命令要求停止2用户,这个时候用户4和用户2的两个线程用exchange交换,相当于唤醒线程。
sleep睡多长时间 循环的条件是神马 最好有伪代码
多个用户请求一个servlet的sleep方法,然后都在这里不断循环,不让起返回,保持一段时间的http连接。 这样做可能会导致你服务器连接用尽 别人都在等待连接,导致服务器无响应
李四向张2发送数据,请求这个servlet的的update方法、要求张二的线程退出。
这个该如何实现? 这个意义何在?
web开发是基于请求/响应模式,你这种设计根本无意义。
这是个什么样的使用场景啊,真令人感兴趣。。。
把数据持久化到数据库里,通过数据库来做业务交互
http连接时间较长的情况下会抛出异常的,不知道这块怎么解决?
两种方法:
1. 公共变量,互斥访问,李四写标志位,张2读,读到后退出
2. 对象锁,张二线程调用对象锁wait,其他线程如李四调用对象锁notify使其继续运行后退出
btw,不要轻易用循环等待,耗CPU资源的玩意
1.多个用户请求一个servlet的sleep方法,然后都在这里不断循环,不让起返回,保持一段时间的http连接。
暂时我没想到好的办法,首先可以排除轮询的方式,可以采用状态机的模式去做。如:保存数据。
2.李四向张2发送数据
轮询的方式貌似不可以,可以采用“长连接”的方式 websocket,可以采用服务器端push的模式去做。
3.请求这个servlet的的update方法、要求张二的线程退出。
可以考虑观察者模式,在push的通知执行update方法。