我想的方法有两个: 1 、一个线程池,同时维护一个每个线程执行任务的信息。新的任务来了,判断是否有对应用一资源执行的任务,放在一个等待队列里。起一个定时作业,轮询是否完成。若完成放入线程池执行。 2 、起多个线程,多少个线程就起多少个队列,线程 take 队列里的 task 。拿到消息 hash 到各自队列中. 在知乎上提了个问题欢迎大家解答。 https://www.zhihu.com/question/52616271
1
ryd994 2016-11-15 16:20:03 +08:00
总的来讲,是每人一个线程
当然,这里说一个线程并不需要是操作系统里一个实际线程 简单高效就是用协程,比如 greenlet ,比如 golang 复杂点就是 event based ,实际上无非自己实现一遍协程 要同时保证线程内部有序就线程内加锁 或者用 worker 模型,启动的时候启动多个 worker ,由 dispatcher 分批给某个 worker ,从此保证来自这个用户的事件只由这个 worker 处理,就不需要加锁 |