servlet thread, SEDA

也是和程序员朋友聊天。
说到了SEDA。关于请求分类合并,批量处理。

谈到一个问题,就是thread个数问题。
目前的servlet container的thread策略是一个request,一个thread。
如果换成如下的方式,就可能减少thread个数。
request进来,不启动一个thread。
而是产生一个listner task,进入task queue。
有一个task picker把task queue里面的task进行分拣和分类,合并成批量处理的任务。然后根据这些批量任务产生thread。
执行完毕,通知task listner,结果返回用户。

朋友的深入考虑的意见:
任务可以分为several stages。每个stage完成都可以通知task listner,可以把部分结果返回给用户,增加响应的友好性。

另一个朋友的关于socket连接的说法,也觉得很有用。
empty socket可以很多,几万个都没有问题。一旦开始数据传输,socket连接数目就有限制了。
我想是因为网络协议栈空间的限制。

这个朋友考虑了SEDA很久。我是第一次听说SEDA,还在学习中。
他关于task listener的设想是,类似于ajax, web service client的异步event model.

submit_task();
on_task_finish();
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值