timescaledb升级(pg_upgrade数据库同步升级-link方式)

一、环境

旧版postgres:10.11

安装目录:/opt/software/psql
数据目录:/data/postgresData
      /data3/postgresData(附加表空间,有一个大表单独存储在挂载的新硬盘)

旧版timescaleDB:1.4.0

新版postgres:12.9 安装包下载

安装目录:/opt/software/postgresql-12.9
数据目录:/data/pg_data

新版timescaleDB:2.4.0
新版中间版本:1.7.5

参考官网版本,1.7支持10和12版本,所以先将timescaleDB升级到1.7版本,再升级数据库,最后再将时序库升级到2.4.0

版本对应

二、时序库升级1.4.0 --> 1.7.5

cmake下载路径

#安装编译cmake
tar -zxvf cmake-3.16.2.tar.gz -C /opt/software/
pushd /opt/software/cmake-3.16.2/
./bootstrap
gmake
make install
popd

#解压编译timescaledb1.7.5
tar -zxvf timescaledb-1.7.5.tar.gz -C /opt/software/pgsql/
pushd /opt/software/pgsql/timescaledb-1.7.5/
#目前,该`bootstrap`脚本有问题,详见https://github.com/timescale/timescaledb/pull/355,必须带后面属性才能通过运行
./bootstrap -DWARNINGS_AS_ERRORS=OFF -DREGRESS_CHECKS=OFF
cd build && make
make install
popd

#timescaledb文件夹名字不要出现特殊字符,保证postgresql.conf中的shared_preload_libraries和新timescaledb文件夹名称一致即可
mv /opt/software/pgsqltimescaledb/ timescaledb-1.4.0
mv /opt/software/pgsqltimescaledb-1.7.5/ timescaledb


#登录重启
su - postgres
pg_ctl restart
psql
#进入有使用timescaledb的数据库
\c bridge
#更新timescaledb版本
ALTER EXTENSION timescaledb UPDATE;
\q
#停止运行旧库
pg_ctl stop
exit

三、新数据库安装

#安装依赖
yum -y install make gcc readline readline-devel zlib zlib-devel perl tcl openssl openssl-devel openldap pam pam-devel perl-ExtUtils-Embed

#解压
tar -zxvf postgresql-12.9.tar.gz -C /opt/software
pushd /opt/software/postgresql-12.9
mkdir /opt/software/pgsql12

#编译
./configure --prefix=/opt/software/pgsql12 --with-perl --with-openssl --with-pam
make world
make install-world

#创建数据目录并授权
mkdir /data/pgsql_data
chown -R postgres /data/pgsql_data/

#进入postgres用户
su - postgres
#初始化
/opt/software/pgsql12/bin/initdb -D /data/pgsql_data
exit

#将旧数据库pg_hba.conf拷贝到新数据库,
cp -rf /data/postgresData/pg_hba.conf /data/pgsql_data/
popd

配置环境变量

#添加环境变量,如果原先版本的/etc/profile下已存在这两个变量,直接修改就行
echo 'export PGHOME=/opt/software/pgsql12' >>/etc/profile;
echo 'export PGDATA=/data/pgsql_data'>>/etc/profile;
echo 'export PATH=$PGHOME/bin:$PATH'>>/etc/profile;

#生效环境变量
source /etc/profile

配置postgresql.conf,\color{red}{必须保证新旧版本端口不一样!},其余的按需自行配置。

sed -i "s/#data_directory = 'ConfigDir'/data_directory = '\/data\/pgsql_data'/" /data/pgsql_data/postgresql.conf
sed -i "s/#listen_addresses = 'localhost'/listen_addresses = '\*'/" /data/pgsql_data/postgresql.conf
sed -i "s/#port = 5432/port = 2345/" /data/pgsql_data/postgresql.conf
sed -i "s/#shared_preload_libraries = ''/shared_preload_libraries = 'timescaledb'/" /data/pgsql_data/postgresql.conf

\color{red}{不要启动新库!!!}
\color{red}{不要启动新库!!!}
\color{red}{不要启动新库!!!}

同步timescaleDB到新版本数据库,保证新旧数据库使用同一版本timescaleDB(1.7.5)

#解压编译timescaledb1.7.5
tar -zxvf timescaledb-1.7.5.tar.gz -C /opt/software/pgsql12/
pushd /opt/software/pgsql12/timescaledb-1.7.5/
./bootstrap -DWARNINGS_AS_ERRORS=OFF -DREGRESS_CHECKS=OFF
cd build && make
make install
popd
mv /opt/software/pgsql12/timescaledb-1.7.5/ /opt/software/pgsql12/timescaledb

四、更新数据库版本

在新库中使用 pg_upgrade 查看帮助信息

/opt/software/pgsql12/bin/pg_upgrade --help

新库 pg_upgrade 检测兼容性,链接方式 是添加 –link 参数

chown -R postgres:postgres /opt/software/pgsql12/

su - postgres

cd /opt/software/pgsql12/bin
./pg_upgrade -c --link -b /opt/software/pgsql/bin -B /opt/software/pgsql12/bin -d /data/postgresData/ -D /data/pgsql_data/ -p 5432 -P 2345

-b:指定旧版本软件的bin目录
-B:指定新版本软件的bin目录
-d:指定旧版本对应的数据目录
-D:指定新版本对应的数据目录。

检查成功

如果老postgres安装了一些插件则需要在新的postgres上安装同样的插件

无法加载库 "$libdir/ltree": 错误:  无法访问文件 "$libdir/ltree": 没有那个文件或目录
无法加载库 "$libdir/dblink": 错误:  无法访问文件 "$libdir/dblink": 没有那个文件或目录
无法加载库 "$libdir/file_fdw": 错误:  无法访问文件 "$libdir/file_fdw": 没有那个文件或目录
无法加载库 "$libdir/postgres_fdw": 错误:  无法访问文件 "$libdir/postgres_fdw": 没有那个文件或目录
无法加载库 "$libdir/pg_stat_statements": 错误:  无法访问文件 "$libdir/pg_stat_statements": 没有那个文件或目录

开始更新

#更新
./pg_upgrade --link -b /opt/software/pgsql/bin -B /opt/software/pgsql12/bin -d /data/postgresData/ -D /data/pgsql_data/ -p 5432 -P 2345
exit
更新成功

可将端口改回5432,启动新库

su - postgres
pg_ctl start

由于pg_upgrade并未传输优化器统计信息,在升级的最后按提示运行一个命令来生成这些信息。

cd /opt/software/pgsql12/bin
./analyze_new_cluster.sh 
统计信息

删除老版本库的数据目录

#使用超级管理员权限删除
exit
sh /opt/software/pgsql12/bin/delete_old_cluster.sh

五、timescaleDB 1.7.5->2.4.0

gcc版本升级,否则编译timescaleDB2.x版本会失败

#gcc版本升级到9
yum -y install centos-release-scl
yum -y install devtoolset-9-gcc*
#仅对本次会话有效
scl enable devtoolset-9 bash

#查看版本号
gcc -v

升级时序库

#解压编译timescaledb2.4.0
tar -zxvf timescaledb-2.4.0.tar.gz -C /opt/software/pgsql12/
pushd /opt/software/pgsql12/timescaledb-2.4.0/
./bootstrap -DWARNINGS_AS_ERRORS=OFF -DREGRESS_CHECKS=OFF  -DTAP_CHECKS=OFF
cd build && make
make install
popd

#timescaledb文件夹名字不要出现特殊字符,保证postgresql.conf中的shared_preload_libraries和新timescaledb文件夹名称一致即可
mv /opt/software/pgsql12/timescaledb/ /opt/software/pgsql12/timescaledb-1.7.5
mv /opt/software/pgsql12/timescaledb-2.4.0/ /opt/software/pgsql12/timescaledb


#登录重启
su - postgres
pg_ctl restart
psql
#进入有使用timescaledb的数据库
\c bridge
#更新timescaledb版本
ALTER EXTENSION timescaledb UPDATE;
\q
exit

查看时序库版本

检查版本
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,590评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 86,808评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,151评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,779评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,773评论 5 367
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,656评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,022评论 3 398
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,678评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,038评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,659评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,756评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,411评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,005评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,973评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,053评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,495评论 2 343

推荐阅读更多精彩内容