环境说明
本内容基于如下环境完成测试
项 | 配置说明 | 备注 |
---|---|---|
操作系统 | 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 数据库迁移内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!