- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
我有一个 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/
我正在开发一个 voip 调用应用程序。我需要做的是在接到来电时将 Activity 带到前台。我在应用程序中使用 Twilio,并在收到推送消息时开始调用。 问题是我试图在接到任何电话时显示 Act
我是一名优秀的程序员,十分优秀!