当前位置: 首页 > news >正文

在CentOS 7上将PostgreSQL数据库从默认路径迁移到自定义目录

在CentOS 7上将PostgreSQL数据库从默认路径迁移到自定义目录,需遵循以下步骤。假设原数据目录为“/var/lib/pgsql/12/data”,目标目录为“/new/path/pgdata”。

1、步骤概览

  1. 停止PostgreSQL服务
  2. 创建新目录并设置权限
  3. 复制数据文件(保留权限)
  4. 修改配置文件指向新目录
  5. 启动服务并验证

2、详细操作

2.1、创建目标目录并设置权限

sudo mkdir -p /new/path/pgdata
sudo chown -R postgres:postgres /new/path/pgdata  # 确保属主正确
sudo chmod 700 /new/path/pgdata  # 安全权限

2.2、初始化PostgreSQL数据库到自定义目录(如果尚未初始化)

“-D /data/pgsql”这条命令的含义是:指定PostgreSQL数据库的数据存储目录(该目录用于存放所有数据库的相关数据)

sudo -u postgres initdb -D /data/pgsql

2.3、停止PostgreSQL服务

sudo systemctl stop postgresql

2.4、复制数据文件(保留权限)

sudo rsync -av /var/lib/pgsql/data/ /new/path/pgdata/
  • -av:保留权限、属主等属性并显示进度
  • 源目录末尾的“/”:确保复制内容而非目录本身

2.5、修改PostgreSQL配置

2.5.1、编辑服务单元文件

sudo vi /usr/lib/systemd/system/postgresql.service

找到“Environment=PGDATA=…”行,修改为:

Environment=PGDATA=/new/path/pgdata

2.5.2、重载systemd配置

sudo systemctl daemon-reload

2.6、启动服务并验证

sudo systemctl start postgresql   # 启动PostgreSQL
sudo systemctl status postgresql  # 检查PostgreSQL状态

2.7、验证数据目录

sudo -u postgres psql -c "SHOW data_directory;"  # 应输出:“/new/path/pgdata”# 查看存储每个数据库的唯一数字标识符(OID)和系统表,包含所有数据库的元数据
sudo -u postgres psql -c "SELECT oid, datname FROM pg_database;"

3、故障排查

  • 权限问题:确保“/new/path/pgdata”属主为“postgres”且权限为“700”
  • SELinux 错误:检查日志“/var/log/audit/audit.log”,临时测试可“setenforce 0”(生产环境不推荐)
  • 服务启动失败:查看日志“journalctl -u postgresql -xe”
  • 路径错误:确认“postgresql.service”中的“PGDATA”路径正确

4、注意事项

  1. 备份优先:操作前务必备份数据(“pg_dumpall”或文件级备份)
  2. 磁盘空间:确保目标目录有足够空间
  3. 路径一致性:自定义路径需永久挂载(避免重启后丢失)
    完成迁移后,可删除原数据目录释放空间(确认服务运行正常后):
sudo rm -rf /var/lib/pgsql/12/data.old
http://www.dtcms.com/a/325517.html

相关文章:

  • Qwen-Image:通义团队新开源超强中文文生图模型(技术报告解读)
  • 【C++】哈希表的实现(unordered_map和unordered_set的底层)
  • 药用植物甾体皂苷生物合成途径研究进展--文献精读158
  • fwrite fread与流定位相关接口
  • CoreShop商城框架开启多租户(1)
  • 下一个排列 的 思路总结
  • OrbStack 入门教程:macOS 上的轻量级容器与虚拟机管理工具
  • macOS 搭建 Gitea 私有 Git 服务器教程
  • Mac配置服务器工具Royal TSX
  • SDI设计中,为何SD-SDI模式下,接收器用DRU实现,在3G-SDI模式下,使用transceiver实现
  • 2508C++,检测S模式
  • Docker 网络-单机版
  • 华为watch5心率变异性测量法的底层逻辑
  • 『“无恙心宽”,梗痛不常』——爱上古中医(12)(健康生活是coder抒写优质代码的前提条件——《黄帝内经》伴读学习纪要)
  • 【C语言】知识详细梳理!共计30万余字!
  • 《 慢 SQL 分析与 SQL 优化实战指南》
  • 用 Docker 安装并启动 Redis:从入门到实战
  • Flutter Provider 状态管理全面解析与实战应用:从入门到精通
  • 帝国理工学院团队研发:Missense3D-PTMdb—— 解析遗传变异与翻译后修饰的交互式工具
  • 基于开源模型构建医疗疾病大模型:从理论到实践
  • 【08】华汉伟业——华汉伟业 嵌入式 C笔试,校招,题目记录及解析
  • 聊天室全栈开发-保姆级教程(Node.js+Websocket+Redis+HTML+CSS)
  • Nginx负载均衡教程:应对网站流量暴增的实战指南 (2025)
  • C#项目上传git常见的忽略项目和推荐配置
  • MySQL,Redis重点面试题
  • SharePlay确保最佳游戏体验
  • [Shell编程] Shell 编程之免交互
  • 【CV 目标检测】①——目标检测概述
  • 每日五个pyecharts可视化图表-line:从入门到精通 (3)
  • 如何网络“钓鱼”,钓鱼鱼饵生成工具CobaltStrike使用