摘要:最近在用跑,也遇到了一些坑,这里记录一下。首先项目然后就开始报错了这里报错是说找不到文件,但我本地运行是没问题的。同样的,还需要把用户名修改成和镜像预定的一致。打开最新生成的文件。本人菜鸟一枚,如有错误之处,敬请指正,谢谢
最近在用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
摘要:最近研究基于的开源框架,其中构建需要使用插件。为例,安装以下包即可系列则请安装初次安装后,默认生成一个名为的数据库和一个名为的数据库用户。注意,不要往这个数据库中添加数据,这个数据库之所以称为模板,就说明它是用来派生用的。 最近研究基于 GeoServer 的开源 GIS 框架,其中构建 GIS database 需要使用 PostgreSQL + PostGIS 插件。花了些时间学习...
摘要:最近研究基于的开源框架,其中构建需要使用插件。为例,安装以下包即可系列则请安装初次安装后,默认生成一个名为的数据库和一个名为的数据库用户。注意,不要往这个数据库中添加数据,这个数据库之所以称为模板,就说明它是用来派生用的。 最近研究基于 GeoServer 的开源 GIS 框架,其中构建 GIS database 需要使用 PostgreSQL + PostGIS 插件。花了些时间学习...
摘要:问题现象最近两个月碰到三次,莫名的无法连接的情况,具体错误信息如下前两次,自己瞎鼓捣,后面就好了,然后也没在意。然后今天早上死机重启后,这个问题又出现了,然后各种重装重启系统依然无解。最后,终于启动了。 问题现象 最近两个月碰到三次,莫名的 PG (PostgreSQL) 无法连接的情况,具体错误信息如下: psql: could not connect to server: No s...
阅读 2892·2021-11-25 09:43
阅读 3593·2021-08-31 09:41
阅读 1197·2019-08-30 15:56
阅读 2072·2019-08-30 15:55
阅读 2895·2019-08-30 13:48
阅读 2781·2019-08-29 15:15
阅读 916·2019-08-29 15:14
阅读 2615·2019-08-28 18:26