如何设置database.yml连接到Postgres Docker容器?

时间:2015-10-11 04:17:04

标签: ruby-on-rails postgresql docker docker-compose

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

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

我有一台docker create_list(&databases_list, sizeof(db *), NULL); 机器正在运行。我创建了docker-compose.yml:

default

我跑postgres: image: postgres ports: - "5432:5432" environment: - POSTGRES_USER=timbuktu - POSTGRES_PASSWORD=mysecretpassword 让Postgres跑。

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

docker-machine ip default

所以一切顺利,我可以在其容器中连接到Postgres。

但是,如果其他人撤回了回购,他们就无法使用我的database.yml连接到Postgres,因为他们的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 ... 获取其Docker默认机器的IP地址,并将env DOCKER_HOST行粘贴到他们的bash_rc中。例如,

docker-machine env default

然后我的database.yml主机可以包含行

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

但这感到丑陋和黑客。还有更好的方法吗?

2 个答案:

答案 0 :(得分:3)

您可以先设置正确的环境变量,然后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://}

答案 1 :(得分:3)

我找到了一种更简单的方法:

host: <%= `docker-machine ip default` %>