如何匹配 pg_repack 二进制文件和数据库版本

Fal*_*con 5 postgresql debian postgresql-extensions

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

postgresql-11-repack is already the newest version (1.4.8-1.pgdg20.04+1).
Run Code Online (Sandbox Code Playgroud)

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

                                        List of installed extensions
     Name     | Version |   Schema   |                         Description
--------------+---------+------------+--------------------------------------------------------------
 pg_repack    | 1.4.4   | public     | Reorganize tables in PostgreSQL databases with minimal locks
Run Code Online (Sandbox Code Playgroud)

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

ERROR: pg_repack failed with error: program 'pg_repack 1.4.8' does not match database library 'pg_repack 1.4.4'
Run Code Online (Sandbox Code Playgroud)
  1. 如何在数据库中创建版本 1.4.8 的重新打包扩展?
  2. 如果上述方法不可行,我如何将 ec2 上的 pg_repack 版本降级回与我的数据库相同的 1.4.4。
  3. AWS 也不允许我在“shared_preload_libraries”下添加此扩展。

从源代码编译时出错:

    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
Run Code Online (Sandbox Code Playgroud)

jus*_*guy 6

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

apt list -a postgresql-11-repack
Run Code Online (Sandbox Code Playgroud)

输出的类型将如下所示:

postgresql-11-repack/buster-pgdg 1.4.4-2.pgdg110+1 amd64 [可升级自:1.4.3-1.pgdg110+1]
postgresql-11-repack/now 1.4.3-1.pgdg110+1 amd64 [已安装,可升级至:1.4.4-2.pgdg110+1]


如果列出了您需要的软件包版本,则可以删除现有软件包并通过删除现有软件包并安装目标版本来安装所需的特定版本,如下所示这里是关于为什么 debian 软件包需要 pg_repack 扩展的一个很好的参考版本1.4.41.4.4-11.4.4-2

这有点做作,但在这个示例中,我删除1.4.3并安装了(如果您已经安装了 debian 软件包并且您想专门安装,则1.4.4适用相同的过程):1.4.8-11.4.4-2

sudo apt-get --purge remove postgresql-11-repack

sudo apt-get install postgresql-11-repack=1.4.4-2
Run Code Online (Sandbox Code Playgroud)

如果该包未显示,您也可以从源代码构建它:

git clone https://github.com/reorg/pg_repack.git
cd pg_repack/
git checkout tags/ver_1.4.4
make
make install
Run Code Online (Sandbox Code Playgroud)

您可能想要从源代码构建的一个原因是因为您需要的软件包版本来自操作系统的早期版本,并且您不想专门处理这种类型的乐趣(示例


Fal*_*con 0

感谢大家的投入。以下是我在 EC2 和 RDS Postgres 中设置 pg_repack 1.4.7 所遵循的步骤

wget https://api.pgxn.org/dist/pg_repack/1.4.7/pg_repack-1.4.7.zip

sudo apt-get install postgresql-server-dev-all
sudo apt-get install postgresql-common
sudo apt-get install postgresql-client
--remove pg 15 from installation ( At present, PG 14 and the latest PG 15 version are not supported, and an error will be reported during installation: pointer type error ) 

sudo make
sudo make install
sudo cp bin/pg_repack /usr/local/bin/
Run Code Online (Sandbox Code Playgroud)

在此输入图像描述

create extension pg_repack; -- RDS Postgres
Run Code Online (Sandbox Code Playgroud)