pg 大版本升级方法 及 pg_upgrade就地升级测试

一、 主要升级方法

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版本升级方案演进》

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Hehuyi_In

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值