我有一个简单的程序,它接收一个连接,做一些处理,并在标准端口上发送回一个响应。由于这是同步完成的,因此如果一个请求花费的时间太长,则不会处理并发请求。
无论发生什么阻塞请求,允许同时处理多个请求的方法是可延迟的吗?
谢谢,
发布于 2011-07-29 07:05:19
最简单的方法是创建一个新的线程来处理你的后台任务,然后在做任何与EventMachine相关的事情之前切换回主线程。您可以使用defer方法执行此操作:
def do_something
EventMachine.defer do
do_long_process
end
end请记住,您的块所接触的应用程序部分必须是线程安全的,并且您需要确保返回到主线程时使用类似于next_tick的代码,以确保所有EventMachine操作都发生在正确的线程上。
发布于 2011-08-09 03:52:24
这取决于为什么你的请求很长,如果它是一些IO绑定的东西,比如数据库查询,或者任何类型的对另一个服务器的请求(HTTP,TCP,SMTP,...)那么EventMachine就是我们要走的路。
如果这不是你的情况,你能描述一下为什么你的请求花费了这么多时间吗?
https://stackoverflow.com/questions/6866653
复制相似问题