gpt4 book ai didi

ruby-on-rails - 如何设置 database.yml 以连接到 Postgres Docker 容器?

转载 作者:IT老高 更新时间:2023-10-28 21:22:54 24 4
gpt4 key购买 nike

我有一个 Rails 应用程序。在开发和测试环境中,我希望 Rails 应用程序连接到 dockerized Postgres。 Rails 应用程序本身不会在容器中 - 只是 Postgres。

我的 database.yml 应该是什么样的?

我有一台 docker default 机器正在运行。我创建了 docker-compose.yml:

postgres:
image: postgres
ports:
- "5432:5432"
environment:
- POSTGRES_USER=timbuktu
- POSTGRES_PASSWORD=mysecretpassword

我运行 docker-compose up 来运行 Postgres。

然后我运行 docker-machine ip default 来获取 Docker 虚拟机的 IP 地址,并相应地更新了 database.yml:

...
development:
adapter: postgresql
host: 192.168.99.100
port: 5432
database: timbuktu_development
username: timbuktu
password: mysecretpassword
encoding: unicode
pool: 5
...

所以一切都很好,我可以在其容器中连接到 Postgres。

但是,如果其他人提取 repo,他们将无法使用我的 database.yml 连接到 Postgres,因为他们的 Docker 默认机器的 IP 地址与我的不同。

那么我该如何更改我的 database.yml 来解决这个问题?

我的一个想法是让他们通过运行 docker-machine env default 并将 env DOCKER_HOST 行粘贴到他们的 bash_rc 中来获取他们的 Docker 默认机器的 IP 地址。例如,

export DOCKER_HOST="tcp://192.168.99.100:2376"

那么我的database.yml主机可以包含这行

host: <%= ENV['DOCKER_HOST'].match(/tcp:\/\/(.+):\d{3,}/)[1] %>

但这感觉丑陋和骇人听闻。有没有更好的办法?

最佳答案

你可以先设置一个正确的环境变量,然后access it from your database.yml :

host: <%= ENV['POSTGRES_IP'] %>

使用类似 bashrc(使用 bash substring removal ):

export DOCKER_HOST=$(docker-machine env default)
export POSTGRES_IP=${DOCKER_HOST#tcp://}

关于ruby-on-rails - 如何设置 database.yml 以连接到 Postgres Docker 容器?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33061464/

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