欢迎来到徐庆高(Tea)的个人博客网站
磨难很爱我,一度将我连根拔起。从惊慌失措到心力交瘁,我孤身一人,但并不孤独无依。依赖那些依赖我的人,信任那些信任我的人,帮助那些给予我帮助的人。如果我愿意,可以分裂成无数面镜子,让他们看见我,就像看见自己。察言观色和模仿学习是我的领域。像每个深受创伤的人那样,最终,我学会了随遇而安。
当前位置: 日志文章 > 详细内容

postgres 数据库迁移的几种方法

2025年07月17日 MsSqlserver
环境说明本内容基于如下环境完成测试项配置说明备注操作系统centos7pg数据版本9.6.24操作系统用户root/postgres数据量用户(20)、角色(20)、数据库(2)、schema(42)

环境说明

本内容基于如下环境完成测试

配置说明备注
操作系统centos7
pg数据版本9.6.24
操作系统用户root/postgres
数据量用户(20)、角色(20)、数据库(2)、schema(42)、数据量(约160w行)数据文件约640m

备份

数据备份

#创建备份存放文件夹(确保postgres用户有权限)
cd /home
mkdir posrgres
chown -r postgres postgres/
#切换postgres用户
su - posrgres
#执行备份
pg_dumpall -u postgres -v -f u_postgres.backup

文件备份

数据文件默认位置:/var/lib/pgsql/9.6

#切换到数据存放位置
cd /var/lib/pgsql/9.6
#停止数据库服务
systemctl stop postgresql-9.6
#压缩数据文件
tar -cvf data.tar.gz data/
#得到的 data.tar.gz 即为压缩后的数据备份文件

迁移方案一:数据文件迁移

迁移数据文件

此过程需要先行停止pg数据库

完成执行文件备份

#确保过程种服务是停止的
systemctl stop postgresql-9.6
cd /home
#创建迁移目录 并修改权限
mkdir pgdata
##修改归属
chown -r postgres pgdata/
##修改权限(必须)
chmod 700 pgdata/
#切换至pg用户
 su - postgres
#复制数据文件到新位置
cp -rf data/* /home/pgdata/

修改服务种数据文件位置

#编辑服务配置文件
vim  /usr/lib/systemd/system/postgresql-9.6.service
#修改配置文件种的数据文件路径
修改:environment=pgdata=/var/lib/pgsql/9.6/data/
为:environment=pgdata=/home/pgdata/
#保存退出
#重启系统
reboot

迁移方案二:数据还原法

此方案基于pg数据库对备份还原的支持,使用此方法强烈建议在同版本的数据库上操作

上传数据备份文件

#创建备份文件存放位置
cd /home
mkdir postgres
#上传备份文件到上一步的存放位置(上传过程省略)
mv u_postgres.backup postgres/
#修改权限
chown -r postgres postgres/

使用psql还原

#切换用户
su - postgres
#切换数据备份目录
cd /home/postgres/
#执行恢复(忽略错误,"postgres"内置角色原因)
psql -u postgres  -f u_postgres.backup
#执行恢复(遇到错误停止,不建议)
#psql -u postgres --set on_error_stop=on -f u_postgres.backup

常见问题及解决办法

权限过大问题

  • 迁移目标目录权限过大

解决办法: 修改权限(必须)
chmod 700 pgdata/

目录错误或权限不足问题

  • 由于错误操作导致的目录无法识别为有效路径或者因错误修改权限导致的

解决办法: 修改数据文件所在文件夹为posrgres所有

chown -r postgres pgdata
chown 700 pgdata
#可切换postgres 测试读写权限

到此这篇关于postgres 数据库迁移的几种方法的文章就介绍到这了,更多相关postgres 数据库迁移内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!