当前位置:   article > 正文

docker部署访问postgres数据库(一次到位)_connection reset by peer postgres docker

connection reset by peer postgres docker

目录

部署与访问

启用日志

如果需要修改pg配置

重启pg

代码&外部连接时注意(温馨提示)



部署与访问


宿主机创建postgres用户:

adduser postgres

拉取镜像,此处以12.1版本为例:

docker pull postgres:12.1

创建所用的卷

docker volume create pgdata_test_env

启动(密码为123456):

  1. docker run --user=0  -p 45565:5432 -d --name pg_test --restart always \
  2. -v pgdata_test_env:/var/lib/postgresql/data \
  3. -e POSTGRES_PASSWORD=123456  \
  4. postgres:12.1

访问pg,进入容器(注意需要用postgres 用户):

  1. docker exec -ti -u postgres pg_test bash
  2. 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

进入卷内部:

  1. cd /opt/docker/volumes/pgdata_test_env/_data
  2. postgresql.conf就是配置文件,修改完后重启pg即可

重启pg


重启方式有两种:

  1. 方法1:docker restart pg_test
  2. 方法2:进入容器,
  3. docker exec -ti -u postgres pg_test bash
  4. cd /var/lib/postgresql/data
  5. pg_ctl restart
  6. 即可重启成功


代码&外部连接时注意(温馨提示)


访问时两种形式皆可:
1,使用容器Ip和映射的容器内端口
2,使用宿主机ip和映射的宿主机端口
如果使用第二种时如果出现以下两种类似的连不上pg的报错:
read: connection reset by peer     或
i/o timeout

但进入容器使用pg正常,这就需要排查网络层面的问题,如端口是否开放,如果你有这方面的未决问题可以提出来,我帮你解决哦

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/AllinToyou/article/detail/561516
推荐阅读
相关标签
  

闽ICP备14008679号