[英]How to setup database.yml to connect to Postgres Docker container?
我有一個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。
但是,如果其他人拉回購,他們將無法使用我的database.yml連接到Postgres,因為他們的Docker默認機器的IP地址將與我的不同。
那么如何更改我的database.yml來解決這個問題呢?
我的一個想法是讓他們通過運行docker-machine env default
來獲取他們的Docker默認機器的IP地址,並將env DOCKER_HOST行粘貼到他們的bash_rc中。 例如,
export DOCKER_HOST="tcp://192.168.99.100:2376"
然后我的database.yml主機可以包含該行
host: <%= ENV['DOCKER_HOST'].match(/tcp:\/\/(.+):\d{3,}/)[1] %>
但這感到丑陋和黑客。 有沒有更好的辦法?
您可以先設置正確的環境變量,然后從database.yml
訪問它 :
host: <%= ENV['POSTGRES_IP'] %>
使用bashrc(使用bash子字符串刪除 ):
export DOCKER_HOST=$(docker-machine env default)
export POSTGRES_IP=${DOCKER_HOST#tcp://}
我發現了一種更簡單的方法:
host: <%= `docker-machine ip default` %>
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.