docker部署访问postgres数据库的实现方法
目录
- 部署与访问
- 启用日志
- 如果需要修改pg配置
- 重启pg
- 代码&外部连接时注意(温馨提示)
部署与访问 宿主机创建postgres用户:
adduser postgres
拉取镜像,此处以12.1版本为例:
docker pull postgres:12.1
创建所用的卷
docker volume create pgdata_test_env
启动(密码为123456):
docker run --user=0-p 45565:5432 -d --name pg_test --restart always \-v pgdata_test_env:/var/lib/postgresql/data \-e POSTGRES_PASSWORD=123456\postgres:12.1
访问pg,进入容器(注意需要用postgres 用户):
docker exec -ti -u postgres pg_test bashpsql
启用日志
- show log_destination; 查看日志记录类型,未开启时显示off
- show log_directory; 查看日志路径
如果需要修改pg配置 【docker部署访问postgres数据库的实现方法】首先查看docker root地址:
执行docker info,找Docker Root进入卷内部:
Docker Root Dir: /opt/docker
cd /opt/docker/volumes/pgdata_test_env/_datapostgresql.conf就是配置文件,修改完后重启pg即可
重启pg 重启方式有两种:
方法1:docker restart pg_test 方法2:进入容器,docker exec -ti -u postgres pg_test bashcd /var/lib/postgresql/datapg_ctl restart即可重启成功
代码&外部连接时注意(温馨提示) 访问时两种形式皆可:
1,使用容器Ip和映射的容器内端口
2,使用宿主机ip和映射的宿主机端口
如果使用第二种时如果出现以下两种类似的连不上pg的报错:
read: connection reset by peer或
i/o timeout
但进入容器使用pg正常,这就需要排查网络层面的问题,如端口是否开放,如果你有这方面的未决问题可以提出来,我帮你解决哦
到此这篇关于docker部署访问postgres数据库的实现方法的文章就介绍到这了,更多相关docker部署访问postgres内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
推荐阅读
- docker内的容器如何与宿主机共享IP的方法
- docker开启mysql的binlog日志解决数据卷问题
- docker|centos8 安装docker报错Error: Unable to find a match: docker
- #|docker-jenkins使用npm报错npm: command not found
- Nginx图片服务器配置之后图片访问404的问题解决
- 博三|24 - srsRAN安装部署(已支持5G NSA, 原srsLTE)
- 容器|通过Docker 创建mysql容器挂载到主机,删除mysql容器后,数据恢复教程
- docker安装教程
- docker|Docker命令
- linux|Linux 安装项目软件 MySql Redis Nginx RabbitMQ Docker 轻松 详细