Rails 6 Docker 与 PostgreSQL 连接错误
Posted
技术标签:
【中文标题】Rails 6 Docker 与 PostgreSQL 连接错误【英文标题】:Rails 6 Docker with PostgreSQL Connection Error 【发布时间】:2020-07-28 09:50:50 【问题描述】:我目前开始使用 Docker,并尝试使用 Docker- 和 Docker-compose 文件调整我的第一个应用程序。
它似乎工作正常,直到我达到我想要创建我的数据库的地步。我正确设置了环境变量并将它们反映在我的 database.yml 文件中
这是我的.env
:
POSTGRES_USER='deploy'
POSTGRES_PASSWORD='deploy'
POSTGRES_DB='nkbrf_db'
这是我的database.yml
:
default: &default
adapter: postgresql
encoding: unicode
pool: <%= ENV.fetch("RAILS_MAX_THREADS") 5 %>
username: <%= ENV['POSTGRES_USERNAME'] %>
password: <%= ENV['POSTGRES_PASSWORD'] %>
database: <%= ENV['POSTGRES_DB'] %>
host: db
development:
<<: *default
test:
<<: *default
production:
<<: *default
这是我的docker-compose.yml
:
version: '3'
services:
db:
image: postgres
volumes:
- 'postgres:/var/lib/postgresql/data'
env_file:
- '.env'
ports:
- "5432"
web:
build: .
command: bash -c "rm -f tmp/pids/server.pid && bundle exec rails s -p 3000 -b '0.0.0.0'"
volumes:
- .:/nkbrfqm
- bundler_gems:/bundle
ports:
- "3000:3000"
environment:
RAILS_ENV: development
depends_on:
- db
volumes:
postgres:
bundler_gems:
它正确设置了所有内容,但如果我尝试使用
创建我的数据库docker-compose 运行 web rake db:create
我收到以下错误:
PG::ConnectionBad: FATAL: 用户密码验证失败 “根”
这个用户“root”来自哪里?我的环境变量设置有问题吗?
【问题讨论】:
这里的提示是使用<%= ENV.fetch('POSTGRES_USERNAME') %>
,如果密钥不存在,则会引发错误。试试看,你会发现这个错字真的很快。
感谢您的提示。我读到它可能与未删除的旧卷有关,但我会记住这一点:)
从外观上看,您只是在引用 POSTGRES_USERNAME
,但这不是您在 .env 中定义的内容。我也怀疑您是否需要使用 .env,因为 Docker 为所有与配置相关的内容提供了大量 ENV 变量。
ENV['POSTGRES_USER']
实际上似乎是容器中的 postgres 图像设置的 ENV var。如果您想使用其他用户,请在 docker 配置中进行设置。 hub.docker.com/_/postgres
【参考方案1】:
您需要删除.env
文件中的单引号'
,然后您需要删除撰写文件中的所有容器(docker-compose rm
)。然后执行docker-compose up -d
例子
# .env
POSTGRES_USER=deploy
POSTGRES_PASSWORD=deploy
POSTGRES_DB=nkbrf_db
谢谢
【讨论】:
谢谢伙计,我修正了环境中的错字(我傻了)并删除了容器,它可以工作了!谢谢:)以上是关于Rails 6 Docker 与 PostgreSQL 连接错误的主要内容,如果未能解决你的问题,请参考以下文章
如何将 Rails 应用程序连接到主机上的 docker postgres
apache_conf 使用rails,docker为dev和test配置postgres数据库的步骤
Ruby on Rails 6 + Docker = Webpacker::Manifest::MissingEntryError?
如何将节点 docker 容器与 postgres docker 容器连接起来