一、 主要升级方法
PostgreSQL自身有三种大版本升级的方法:
三种方法升级建议架构如下:
另外根据pg大会介绍,还有一种升级工具叫做PgQ
其特点如下
二、 pg_upgrade就地升级测试
1. 测试环境
测试postgresql 9.6 升级至 postgresql 10.4
源库:9.6环境
- prefix目录: /data/PRD/postgres/base/9.6.2
- pgdata目录:/data/PRD/postgres/9.6.2/pg5432/data
- extension:pg_stat_statements、plpgsql
目标库:10.4环境
- prefix /data/PRD/postgres/base/10.4
- pgdata /data/PRD/postgres/10/pg5432/data
2. 升级步骤
- 安装postgresql10软件
详情参考安装文档,需要在升级前完成,缩短升级时间
- 关闭源与目标库
# 停业务关闭源库
/data/PRD/postgres/base/9.6.2/bin/pg_ctl -D /data/PRD/postgres/9.6.2/pg5432/data stop
# 关闭目标库
/data/PRD/postgres/base/10.4/bin/pg_ctl -D /data/PRD/postgres/10/pg5432/data stop
- 升级
/data/PRD/postgres/base/10.4/bin/pg_upgrade --old-datadir "/data/PRD/postgres/9.6.2/pg5432/data" --new-datadir "/data/PRD/postgres/10/pg5432/data" --old-bindir "/data/PRD/postgres/base/9.6.2/bin" --new-bindir "/data/PRD/postgres/base/10.4/bin" --link
# 输出
If you want to start the old cluster, you will need to remove
the ".old" suffix from /data/PRD/postgres/9.6.2/pg5432/data/global/pg_control.old.
Because "link" mode was used, the old cluster cannot be safely
started once the new cluster has been started.
也可以在升级时加上vacuumdb参数
start:14:30:05 14:33:29 3分钟 --vacuumdb --analyze-only
start:14:45:40 14:54:25 10分钟 --vacuumdb 210GB
如果不进行vacuumdb,中断时间在1min左右,后面的过程可以在拉起数据库之后执行
- 修改环境变量文件 .bash_profile
- 启动10数据库
/data/PRD/postgres/base/10.4/bin/pg_ctl -D /data/PRD/postgres/10/pg5432/data start
- pgrman升级,备份脚本修改
3. 回滚方案
- 将 /data/PRD/postgres/9.6.2/pg5432/data/global/pg_control.old 文件重命名回pg.control
- 拉起原9.6库即可
4. 备库升级
- 安装postgresql软件,参考主库升级文档
- 删除备库原文件
- 重新搭建备库
pg_basebackup -hip -U repuser -F p -P -Xfetch -R -D /data/PRD/postgres/10.4/pg5432/data -l repuserback
参考
http://www.yunweipai.com/archives/23860.html
《postgresql版本升级方案演进》
标签:PRD,upgrade,postgres,pg5432,版本升级,pg,9.6,data From: https://blog.51cto.com/u_13631369/6203180