首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何匹配pg_repack二进制和db版本

如何匹配pg_repack二进制和db版本
EN

Database Administration用户
提问于 2022-12-19 20:57:50
回答 1查看 472关注 0票数 4

我使用这个命令sudo apt-get install postgresql-11-repack来安装pg_repack(默认为1.4.8)。

代码语言:javascript
复制
postgresql-11-repack is already the newest version (1.4.8-1.pgdg20.04+1).

当我在rds postgres 11中运行“创建扩展pg_repack”时,它默认使用1.4.4版本创建。

代码语言:javascript
复制
                                        List of installed extensions
     Name     | Version |   Schema   |                         Description
--------------+---------+------------+--------------------------------------------------------------
 pg_repack    | 1.4.4   | public     | Reorganize tables in PostgreSQL databases with minimal locks

因此,由于pg_repack和db之间的版本号不匹配,ec2失败了。

代码语言:javascript
复制
ERROR: pg_repack failed with error: program 'pg_repack 1.4.8' does not match database library 'pg_repack 1.4.4'
  1. 如何在DB中创建1.4.8版本的repack扩展?
  2. 如果不可能,如何将pg_repack版本的ec2降级到与db相同的1.4.4。
  3. AWS也不允许我在"shared_preload_libraries“下添加这个扩展。

从源编译错误:

代码语言:javascript
复制
    gcc -Wall -Wmissing-prototypes -Wpointer-arith -Wdeclaration-after-statement -Wendif-labels -Wmissing-format-attribute -Wformat-security -fno-strict-aliasing -fwrapv -fexcess-precision=standard -Wno-format-truncation -Wno-stringop-truncation -g -g -O2 -fstack-protector-strong -Wformat -Werror=format-security -fno-omit-frame-pointer pg_repack.o pgut/pgut.o pgut/pgut-fe.o  -L/usr/lib/x86_64-linux-gnu -Wl,-Bsymbolic-functions -Wl,-z,relro -Wl,-z,now -L/usr/lib/llvm-10/lib  -L/usr/lib/x86_64-linux-gnu/mit-krb5 -Wl,--as-needed  -L/usr/lib/x86_64-linux-gnu -lpq -L/usr/lib/postgresql/11/lib -lpgcommon -lpgport -lpthread -lssl -lcrypto -lz -lrt -lcrypt -ldl -lm -o pg_repack
/usr/bin/ld: cannot find -lpgcommon
/usr/bin/ld: cannot find -lpgport
collect2: error: ld returned 1 exit status
make[1]: *** [/usr/lib/postgresql/11/lib/pgxs/src/makefiles/pgxs.mk:430: pg_repack] Error 1
make[1]: Leaving directory '/home/user/pg_repack-ver_1.4.4/bin'
make: *** [Makefile:35: all] Error 2
enter code here
EN

回答 1

Database Administration用户

发布于 2022-12-19 22:12:22

首先,检查当前发行版是否存在包版本:

代码语言:javascript
复制
apt list -a postgresql-11-repack

输出的类型如下所示:

PostgreSQL11-repack/buster-pgdg 1.4.4-2.pgdg 110+1 amd64 110+1可升级:1.4.3-1.pgdg可升级 postgresql-11-repack/now 1.4.3-1.pgdg 110+1 amd64 110+1已安装,可升级到:1.4.4-2.pgdg已安装,可升级到

如果列出了所需的包版本,则可以删除现有包并安装所需的特定版本,方法如下所示(这里是pg_repack扩展版本1.4.4的debian包编号1.4.4-11.4.4-2等的一个很好的参考)

这有点做作,但在本例中,我删除了1.4.3并安装了1.4.4 (如果您已经安装了1.4.8-1 debian包,并且希望具体安装1.4.4-2,则同样的过程也适用):

代码语言:javascript
复制
sudo apt-get --purge remove postgresql-11-repack

sudo apt-get install postgresql-11-repack=1.4.4-2

如果包没有出现,您也可以从源代码:

构建它

代码语言:javascript
复制
git clone https://github.com/reorg/pg_repack.git
cd pg_repack/
git checkout tags/ver_1.4.4
make
make install

您可能希望从源代码构建的一个原因是,您需要的包的版本来自于操作系统的前一个版本,并且您不想专门处理喜悦的那种类型(示例)。

票数 5
EN
页面原文内容由Database Administration提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://dba.stackexchange.com/questions/321173

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档