文章结构如下:

Postgresql是一个非常活跃的社区开源项目,更新速度很快,每一次版本的更新都会积极的修复旧版本的BUG,性能上也会有不同幅度的提升。10之前的版本由三部分组成,10开始只有两部分数字组成。

1. 小版本升级

Postgresql每次的小版本升级不会改变内部的存储格式,也不会改变数据目录,并且总是向上兼容同一主版本,9.6.2与9.6.1总是兼容的。升级小版本只需要安装新的可执行文件,并且重启数据库实例。

① 备份

可以进行数据库备份pg_dump备份

② 关闭数据库服务器

pg_ctl stop -D /pgsql/pg_data/

cd /usr/local/

mv pgsql/ pgsqlbak

把postgresql9.6.8 上传到目录/usr/local/src并解压

mkdir -p /usr/local/pgsql

cd /usr/local/src/postgresql

./configure --with-ossp-uuid --prefix=/usr/local/pgsql

gmake world

gmake install-world

③ 安装完后,直接启动数据库

pg_ctl start -D /pgsql/pg_data/

启动后,数据查询成功。

2. 大版本升级

大版本可以用pg_dumpall 和pg_upgrade进行升级,主要是将pg_upgrade升级。

pg_upgrade(以前称为pg_migrator)允许将存储在PostgreSQL数据文件中的数据升级到更高版本的PostgreSQL主版本,而不需要主要版本升级所需的数据转储/重载,例如从8.4.7升级到PostgreSQL的当前主要版本。次要版本升级不需要,例如从9.0.1到9.0.4。

主要的PostgreSQL版本会定期添加新功能,这些功能通常会改变系统表的布局,但内部数据存储格式很少会发生变化。pg_upgrade通过创建新的系统表并简单地重用旧的用户数据文件来使用此事实来执行快速升级。如果未来的主要版本以一种使旧数据格式不可读的方式更改数据存储格式,则pg_upgrade将无法用于此类升级。(社区将试图避免这种情况。)

pg_upgrade尽力确保旧的和新的集群是二进制兼容的,例如通过检查兼容的编译时设置,包括32/64位二进制文​​件。重要的是,任何外部模块也是二进制兼容的,尽管pg_upgrade无法检查。

pg_upgrade支持从8.4.X及更高版本升级到PostgreSQL的当前主要版本。

有一些外部扩展要求在升级之前先升级旧版本的外部扩展,例如GIS。

一.使用upgrade 普通模式升级

1) 安装新版的PG并初始化数据目录

把新版本的包上传到/usr/local/src目录 root 执行以下命令

mkdir -p /usr/local/pgsql10

cd /usr/local/src/

tar -zxvf postgresql-10.8.tar.gz

./configure --with-ossp-uuid --prefix=/usr/local/pgsql10

gmake world

gmake install-world

mkdir -p /pgsql/pg_data10

mkdir -p /pgsql/pg_archive10

mkdir -p /pgsql/pg_log10

chown -R postgres:postgres /pgsql/pg_data10

su - postgres

export PGHOME=/usr/local/pgsql10

export PGDATA=/pgsql/pg_data10

初始化后不能启动新的库。

/usr/local/pgsql10/bin/initdb -D $PGDATA -E UTF-8 --locale=C -U postgres -W

查看安装的目录:

2) 停止旧版本的数据库

pg_ctl stop -D /pgsql/pg_data/ -m fast

3) 检查兼容性

为了避免数据库升级失败造成的长时间宕机,升级之前都做兼容性检查。

检查语句:

/usr/local/pgsql10/bin/pg_upgrade -b /usr/local/pgsql/bin/ -B /usr/local/pgsql10/bin/ -d /pgsql/pg_data/ -D /pgsql/pg_data10/ -k -c

可以查看已经通过兼容性测试。

值得注意的是pg10跟之前的版本hash 索引结构不一样,升级之后需要重建hash索引。

