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”来自哪里?我的环境变量设置有问题吗?

【问题讨论】:

这里的提示是使用&lt;%= ENV.fetch('POSTGRES_USERNAME') %&gt;,如果密钥不存在,则会引发错误。试试看,你会发现这个错字真的很快。 感谢您的提示。我读到它可能与未删除的旧卷有关,但我会记住这一点:) 从外观上看,您只是在引用 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 容器连接起来

docker-compose 与 postgres 的 Django 连接

Rails不会替换database.yml中ENV的值