11

我是 Rails 和 Puma 的新手,所以这个问题对于简单的解决方案可能太愚蠢了,如果你认为我做错了什么,请指导我。

我正在尝试与工人一起为我的导轨启动 Puma 服务器。如果我将工人设置为 0

puma -w0

服务器完美启动,但如果我将 worker 设置为 1 或更多,则会出现以下错误:

E:\RoR_tryouts\ws_13.11.13\todo>puma -w3
[2120] *** SIGUSR2 not implemented, signal based restart unavailable!
[2120] *** SIGUSR1 not implemented, signal based restart unavailable!
[2120] Puma starting in cluster mode...
[2120] * Version 2.7.1, codename: Earl of Sandwich Partition
[2120] * Min threads: 0, max threads: 16
[2120] * Environment: development
[2120] * Process workers: 3
[2120] * Phased restart available
[2120] * Listening on tcp://0.0.0.0:9292

C:/Ruby/Ruby193/lib/ruby/gems/1.9.1/gems/puma-2.7.1/lib/puma/cluster.rb:229:in `trap': unsupported signal SIGCHLD (ArgumentError)
        from C:/Ruby/Ruby193/lib/ruby/gems/1.9.1/gems/puma-2.7.1/lib/puma/cluster.rb:229:in `run'
        from C:/Ruby/Ruby193/lib/ruby/gems/1.9.1/gems/puma-2.7.1/lib/puma/cli.rb:442:in `run'
        from C:/Ruby/Ruby193/lib/ruby/gems/1.9.1/gems/puma-2.7.1/bin/puma:10:in `<top (required)>'
        from C:/Ruby/Ruby193/bin/puma:23:in `load'
        from C:/Ruby/Ruby193/bin/puma:23:in `<main>'

规格:

  • Windows 7的
  • Ruby 1.9.3p448 (2013-06-27) [i386-mingw32] MRI Rail 4.0.0 Puma
  • 版本 2.7.1,代号:Earl of Sandwich Partition
4

2 回答 2

20

是的,我遇到了同样的问题,并在https://devcenter.heroku.com/articles/deploying-rails-applications-with-the-puma-web-server的“Workers”主题下找到了解决方案。如果您使用的是 Windows 或 JRuby,请在 config/puma.rb 文件中省略“workers Integer(ENV['WEB_CONCURRENCY'] || 2)”行。它为我解决了。阅读上面的链接以获取更多信息。

于 2016-05-06T16:06:41.073 回答
8

Puma README 中引用:

由于各种平台没有实现某些东西,因此在不同平台上使用 Puma 时会出现以下差异:

  • JRuby,Windows:服务器套接字在重新启动时不是无缝的,它们必须关闭并重新打开。这些平台无法将描述符传递到暴露给 ruby​​ 的新进程中
  • JRuby,Windows:由于缺少 fork(2),不支持集群模式
  • Windows:由于缺少 fork(2),不支持守护程序模式

正如它明确指出的那样,Windows 不支持集群模式(即运行具有多个工作人员的单个 puma 实例)和守护进程模式(启动后从 shell 中分离)。

您应该使用不同的操作系统(例如 Linux)或在单工模式下使用 Puma。即使在 Windows 上,您也可以在不同的端口上手动启动多个 Puma 实例并在它们之间进行负载平衡。你只需要一个前端负载均衡器,它不像 Puma 内置的原生集群模式那样无缝。

于 2013-12-27T14:51:10.213 回答