博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
PostgreSQL 利用pg_upgrade升级版本
阅读量:4511 次
发布时间:2019-06-08

本文共 1362 字,大约阅读时间需要 4 分钟。

  参考:

  • 概述

从低版本升级到 新版本,有几种可选的方案。一是使用pg_dump/pg_restore,该方法比较耗时,也即是停机时间比较长,特别是大数据量下,但是 稳定且易于操作。二是和MySQL那样利用复制的方式,停机时间短,但操作相对复杂。第三种就是利用pg_upgrade,重建系统表,相对停机时间较短。

  • pg_upgrade

  1. 语法

  pg_upgrade -b oldbindir -B newbindir -d olddatadir -D newdatadir [option...]

  2. 原理

根据官方文档介绍,PostgreSQL  每次升级主要体现在系统表的改变,对于数据文件的格式基本不做改动,因此利用这个特性,只要重建所有系统表,复用原有数据文件,即可完成升级。对于 8.4.X后的每一次大版本升级都适用。需要注意的是,即便如此,该方法也有一定的限制,在官方文档的NOTE部分有详细说明。

  • 升级步骤

  1. 编辑postgresql.conf,修改旧数据库端口为5433

  2. 安装新版PostgreSQL

  3. 停止新旧数据库服务 

  sudo service postgresql stop

  4. 验证兼容性

/usr/lib/postgresql/9.4/bin/pg_upgrade --old-datadir=/var/lib/postgresql/9.3/main/ --new-datadir=/var/lib/postgresql/9.4/main/  --old-bindir=/usr/lib/postgresql/9.3/bin/  --new-bindir=/usr/lib/postgresql/9.4/bin -p5433 -P5432 -o"-c config_file=/etc/postgresql/9.3/main/postgresql.conf" -O"-c config_file=/etc/postgresql/9.4/main/postgresql.conf" -c

  5. 升级

/usr/lib/postgresql/9.4/bin/pg_upgrade --old-datadir=/var/lib/postgresql/9.3/main/ --new-datadir=/var/lib/postgresql/9.4/main/  --old-bindir=/usr/lib/postgresql/9.3/bin/  --new-bindir=/usr/lib/postgresql/9.4/bin -p5433 -P5432 -o"-c config_file=/etc/postgresql/9.3/main/postgresql.conf" -O"-c config_file=/etc/postgresql/9.4/main/postgresql.conf"

  6. 执行脚本重建统计信息,删除旧数据库(可选)

./analyze_new_cluster.sh./delete_old_cluster.sh

 

转载于:https://www.cnblogs.com/cxy486/p/5136464.html

你可能感兴趣的文章
layer的简单使用
查看>>
命名空间
查看>>
JS禁止右键,禁止Ctrl键,禁止选中文字
查看>>
XtraGrid判断列有没有显示
查看>>
MySQL系列--3.数据类型和连接查询
查看>>
servlet的url-pattern匹配规则详细描述
查看>>
jquery 进度条
查看>>
《BI那点儿事》数据流转换——查找转换
查看>>
二叉树中和为某一值的路径
查看>>
07_组件三大属性(1)_state
查看>>
学习PYTHON之路, DAY 3 - PYTHON 基础 3 (函数)
查看>>
Leetcode 416.分割等和子集
查看>>
java8 lambda 表达式
查看>>
【转】提示框第三方库之MBProgressHUD iOS toast效果 动态提示框效果
查看>>
JS对象和JSON字符串相互转化总结
查看>>
Ajax
查看>>
poj1019——log10求位数
查看>>
xdoj1065 Efficent Allocation 动态开点的线段树
查看>>
css默认值汇总
查看>>
IE兼容CSS3圆角border-radius的方法(同时兼容box-shadow,text-shadow)
查看>>