V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
ch3rub1m
V2EX  ›  问与答

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

  •  
  •   ch3rub1m · 2015-08-23 12:20:52 +08:00 · 2801 次点击
    这是一个创建于 3161 天前的主题,其中的信息可能已经有所发展或是发生改变。

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

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

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

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

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

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

    像 thin 要处理多个请求的话,需要前面再架个 Nginx 什么的。你要简单处理可以用 puma ,然后启动多个 worker ,这时就会有一个进程负责接受请求,然后分发到 worker 进程处理。
    ch3rub1m
        8
    ch3rub1m  
    OP
       2015-08-28 02:52:34 +08:00
    @kaichen 不是 已经弄清楚原因了 是线程安全的问题 thin 的解决办法是启动的时候加上--threaded 参数就可以
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   1407 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 24ms · UTC 23:52 · PVG 07:52 · LAX 16:52 · JFK 19:52
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.