在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.pswp.cn/pingmian/92756.shtml
繁体地址,请注明出处:http://hk.pswp.cn/pingmian/92756.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C语言基础06——结构体(struct)

一、结构体的概念结构体(struct)是 C 语言中一种自定义数据类型,它允许你将不同类型的数据项组合在一起,形成一个新的复合数据类型。想象一下:如果要表示一个 "学生",需要包含姓名(字…

小白入门指南:Edge SCDN 轻松上手

在互联网飞速发展的当下,网站性能与安全至关重要。对于小白而言,Edge SCDN 可能是个陌生概念,但它却能极大助力网站运营。本文将用简单易懂的语言,带大家了解 Edge SCDN,探讨其运用方法。​一、Edge SCDN 是什么&#…

探秘酵母单杂交技术:解锁基因调控的密码

在生命科学研究领域,基因的表达调控机制一直是科学家们关注的焦点。为了深入探究这一复杂过程,众多先进技术应运而生,酵母单杂交技术便是其中极具价值的一项,它为研究 DNA 与蛋白质之间的相互作用提供了独特视角与有效手段。酵母单…

大模型备案要点一次过【附材料清单详解】

最近,广东省公布了最新一批的大模型备案(登记)名单,很多准备要做大模型备案的企业都在纷纷咨询:“大模型备案的周期是多久?”“做大模型备案有什么要求?”“做大模型备案一共需要准备多少材料&a…

启保停-----------单相照明灯的接法

一.单相照明灯-K21使用的器材,单相电能表,空开,插座,开关,灯泡二.启 保 停1.需要用到的器材1.空开2.三相电机3.接触器4.熔断器5.按钮2.电路的作用按按钮 运转 在按按钮 停止运转3.电动4.加上辅助触点 控制电路5.在加上按钮 停止电路

TF-IDF:信息检索与文本挖掘的统计权重基石

本文由「大千AI助手」原创发布,专注用真话讲AI,回归技术本质。拒绝神话或妖魔化。搜索「大千AI助手」关注我,一起撕掉过度包装,学习真实的AI技术! 1. 背景与定义 TF-IDF 是一种统计加权方法,用于衡量词语在…

[论文阅读] (41)JISA24 物联网环境下基于少样本学习的攻击流量分类

《娜璋带你读论文》系列主要是督促自己阅读优秀论文及听取学术讲座,并分享给大家,希望您喜欢。由于作者的英文水平和学术能力不高,需要不断提升,所以还请大家批评指正,非常欢迎大家给我留言评论,学术路上期…

react中父子数据流动和事件互相调用(和vue做比较)

前言:react中父子数据流动和事件互相调用,父组件给子组件数据,父组件调用子组件的事件,同理,子也可以调用父的数据和传值。react是单向数据流,具体使用跟vue是不同的。1、父组件的数据传给子组件&#xff0…

杰理手表-增加提示音-提示音音量调整--使用提示音

本章节非常详细的介绍这个提示音的增加-调整-使用,其余耳机包之类的也是差不多的!! 目录 1.添加自己需要用的提示音 2.根据添加的提示音-代码中配置 1.在tone_player.h中枚举里添加本次提示音的名称 2.把定义好的提示音放到tone_player.…

数据库的基本操作(视图,存储,触发器)

1、视图(1)什么是视图视图是虚拟表,是基于查询结果的可视化表,视图的作用有:①简化复杂查询 ②限制数据访问 ③提供数据独立性 ④汇总数据(2)怎么创建视图创建视图 CREATE OR REPLACE VIEW 视图…

Pytest项目_day13(usefixture方法、params、ids)

usefixture 我们还可以使用mark.usefixtures来调用fixture 这样相比在传入参数处调用fixture,会更加直接 但是如果我们在一个测试用例中使用了多个usefixtures,那么测试用例会先调用离他最近的那个fixtureparams fixture中还可以带参数 当我们用request.…

Rust 异步生态实战:Tokio 调度、Pin/Unpin 与零拷贝 I/O

🌟 Hello,我是蒋星熠Jaxonic! 🌈 在浩瀚无垠的技术宇宙中,我是一名执着的星际旅人,用代码绘制探索的轨迹。 🚀 每一个算法都是我点燃的推进器,每一行代码都是我航行的星图。 &#x…

通用 maven 私服 settings.xml 多源配置文件(多个仓库优先级配置)

<?xml version"1.0" encoding"UTF-8"?> <settings xmlns"http://maven.apache.org/SETTINGS/1.0.0"xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation"http://maven.apache.org/SETTINGS/1.0.…

AT F-Intervals 题解

简化题意&#xff1a; 有 nnn 个区间&#xff0c;保证所有区间同时覆盖一个点&#xff0c;每次将区间平移一个单位&#xff0c;问使得区间两两不交的最小操作数&#xff08;端点处可重叠&#xff09;。n≤5000。l,r≤231−1n\leq 5000。l,r\leq 2^{31}-1n≤5000。l,r≤231−1。…

《飞算Java AI:从安装到需求转实战项目详细教学》

前引&#xff1a;在当今快速发展的技术环境中&#xff0c;人工智能&#xff08;AI&#xff09;与编程语言的结合为开发者提供了前所未有的便利。飞算Java AI作为一款智能化编程工具&#xff0c;能够显著提升Java开发效率&#xff0c;减少重复性工作&#xff0c;并帮助开发者更专…

6深度学习Pytorch-神经网络--过拟合欠拟合问题解决(Dropout、正则化、早停法、数据增强)、批量标准化

过拟合、欠拟合 在机器学习和深度学习中&#xff0c;过拟合&#xff08;Overfitting&#xff09;和欠拟合&#xff08;Underfitting&#xff09;是模型训练过程中常见的两种问题&#xff0c;直接影响模型的泛化能力&#xff08;即对未见过的数据的预测能力&#xff09;。 1. 欠…

新手向:Python编写简易翻译工具

Python 编写简易翻译工具&#xff1a;从零开始入门指南对于刚接触编程的新手来说&#xff0c;编写一个实用的工具是快速入门的好方法。本文将详细介绍如何用 Python 编写一个简易的翻译工具&#xff0c;帮助理解基础编程概念和实际应用。无需任何编程基础&#xff0c;只需按照步…

爬虫与数据分析结和

任务描述 爬取目标&#xff1a;高三网中国大学排名一览表&#xff0c;网址为 2021中国的大学排名一览表_高三网。爬取内容&#xff1a;学校名称、总分、全国排名、星级排名、办学层级。数据存储&#xff1a;爬取后的数据保存在 CSV 文件中。 代码实现&#xff08;爬取&#xff…

linux下安装php

1.php官网下载所需要的php版本 下载php 2.将下载好的压缩包上传至linux服务器&#xff0c;解压并配置 tar -xzvf php-8.4.11.tar.gz cd php-8.4.11 ./configure --prefix/home/admintest/php/php-8.4.11 # 配置安装路径和选项 make sudo make install3.使用make命令编译完成…

nurbs曲线的matlab

基于MATLAB的NURBS曲线生成与可视化程序 %% NURBS曲线生成与可视化 clc; clear; close all;%% 基本参数设置 degree 3; % 曲线阶数 (degree k-1, k为控制点数) numCtrlPts 6; % 控制点数量 weights ones(1, numCtrlPts); % 权重向量&#xff08;可调整&#…