PostGreSQL docker 拉取以及部署流程


1. 拉取镜像(国内加速)

bash 复制代码
# 2025-10 已推送的 18 最新版 
docker pull docker.1ms.run/postgres:18

2. 创建宿主机目录(父目录挂载方案)

bash 复制代码
mkdir -p $HOME/pg18
# 赋予容器内 999 用户写权限(镜像默认 uid)
sudo chown -R 999:999 $HOME/pg18

3. 启动容器(关键:挂载父目录 /var/lib/postgresql

bash 复制代码
docker run -d --name postgres \
  -e POSTGRES_PASSWORD=Root@123 \
  -v $HOME/pg18:/var/lib/postgresql \
  -p 5432:5432 \
  --restart unless-stopped \
  docker.1ms.run/postgres:18
参数 说明
-v $HOME/pg18:/var/lib/postgresql 只挂父目录 ,镜像会在其下自动创建 18/main 版本子目录,兼容 18+ 的 pg_ctlcluster 结构
不再挂 /var/lib/postgresql/data 避免与新版目录冲突,防止出现「unused mount」错误

4. 验证部署

bash 复制代码
docker ps | grep postgres
# 状态 Up 即可

docker exec -it postgres psql -U postgres
# 出现 postgres=# 表示正常连接

5. 后续升级小版本(18.x → 18.y)

bash 复制代码
docker pull docker.1ms.run/postgres:18
docker restart postgres

数据目录结构不变,自动兼容 。


6. 一键停/删(可选)

bash 复制代码
docker stop postgres && docker rm postgres

宿主机 $HOME/pg18 仍会保留,重新运行第 3 步即可复用数据。

按照以上 5 步,即可在本地完成 PostgreSQL 18 的拉取与部署,并规避因目录结构变更导致的重启循环。

相关推荐
武子康4 小时前
大数据-239 离线数仓 - 广告业务实战:Flume 导入日志到 HDFS,并完成 Hive ODS/DWD 分层加载
大数据·后端·apache hive
摸鱼的春哥5 小时前
Agent教程15:认识LangChain(中),状态机思维
前端·javascript·后端
风象南11 小时前
我把大脑开源给了AI
人工智能·后端
橙序员小站16 小时前
Agent Skill 是什么?一文讲透 Agent Skill 的设计与实现
前端·后端
怒放吧德德16 小时前
Netty 4.2 入门指南:从概念到第一个程序
java·后端·netty
雨中飘荡的记忆18 小时前
大流量下库存扣减的数据库瓶颈:Redis分片缓存解决方案
java·redis·后端
开心就好202519 小时前
UniApp开发应用多平台上架全流程:H5小程序iOS和Android
后端·ios
悟空码字19 小时前
告别“屎山代码”:AI 代码整洁器让老项目重获新生
后端·aigc·ai编程
小码哥_常19 小时前
大厂不宠@Transactional,背后藏着啥秘密?
后端
奋斗小强19 小时前
内存危机突围战:从原理辨析到线上实战,彻底搞懂 OOM 与内存泄漏
后端