本文主要介绍了docker部署访问postgres数据库的实现方法,文中根据实例编码详细介绍的十分详尽,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
部署与访问
宿主机创建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 bash
psql
启用日志
- show log_destination; 查看日志记录类型,未开启时显示off
- show log_directory; 查看日志路径
启用日志:alter system set logging_collector='on'; 重启pg容器。
如果需要修改pg配置
首先查看docker root地址:
执行docker info,找Docker Root
Docker Root Dir: /opt/docker
进入卷内部:
cd /opt/docker/volumes/pgdata_test_env/_data
postgresql.conf就是配置文件,修改完后重启pg即可
重启pg
重启方式有两种:
方法1:docker restart pg_test
方法2:进入容器,
docker exec -ti -u postgres pg_test bash
cd /var/lib/postgresql/data
pg_ctl restart
即可重启成功
代码&外部连接时注意(温馨提示)
访问时两种形式皆可:
1,使用容器Ip和映射的容器内端口
2,使用宿主机ip和映射的宿主机端口
如果使用第二种时如果出现以下两种类似的连不上pg的报错:
read: connection reset by peer 或
i/o timeout
但进入容器使用pg正常,这就需要排查网络层面的问题,如端口是否开放,如果你有这方面的未决问题可以提出来,我帮你解决哦
到此这篇关于docker部署访问postgres数据库的实现方法的文章就介绍到这了,更多相关docker部署访问postgres内容请搜索编程学习网以前的文章希望大家以后多多支持编程学习网!
本文标题为:docker部署访问postgres数据库的实现方法


基础教程推荐
- http请求报错:Redirect Error的原因和解决办法 2023-12-04
- CentOS7中使用iptables 2023-09-24
- http请求报错:SSL Certificate Expired Error的原因和解决办法 2023-12-04
- 详解Nginx 虚拟主机配置的三种方式(基于IP) 2024-03-14
- Windows Server 2022 安装体验与功能对比 2022-11-26
- Nginx搭建负载均衡集群的实现 2024-03-16
- 彻底掌握IIS6.0功能及应用详解图文教程一第1/2页 2022-09-01
- nginx关闭/重启/启动的操作方法 2024-03-18
- apache web页面的rsync同步 2023-09-11
- 一台虚拟机基于docker搭建大数据HDP集群的思路详解 2022-12-28