写了一个 Sinatra 程序,其中有两个接口是这样的:
接口 1 :处理 GET 请求,根据 url 返回一张图片
接口 2 :收到请求后,发出一个请求请求服务器 B 回调本服务器的接口 1 获取图片,然后再将计算结果返回给服务器 A
现在问题出现了,当调用接口 2 的时候,由于请求发出后,服务器 B 需要调用服务器 A 的接口 1 ,导致服务器 A 无法处理接口 1 的请求,出现阻塞现象
Web 服务器用的 Thin ,当我用 ruby -e production app.rb 运行时,是可以同时处理两个请求的
但是用 thin s 命令运行时,却出现阻塞
本人比较菜 请各位大神帮帮忙 说说这是什么问题
1
jhaohai 2015-08-23 12:35:09 +08:00 via iPhone
webrick 同时只能处理一个请求
|
2
ch3rub1m OP @jhaohai 那 thin 也是吗 为什么我用 thin s 不行 用 ruby 直接跑就行 输出提示也是用 thin 在跑
|
4
ch3rub1m OP |
5
ch3rub1m OP 用 ps -A 命令看了一下 ruby 只有一个进程 但是不会阻塞
|
6
yakczh 2015-08-23 15:40:43 +08:00
图片是要实时生成的吗? 这类的工作可以放到 sidekiq 里面
|
7
kaichen 2015-08-23 18:36:35 +08:00
thin 单进程只能处理一个请求,并且用 cluster 的方式启动多个进程的话会监听多个端口,不能通过一个端口分发请求。
像 thin 要处理多个请求的话,需要前面再架个 Nginx 什么的。你要简单处理可以用 puma ,然后启动多个 worker ,这时就会有一个进程负责接受请求,然后分发到 worker 进程处理。 |