有人懂 Ruby 吗,大家来看看这种场景算是因为单线程引起的吗

2015-08-23 12:20:52 +08:00
 ch3rub1m

写了一个 Sinatra 程序,其中有两个接口是这样的:

接口 1 :处理 GET 请求,根据 url 返回一张图片
接口 2 :收到请求后,发出一个请求请求服务器 B 回调本服务器的接口 1 获取图片,然后再将计算结果返回给服务器 A

现在问题出现了,当调用接口 2 的时候,由于请求发出后,服务器 B 需要调用服务器 A 的接口 1 ,导致服务器 A 无法处理接口 1 的请求,出现阻塞现象

Web 服务器用的 Thin ,当我用 ruby -e production app.rb 运行时,是可以同时处理两个请求的
但是用 thin s 命令运行时,却出现阻塞

本人比较菜 请各位大神帮帮忙 说说这是什么问题

2816 次点击
所在节点    问与答
8 条回复
jhaohai
2015-08-23 12:35:09 +08:00
webrick 同时只能处理一个请求
ch3rub1m
2015-08-23 13:53:34 +08:00
@jhaohai 那 thin 也是吗 为什么我用 thin s 不行 用 ruby 直接跑就行 输出提示也是用 thin 在跑
fogisland
2015-08-23 14:40:28 +08:00
@ch3rub1m 是不是 production 模式下开了多个进程所以才没有阻塞
ch3rub1m
2015-08-23 15:33:23 +08:00
@fogisland 我的 config.ru 里指定的模式也是 PRODUCTION 啊,但是 thin s 命令就不行
ch3rub1m
2015-08-23 15:34:21 +08:00
用 ps -A 命令看了一下 ruby 只有一个进程 但是不会阻塞
yakczh
2015-08-23 15:40:43 +08:00
图片是要实时生成的吗? 这类的工作可以放到 sidekiq 里面
kaichen
2015-08-23 18:36:35 +08:00
thin 单进程只能处理一个请求,并且用 cluster 的方式启动多个进程的话会监听多个端口,不能通过一个端口分发请求。

像 thin 要处理多个请求的话,需要前面再架个 Nginx 什么的。你要简单处理可以用 puma ,然后启动多个 worker ,这时就会有一个进程负责接受请求,然后分发到 worker 进程处理。
ch3rub1m
2015-08-28 02:52:34 +08:00
@kaichen 不是 已经弄清楚原因了 是线程安全的问题 thin 的解决办法是启动的时候加上--threaded 参数就可以

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/215311

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX