postgresql数据库升级
pg_upgrade官网介绍:https://www.postgresql.org/docs/10/pgupgrade.html
1.查看老版本数据库编译参数值并记录
select name,setting,unit from pg_catalog.pg_settings where context='internal'
或者在postgres用户下执行如下命令
$ pg_config
重点关注一下四个参数,block_size,segment_size,wal_block_size,wal_segment_size
2.上传新版本PG源码并安装(本例使用PG12演示)
# tar vxf postgresql-12beta1.tar.gz
# cd postgresql-12beta1
# ./configure --prefix=/usr/local/pgsql-12.0 --with-wal-blocksize=8 --with-segsize=1 --with-blocksize=8
# make -j 10
# make install
# export PATH=$PATH:/usr/local/pgsql-12.0/bin
# cd contrib
# make all
# make install
注意,在编译的时候,一定要保证参数的值和旧版本数据库的值相同,否则后续无法升级
3.初始化新版本数据库
新版本数据库和旧版本数据库的PGDATA必须在同一个文件系统(目录)内才可以使用--link(硬链接)
$ cd /usr/local/pgsql-12.0/bin/
$ ./initdb --wal-segsize=16 -D /pgdata01/data/
pg12中编译时没有wal_segment_size参数,可以在初始化时指定
4.检查是否可以升级
$ cd /tmp
$ mkdir upgrade_log
$ cd upgrade_log
# 使用link硬链接方式的检查
$ /usr/local/pgsql-12.0/bin/pg_upgrade -c -- link -b /postgresql/pgsql/database/bin -B /usr/local/pgsql-12.0/bin -d /postgresql/pgsql/body/etc -D /pgdata01/data
# 使用copy方式的检查
$ /usr/local/pgsql-12.0/bin/pg_upgrade -c -b /postgresql/pgsql/database/bin -B /usr/local/pgsql-12.0/bin -d /postgresql/pgsql/body/etc -D /pgdata01/data
5.检查失败,解决失败问题,检查成功,可以跳过本步骤
本例检查失败,因为旧版本数据库安装了一个插件
可以卸载插件或者在新版本数据库上面安装插件
卸载插件:
psql
drop extension pg_proctab;
\c db01
drop extension pg_proctab;
\c db02
drop extension pg_proctab;
\c db03
drop extension pg_proctab;
因为postgres,db01,db02,db03,db04数据库都安装有插件,因此都卸载掉
新版本数据库安装插件
上傳插件
# unzip pg_proctab-0.0.7.zip
# cd pg_proctab-0.0.7
# export PATH=$PATH:/usr/local/pgsql-12.0/bin/
# make
# make install
安装完毕后,再次检查,看是否通过
其他异常请根据检查提示解决
6.开始升级
关闭旧版本数据库
升级有一下两种方式:
copy方式升级
$ /usr/local/pgsql-12.0/bin/pg_upgrade -b /postgresql/pgsql/database/bin -B /usr/local/pgsql-12.0/bin -d /postgresql/pgsql/body/etc -D /pgdata01/data
优点:
copy方式是在旧版本数据库表空间同目录下新建一个新版本数据库的目录并将数据文件复制过来,因此在数据库升级后,如果新旧版本数据库的端口号不一样的话,可以同时开启
缺点:
对于大数据量数据库需要的升级时间较长,且旧版本数据库数据文件所在目录剩余容量至少和现有使用量相同,占据空间
link方式升级
$ /usr/local/pgsql-12.0/bin/pg_upgrade --link -b /postgresql/pgsql/database/bin -B /usr/local/pgsql-12.0/bin -d /postgresql/pgsql/body/etc -D /pgdata01/data
优点:
link方式是在旧版本数据库表空间目录下新建一个目录,并在里面新建一个硬链接直接指向旧版本数据库的数据文件,升级迅速且不占用空间
缺点:
因为旧版本数据库和新版本数据库由于硬链接,因此使用的实际是同一个文件,因此无法同时开启新旧版本数据库
查看是否是硬链接可以进入新版本数据库数据文件所在目录执行ll命令
$ cd /data/tbs/PG_10_201707211/16384
$ ll
结果:
-rw-------. 2 postgres postgres 32768 Jun 26 09:09 16391
-rw-------. 2 postgres postgres 0 Jun 26 09:01 16394
从结果里面可以看到,每一个数据文件2个目录指向它,硬链接
7.修改环境变量
# su - postgres
$ vi .bash_profile export PGHOME=/usr/local/pgsql
export PGDATA=/pgdata01/data
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/local/pgsql/lib
export PATH=$PATH:$PGHOME/bin
8.修改postgresql.conf和pg_hba.conf文件
9.创建扩展
10.扫尾等
postgresql数据库升级的更多相关文章
- PostgreSQL 数据库升级
PostgreSQL软件版本升级后,需要使用pg_upgrade迁移旧版本的数据库,具体的操作参数可以参考官方文档,在此记录一下操作过程中出现的细节问题: 新版本软件在initdb的时候要保证loca ...
- postgresql数据库的数据导出
一.pg_dump的用法:数据库的导入导出是最常用的功能之一,每种数据库都提供有这方面的工具,例如Oracle的exp/imp,Informix的dbexp/dbimp,MySQL的mysqldump ...
- 关于PDF.NET开发框架对Mysql Sqlite PostgreSQL数据库分页支持的个人看法
关于PDF.NET开发框架的名字由来 在设计www.pwmis.com站点的时候,考虑到架构的兼容性和将来升级的可能性,最重要的是没有足够的时间去为网站添加和维护很多复杂的程序,所以在借鉴前人成功经 ...
- MetaSploit攻击实例讲解------终端下PostgreSQL数据库的使用(包括kali linux 2016.2(rolling) 和 BT5)
不多说,直接上干货! 配置msf连接postgresql数据库 我这里是使用kali linux 2016.2(rolling) 用过的博友们都知道,已经预安装好了PostgreSQL. 1. p ...
- PostgreSQL数据库安装
PostgreSQL数据库安装 postgresqllinux9.6.0 2018年01月31日 10时53分13秒 编译以及安装 源码编译 程序安装 数据库的启动和停止 启动数据库 关闭数据库 数据 ...
- PostgreSQL 数据库备份与还原
PostgreSQL 数据库备份与还原 目录 备份 还原 栗子 备份 PostgreSQL提供的一个工具pg_dump,逻辑导出数据,生成sql文件或其他格式文件,pg_dump是一个客户端工具,可以 ...
- ASP.NET MVC 使用 Petapoco 微型ORM框架+NpgSql驱动连接 PostgreSQL数据库
前段时间在园子里看到了小蝶惊鸿 发布的有关绿色版的Linux.NET——“Jws.Mono”.由于我对.Net程序跑在Linux上非常感兴趣,自己也看了一些有关mono的资料,但是一直没有时间抽出时间 ...
- Oracle数据库升级(10.2.0.4->11.2.0.4)
环境: RHEL5.4 + Oracle 10.2.0.4 目的: 在本机将数据库升级到11.2.0.4 之前总结的Oracle数据库异机升级:http://www.cnblogs.com/jyzha ...
- PostgreSQL介绍以及如何开发框架中使用PostgreSQL数据库
最近准备下PostgreSQL数据库开发的相关知识,本文把总结的PPT内容通过博客记录分享,本随笔的主要内容是介绍PostgreSQL数据库的基础信息,以及如何在我们的开发框架中使用PostgreSQ ...
随机推荐
- Unity射击实例讲解—主角创建
前言: 经过三分钟的思考决定换个标题,这两天其实游戏制作进度推了大半了,加入了许多自我创作的素材,不过想一想用来讲解的实例不该这么花哨,决定还是参照我的一些教材做一些简单的示例不然要说的东西太多,本人 ...
- Redis安装教程及安装报错解决方案(大佬勿喷)
安装环境:CentOS7 Redis版本:redis-6.0.9.tar.gz 依次按照以下顺序执行: 1. [root@localhost ~]# wget https://download.red ...
- SpringBoot执行原理
目录 [Toc] 一.执行原理: 每个Spring Boot项目都有一个主程序启动类,在主程序启动类中有一个启动项目的main()方法, 在该方法中通过执行SpringApplication.run( ...
- python的常量与变量
1.Python属于强类型编程语言,Python解释器会根据赋值或运算来自动判断变量的类型.Python还是一种动态类型语言,变量的类型也是可以随时变化的. >>> x=3 > ...
- [Python] iupdatable包:Timer 类使用介绍
iudatable包是我对常用函数进行的封装后发布的一个python包,教程汇总目录: [Python] iupdatable包使用说明 安装 iupdatable 包 pip install iup ...
- idea中快捷键换成熟悉的celipse中快捷键
打开idea,找到菜单栏的file,点击打开,找到settings,打开 用key做关键词搜索keymap 找到之后点击打开,右侧就会显示快捷键界面,可以点击查看每一项 4 默认为defaul ...
- 阿里云Ubuntu配置安装MQTT服务器
先来说说mqtt协议: MQTT(Message Queuing Telemetry Transport,消息队列遥测传输)是IBM开发的一个即时通讯协议,它比较适合于在低带宽.不可靠的网络的进行远程 ...
- uniapp H5引入腾讯地图
在网上搜索了许多关于uniapp引入腾讯地图的方法都以失败告终,我开发的应用主要使用于H5,小程序与H5是不同的sdk,就不在这说了,况且小程序有手把手教学,可参考腾讯地图官网https://lbs. ...
- Spark MLlib中KMeans聚类算法的解析和应用
聚类算法是机器学习中的一种无监督学习算法,它在数据科学领域应用场景很广泛,比如基于用户购买行为.兴趣等来构建推荐系统. 核心思想可以理解为,在给定的数据集中(数据集中的每个元素有可被观察的n个属性), ...
- idea中maven的安装与配置
说明:类似maven安装和配置的帖子在网上有很多,本人也有做过参照,但是有些帖子的步骤跳跃性比较大,故此,本人整理了一下,给大家做个参考. 一.下载安装 一般都是在官网进行下载 https://mav ...