资讯专栏INFORMATION COLUMN

docker 踩坑笔记之 psql: could not connect to server

ddongjian0000 / 2852人阅读

摘要:最近在用跑,也遇到了一些坑,这里记录一下。首先项目然后就开始报错了这里报错是说找不到文件,但我本地运行是没问题的。同样的,还需要把用户名修改成和镜像预定的一致。打开最新生成的文件。本人菜鸟一枚,如有错误之处,敬请指正,谢谢

最近在用docker跑rails,也遇到了一些坑,这里记录一下。

首先build项目:

docker-compose build

然后就开始报错了:

psql: could not connect to server: No such file or directory
Is the server running locally and accepting
connections on Unix domain socket "/var/run/postgresql/.s.PGSQL.5432"?

这里报错是说找不到 /var/run/postgresql/.s.PGSQL.5432 文件,但我本地运行是没问题的。于是去找docker从入门到实践这本书的docker rails 例子, 地址在这里:https://yeasy.gitbooks.io/doc...,发现我的database.yml文件不对。我的是这样的:

default: &default
  adapter: postgresql
  encoding: unicode`请输入代码`
  # For details on connection pooling, see Rails configuration guide
  # http://guides.rubyonrails.org/configuring.html#database-pooling
  pool: <%= ENV.fetch("RAILS_MAX_THREADS") { 5 } %>

Rails 默认读取的数据库目标是 localhost ,我们需要手动指定容器的 db 。同样的,还需要把用户名修改成和 postgres 镜像预定的一致。 打开最新生成的 database.yml 文件。用以下内容替换:

default: &default
  adapter: postgresql
  encoding: unicode
  # For details on connection pooling, see Rails configuration guide
  # http://guides.rubyonrails.org/configuring.html#database-pooling
  pool: <%= ENV.fetch("RAILS_MAX_THREADS") { 5 } %>
  username: postgres
  host: db

这样再运行docker-compose build,成功build! 然后再跑起来docker-compose up,悲剧的又报错了:

ActiveRecord::NoDatabaseError (FATAL: database "heroku_app_development" does not exist

提示没有创建heroku_app_development数据库,OK,那就创建一个:

sudo docker ps #列出所有容器
sudo docker exec -it [container ID] /bin/bash #进入postgres
sudo su - postgres #切换到postgres用户,因为这个用户有createdb权限
ceratedb heroku_app_development #heroku_app_development 创建完成!

再运行docker-compose up,又报错:

Migrations are pending. To resolve this issue, run:

    bin/rails db:migrate RAILS_ENV=development

railser应该很熟悉,数据库迁移,进入web容器:
sudo docker exec -it [container ID] /bin/bash #进入web容器
rails db:migrate #迁移成功!

至此,程序可以在docker上跑起来了。本人菜鸟一枚,如有错误之处,敬请指正,谢谢!

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/27155.html

相关文章

  • Linux PostgreSQL 和 PostGIS 安装和使用

    摘要:最近研究基于的开源框架,其中构建需要使用插件。为例,安装以下包即可系列则请安装初次安装后,默认生成一个名为的数据库和一个名为的数据库用户。注意,不要往这个数据库中添加数据,这个数据库之所以称为模板,就说明它是用来派生用的。 最近研究基于 GeoServer 的开源 GIS 框架,其中构建 GIS database 需要使用 PostgreSQL + PostGIS 插件。花了些时间学习...

    shixinzhang 评论0 收藏0
  • Linux PostgreSQL 和 PostGIS 安装和使用

    摘要:最近研究基于的开源框架,其中构建需要使用插件。为例,安装以下包即可系列则请安装初次安装后,默认生成一个名为的数据库和一个名为的数据库用户。注意,不要往这个数据库中添加数据,这个数据库之所以称为模板,就说明它是用来派生用的。 最近研究基于 GeoServer 的开源 GIS 框架,其中构建 GIS database 需要使用 PostgreSQL + PostGIS 插件。花了些时间学习...

    dreamans 评论0 收藏0
  • Mac 死机后导致 PostgreSQL 无法连接

    摘要:问题现象最近两个月碰到三次,莫名的无法连接的情况,具体错误信息如下前两次,自己瞎鼓捣,后面就好了,然后也没在意。然后今天早上死机重启后,这个问题又出现了,然后各种重装重启系统依然无解。最后,终于启动了。 问题现象 最近两个月碰到三次,莫名的 PG (PostgreSQL) 无法连接的情况,具体错误信息如下: psql: could not connect to server: No s...

    niuxiaowei111 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<