4) 使用PG_UPGRADE普通模式升级

/usr/local/pgsql10/bin/pg_upgrade -b /usr/local/pgsql/bin/ -B /usr/local/pgsql10/bin/ -d /pgsql/pg_data -D /pgsql/pg_data10/

图片中提示,如果升级失败,必须重新初始化新的数据库才能够继续进行升级,本次实验中升级成功。

修改postgresql.conf,pg_hba.conf 参数

开启后,检查数据库是否正常运行以及有无报错。

二.使用upgrade link模式升级

同样的也是前期准备工作一样,初始化数据库:

把新版本的包上传到/usr/local/src目录 root 执行以下命令

mkdir -p /usr/local/pgsql10

cd /usr/local/src/

tar -zxvf postgresql-10.8.tar.gz

./configure --with-ossp-uuid --prefix=/usr/local/pgsql10

gmake world

gmake install-world

mkdir -p /pgsql/pg_data10

mkdir -p /pgsql/pg_archive10

mkdir -p /pgsql/pg_log10

chown -R postgres:postgres /pgsql/pg_data10

su - postgres

export PGHOME=/usr/local/pgsql10

export PGDATA=/pgsql/pg_data10

/usr/local/pgsql10/bin/initdb -D $PGDATA -E UTF-8 --locale=C -U postgres -W

初始化后不能启动新的库。

1) 了解旧版本有那些extension以及表空间

2) 检查兼容性

检查语句:

/usr/local/pgsql10/bin/pg_upgrade -b /usr/local/pgsql/bin/ -B /usr/local/pgsql10/bin/ -d /pgsql/pg_data/ -D /pgsql/pg_data10/ -k -c

3) 使用PG_UPGRADE link模式升级

如果使用了hash 索引,需要重建索引升级完成后(升级的过程中,索引会变为不可用)

关闭旧的数据库:

/usr/local/pgsql/bin/pg_ctl stop -D /pgsql/pg_data -m fast

/usr/local/pgsql10/bin/pg_upgrade -b /usr/local/pgsql/bin -B /usr/local/pgsql10/bin -d /pgsql/pg_data/ -D /pgsql/pg_data10/ -k

其中提示,如果想用旧版本,需要把/pgsql/pg_data/global/pg_control.old命名为/pgsql/pg_data/global/pg_control

例如测试:

mv /pgsql/pg_data/global/pg_control.old /pgsql/pg_data/global/pg_control

/usr/local/pgsql/bin/pg_ctl start -D /pgsql/pg_data

还是可以启动使用以前的数据库。

由于本次是使用新的版本:

mv /pgsql/pg_data/global/pg_control /pgsql/pg_data/global/pg_control.old

启动新的实例。(新的实例端口为5433)

pg_ctl start -D /pgsql/pg_data10/

手动收集统计信息:

/usr/local/pgsql10/bin/vacuumdb -a --analyze-in-stages -h127.0.0.1 -p5433

9版本新的库升级成功,并且开启后,旧的仍然能够通过修改pg_control.old后启动。

貌似10的旧版本

