gpt4 book ai didi

ruby-on-rails - 配置 docker 卷以跨主机和容器共享数据

转载 作者:太空宇宙 更新时间:2023-11-03 14:30:06 25 4
gpt4 key购买 nike

我一直在尝试配置 docker volumes 以在我的主机之间共享文件并使我的容器能够使用这些文件。让我解释一下。

我有一个 Rails docker 应用程序,将 puma 作为 Web 服务器,我希望能够让 puma 查看和使用 ssl .key 和 .crt 文件,所以对于这个项目,我也在“生产”中使用 docker-compose模式”,但我不知道如何使它工作。

我的设置是这样的:

  • 用于生产的 Ubuntu 18.04 服务器主机在 /home/ubuntu/my_app_keys 中有 ssl 文件,容器也在我的主机中。

/home/ubuntu/docker-compose.yml

version: '3'

services:
postgres:
image: postgres:10.5
environment:
POSTGRES_DB: my_app_production
env_file:
-~/production.env

redis:
image: redis:4.0.11

web:
image: my_app:latest
command: bundle exec rails server -p 3000 -b 'ssl://127.0.0.1:3000?key=/home/ubuntu/my_app_keys/server.key&cert=/home/ubuntu/my_app_keys/server.crt' -e production
ports:
- '3000:3000'
volumes:
- /home/ubuntu/my_app_keys
depends_on:
- postgres
- redis
env_file:
- ~/production.env
restart: always

sidekiq:
image: my_app_sidekiq:latest
command: bundle exec sidekiq -C config/sidekiq.yml
depends_on:
- postgres
- redis
env_file:
- ~/production.env
restart: always

因此,如您所见:命令:bundle exec rails server -p 3000 -b 'ssl://127.0.0.1:3000?key=/home/ubuntu/my_app_keys/server.key&cert=/home/ubuntu/my_app_keys/server.crt' 正在/home/ubuntu/my_app_keys 中寻找 ssl 文件,当我执行 docker-compose up puma 找不到 ssl 文件并退出时:

/usr/local/bundle/gems/puma-3.9.1/lib/puma/minissl.rb:180:in `key=': No such key file '/home/ubuntu/my_app_keys/server.key' (ArgumentError)

我认为是因为 key=/home/ubuntu/my_app_keys/server.key&cert=/home/ubuntu/my_app_keys/server.crt 指向容器上下文,但我有证书和 key 在我的主机上下文中

所以,我在 docker compose volume 中包含了为了绑定(bind)挂载文件:

volumes:
- /home/ubuntu/my_app_keys

但没有运气,同样的错误。

在容器上下文中,我的应用程序位于 /var/www/my_app 目录中,因此我尝试指定一个绝对路径(出于某种原因,我认为这是因为 ssl 文件不在我的应用所在的同一目录无法共享),所以我添加为 compose-file docs说:

volumes:
- /home/ubuntu/my_app_keys:/var/www/my_app

并更改撰写文件:

command: bundle exec rails server -p 3000 -b 'ssl://127.0.0.1:3000?key=server.key&cert=server.crt' -e

当我执行 compose up 我的 web 服务退出时出现错误:

web | Could not locate Gemfile or .bundle/ directory

Web 服务运行的唯一方式是(但不存在 ssl 文件):

volumes:
- /home/ubuntu/my_app_keys

所以,我现在不知道该怎么办。有帮助吗?

最佳答案

当您的 Docker Compose YAML 文件说:

volumes:
- /home/ubuntu/my_app_keys

这意味着,“使容器空间中的 /home/ubuntu/my_app_keys 在容器重新启动后持续存在;除非 Dockerfile 做了一些特殊的事情,否则它将从空开始;它没有连接到任何特定主机内容”。

当你说:

volumes:
- /home/ubuntu/my_app_keys:/var/www/my_app

意思是,“将容器空间中/var/www/my_app的内容完全替换为主机上/home/ubuntu/my_app_keys的内容”。 (主机和容器空间中的路径名不需要相同。)

作为奖励问题,当你说:

rails server -b 'ssl://127.0.0.1:3000?...'

这意味着,“只监听从这个 Docker 容器内发起的端口 3000 上的入站连接;根本不接受来自容器外部的任何连接,无论是来自同一物理主机、其他容器还是其他地方。”

关于ruby-on-rails - 配置 docker 卷以跨主机和容器共享数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53438521/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com