小知识:docker部署访问postgres数据库的实现方法

部署与访问

宿主机创建postgres用户:

?
1
adduser postgres

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

?
1
docker pull postgres:12.1

创建所用的卷

?
1
docker volume create pgdata_test_env

启动(密码为123456):

?
1
2
3
4
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 用户):

?
1
2
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

进入卷内部:

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

重启pg

重启方式有两种:

?
1
2
3
4
5
6
7
方法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内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://lan6193.blog.csdn.net/article/details/122088367

声明: 猿站网有关资源均来自网络搜集与网友提供,任何涉及商业盈利目的的均不得使用,否则产生的一切后果将由您自己承担! 本平台资源仅供个人学习交流、测试使用 所有内容请在下载后24小时内删除,制止非法恶意传播,不对任何下载或转载者造成的危害负任何法律责任!也请大家支持、购置正版! 。本站一律禁止以任何方式发布或转载任何违法的相关信息访客发现请向站长举报,会员发帖仅代表会员个人观点,并不代表本站赞同其观点和对其真实性负责。本网站的资源部分来源于网络,如有侵权烦请发送邮件至:2697268773@qq.com进行处理。
建站知识

小知识:基于docker 部署canvas-lms的详细步骤

2023-3-9 9:56:18

建站知识

小知识:查看Docker容器的信息的方法实现

2023-3-9 10:10:49

0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索