ruby-on-rails - 使用 docker 设置 puma、rails 和 nginx 的正确方法是什么?

标签 ruby-on-rails docker

我有一个使用 Puma 的 Rails 应用程序。我正在使用 nginx 进行负载平衡。我想 dockerize 并部署到 DigitalOcean (Docker) droplet。

在阅读了大量博客和示例(其中大部分是一年前的,并且在 Docker 世界中已经很长时间了)之后,我仍然对两件事感到困惑。假设我选择了一个带有 4 个 CPU 的 DigitalOcean 盒子。我应该如何设置 Rails 容器?我应该设置 4 个不同的容器,其中 Puma 配置有 1 个工作进程吗?或者我应该设置 1 个容器,其中 Puma 配置了 4 个工作进程?

我感到困惑的第二件事是:我应该在 Rails 容器中运行 nginx,还是应该在单独的容器中运行它们?

这两个问题允许我在下面绘制的 4 个排列。

选项1
option 1

选项 2
option 2

选项 3
option 3

选项 4
option 4

最佳答案

Docker 喜欢按容器的设计风格推送单个进程。当在单个容器中运行多个进程时,在 Docker 和底层进程之间有一个额外的服务管理器层,这会导致 Docker 失去对真实服务状态的可见性。这通常会使服务更难使用 Docker 及其相关工具进行管理。 Puma 管理 worker 不会像运行多个进程的通用服务管理器那么糟糕。

您可能还需要考虑应用程序的下一步,跨多个 Droplet/主机托管,以及如何轻松地移动到下一步。

选项 1 和 3 遵循 Docker 的首选设计。如果您使用 MRI,Puma 可以在集群模式下运行,因此这取决于您是要自己管理 Ruby 进程 (1) 还是让 Puma 进行工作人员管理 (3)。 nginx 和 Puma 在 worker 之间分配请求的方式会有所不同。 Puma 还可以安排零停机时间更新,这需要一些努力才能通过 Docker 工作。如果您正在使用 Rubinius 或 JRuby,您可能会倾向于选项 3 并让线程来完成工作。

选项 1 可能允许您使用 Docker 工具更轻松地跨不同大小的主机进行扩展。

选项 2 看起来像是添加了一个不必要的应用程序跃点,并且 Docker 不再维护应用层中的服务状态,因为您需要容器中的其他内容来启动 nginx 和 Puma。

由于本地套接字,选项 4 的性能可能比其他选项好一点,但 Docker 不再知道服务状态。

在任何情况下,尝试几个解决方案并使用 JMeter 之类的工具进行基准测试。您将很快了解在绩效和管理方面什么有效,什么无效。

关于ruby-on-rails - 使用 docker 设置 puma、rails 和 nginx 的正确方法是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40878753/

相关文章:

ruby-on-rails - 如何验证包含时区?

ruby-on-rails - 我可以让 Heroku Logs 仅返回概述错误的行吗?

javascript - 尝试建立 Angular 项目时的业力问题

ruby-on-rails - 如何在 Rails 中显式指定模型的表名映射?

来自 Rails Controller 的 Javascript 响应导致未捕获的语法错误 : Unexpected token :

docker - docker 是使应用程序跨平台的解决方案吗?

docker - 用于两个并行 docker 构建的 Bitbucket docker 图像缓存

postgresql:dockerfile 从入口点脚本创建用户和数据库

docker - 在 docker 中生成自签名证书

postgresql - Docker 和 Postgres - 服务器在使用 5432 以外的端口时意外关闭连接错误