Postgresql 大小版本升级的更多相关文章

  1. 使用pg_upgrade工具为PostgreSQL进行版本升级

    公司的测试环境和生产环境都是9.2.4版本,而开发环境是9.0.18版本. PS: 不知道公司里的其它同事,是如何做数据库迁移的,利用第三方可视化工具备份数据库,然后恢复到其它高版本的环境?反正我没成 ...

  2. PostgreSQL 数据库升级

    PostgreSQL软件版本升级后,需要使用pg_upgrade迁移旧版本的数据库,具体的操作参数可以参考官方文档,在此记录一下操作过程中出现的细节问题: 新版本软件在initdb的时候要保证loca ...

  3. Windows版 PostgreSQL 利用 pg_upgrade 进行大版升级操作

    最近 PostgreSQL 15 版本正式发布了,新版本的各种特性和好处本文就不展开介绍了,主要介绍一下 Windows 环境下 PostgreSQL 大版本升级的方法,我们现在的几个数据库都是运行在 ...

  4. Zabbix 6.0:原生高可用(HA)方案部署

    Blog:博客园 个人 本部署文档适用于CentOS 8.X/RHEL 8.X/Anolis OS 8.X/AlmaLinux 8.X/Rockey Linux 8.X. 原生的HA方案终于来了 相比 ...

  5. PostgreSQL 磁盘使用大小监控

    表大小信息 postgres=# SELECT *, pg_size_pretty(total_bytes) AS totalpostgres-# , pg_size_pretty(index_byt ...

  6. postgresql基本操作:查看数据库、索引、表、表空间大小

    一.简介 PostgreSQL 提供了多个系统管理函数来查看表,索引,表空间及数据库的大小,下面详细介绍一下. 二.数据库对象尺寸函数 函数名 返回类型 描述 pg_column_size(any) ...

  7. postgresql查看数据库占用的物理存储空间大小

    1.手动查看: 查看数据库postgres的oid postgres=# SELECT oid from pg_database where datname='postgres'; oid------ ...

  8. PostgreSQL 查看单表大小

    1. 在数据库中查单个表 select pg_size_pretty(pg_relation_size('table_name')); 2. 查出并按大小排序 SELECT table_schema ...

  9. PostgreSQL查看表大小的命令

    SELECT table_name, pg_size_pretty(table_size) AS table_size, pg_size_pretty(indexes_size) AS indexes ...

随机推荐

  1. 设置PyCharm中选择文本的背景颜色和代码中和选中单词相同单词的背景颜色

    1 设置选中单词的背景颜色 首先进入File->Setting->Editor->Color Scheme后复制一个存在的颜色主题作为自定义的颜色主题(默认的颜色主题是无法修改的,也 ...

  2. PHP ob_get_level嵌套输出缓冲

    PHP的输出缓存是可以嵌套的.用ob_get_level()就可以输出嵌套级别. 测试发现在cli和浏览器下输出结果不一样(PHP5.4). ob_level1.png手册说明如下: ob_get_l ...

  3. ELK- elasticsearch 讲解,安装,插件head,bigdesk ,kopf,cerebro(kopf升级版)安装

    ElasticSearch:简称es ,分布式全文搜索引擎,使用java语言开发,面向文档型数据库,一条数据就是一个文档,数据用json序列化后存储. 默认端口:9200 借助redis来理解 red ...

  4. STL -- heap结构及算法

    STL -- heap结构及算法 heap(隐式表述,implicit representation) 1. heap概述 : vector + heap算法 heap并不归属于STL容器组件,它是个 ...

  5. javascript之日期对象(Date)

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  6. [idea]添加jar包的方法

    一:在项目的根目录下建立lib文件夹,然后将对应的jar包文件拷贝进去. 二:点击项目右键,选择Open Module Settings 三.选择Project Settings->Librar ...

  7. python对列表中名字进行修改,在每个名字后面加入‘the Great’

    第一种方法:使用enumerate函数 def make_great(magicians): for i ,name in enumerate(magicians): magicians[i] = m ...

  8. HBase 参考信息

    Apache HBase Region Splitting and Merging  https://blog.cloudera.com/apache-hbase-region-splitting-a ...

  9. Qt qss 动态属性-不同条件不同显示

    一. 1.为了用户界面外观的动态变化,属性选择器可以与动态属性组合使用. 2.当一个属性值变化时,所引用的样式不会自动更新.相反地,必须手动触发更新才会生效.unpolish()用于清理之前的样式,而 ...

  10. Django与Session

    Session Session的由来 ​ Cookie虽然在一定程度上解决了"保持状态"的需求,但是由于Cookie本身最大支持4096字节,以及Cookie本身保存在客户端,可能 ...