欢迎来到站长天空!

其它服务器

当前位置: 主页 > 服务器 > 其它服务器

docker部署访问postgres数据库的实现方法

时间:2025-12-20 09:30:03|栏目:其它服务器|点击:

目录
  • 部署与访问
  • 启用日志
  • 如果需要修改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 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正常,这就需要排查网络层面的问题,如端口是否开放,如果你有这方面的未决问题可以提出来,我帮你解决哦

上一篇:云原生技术持久化存储PV与PVC

栏    目:其它服务器

下一篇:Deployment副本无状态服务创建及水平扩展

本文标题:docker部署访问postgres数据库的实现方法

本文地址:https://zz.feitang.co/server/32172.html

广告投放 | 联系我们 | 版权申明

申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:257218569 | 邮箱:257218569@qq.com

Copyright © 2018-2025 站长天空 版权所有 Powered by EyouCms冀ICP备14023439号