PostgreSQL
 sql >> Baza danych >  >> RDS >> PostgreSQL

Kompilacja rozszerzenia pg_repack na binarnym formacie instalacji PostgreSQL

Ten blog dotyczy kompilacji rozszerzenia pg_repack na binarnym formacie instalacji PostgreSQL. Większość z was wie, że rozszerzenie pg_repack jest jednym z dobrze znanych rozszerzeń PostgreSQL, szczególnie używanym do odzyskiwania miejsca [rozdęcia] ONLINE bez trzymania WYŁĄCZNEJ BLOKADA na tabelach/indeksach.

Aby włączyć rozszerzenie pg_repack w bazie danych PostgreSQL, należy je skompilować ze źródeł. Jest dość łatwy i prosty do kompilacji ze źródeł na dowolnych zainstalowanych wariantach PostgreSQL (źródło, obroty, pliki binarne), jednak jest nieco inny, jeśli jest to binarny format PostgreSQL [Instalator jednym kliknięciem], ponieważ są one wstępnie zbudowanymi pakietami binarnymi z zależnością biblioteki. Skompilujmy i zobaczmy.

Na maszynie wirtualnej CentOS 7 zainstalowałem format binarny PostgreSQL 9.4 (link do pobrania) i jego katalog domowy „/opt/PostgreSQL/9.4/”. Następnie musimy pobrać źródło pg_repack z ich oficjalnej strony.

[root@localhost ~]# git clone https://github.com/reorg/pg_repack.git

Przed kompilacją w PATH należy ustawić pg_config PostgreSQL 9.4.

[root@localhost pg_repack]# export PATH=/opt/PostgreSQL/9.4/bin:$PATH
[root@localhost pg_repack]# type pg_config
pg_config is /opt/PostgreSQL/9.4/bin/pg_config

Teraz możemy wykonać polecenia instalacji źródłowej „make” i „make install”. Wykonajmy „make”

[root@localhost ~]# cd pg_repack/
[root@localhost pg_repack]# make
make[1]: Entering directory `/root/pg_repack/bin'
....
....
gcc -Wall -Wmissing-prototypes -Wpointer-arith -Wdeclaration-after-statement -Wendif-labels -Wmissing-format-attribute -Wformat-security -fno-strict-aliasing -fwrapv -O2 pg_repack.o pgut/pgut.o pgut/pgut-fe.o -L/opt/PostgreSQL/9.4/lib -lpq -L/opt/PostgreSQL/9.4/lib -L/opt/local/Current/lib -Wl,--as-needed -Wl,-rpath,'/opt/PostgreSQL/9.4/lib',--enable-new-dtags -lpgcommon -lpgport -lssl -lcrypto -lgssapi_krb5 -lz -ledit -lrt -lcrypt -ldl -lm -o pg_repack
/usr/bin/ld: cannot find -ledit
collect2: ld returned 1 exit status
make[1]: *** [pg_repack] Error 1
make[1]: Leaving directory `/root/pg_repack/bin'
make: *** [all] Error 2

Ups…!!, wygląda na to, że w katalogu lib PostgreSQL występuje błąd związany z brakiem biblioteki -ledit(libedit). Uruchommy to samo polecenie „ld -ledit” w trybie szczegółowym (-verbose), aby uzyskać więcej informacji, wypróbowane i nieudane poleceniem „make”.

[root@localhost pg_repack]# ld -ledit -verbose
GNU ld version 2.20.51.0.2-5.42.el6 20100205
...
...
...
==================================================
attempt to open /usr/x86_64-redhat-linux/lib64/libedit.so failed
attempt to open /usr/x86_64-redhat-linux/lib64/libedit.a failed
attempt to open /usr/local/lib64/libedit.so failed
attempt to open /usr/local/lib64/libedit.a failed
attempt to open /lib64/libedit.so failed
attempt to open /lib64/libedit.a failed
attempt to open /usr/lib64/libedit.so failed
attempt to open /usr/lib64/libedit.a failed
attempt to open /usr/x86_64-redhat-linux/lib/libedit.so failed
attempt to open /usr/x86_64-redhat-linux/lib/libedit.a failed
attempt to open /usr/lib64/libedit.so failed
attempt to open /usr/lib64/libedit.a failed
attempt to open /usr/local/lib/libedit.so failed
attempt to open /usr/local/lib/libedit.a failed
attempt to open /lib/libedit.so failed
attempt to open /lib/libedit.a failed
attempt to open /usr/lib/libedit.so failed
attempt to open /usr/lib/libedit.a failed
ld: cannot find -ledit

Dobra, teraz jest jasne, że szuka biblioteki libedit.so w katalogu lib PostgreSQL [/opt/PostgreSQL/9.4/lib]. Sprawdźmy, czy w tym katalogu znajduje się biblioteka.

[root@localhost pg_repack]# cd /opt/PostgreSQL/9.4/lib
[root@localhost lib]# ls -l libedit*
-rwxr-xr-x. 1 root daemon 254702 Mar 22 23:32 libedit.so.0

Ach, mamy „libedit.so.0”, ale nie „libedit.so” wymagane przez polecenie „make”. Tworzenie dowiązania symbolicznego powinno być szybkim rozwiązaniem.

[root@localhost lib]# ln -s libedit.so.0 libedit.so
[root@localhost lib]# ls -l libedit*
lrwxrwxrwx. 1 root root 12 May 19 22:25 libedit.so -> libedit.so.0
-rwxr-xr-x. 1 root daemon 254702 Mar 22 23:32 libedit.so.0

Uruchom ponownie polecenie „make”.

[root@localhost pg_repack]# make
make[1]: Entering directory `/root/pg_repack/bin'
gcc -Wall -Wmissing-prototypes -Wpointer-arith -Wdeclaration-after-statement -Wendif-labels -Wmissing-format-attribute -Wformat-security -fno-strict-aliasing -fwrapv -O2 pg_repack.o pgut/pgut.o pgut/pgut-fe.o -L/opt/PostgreSQL/9.4/lib -lpq -L/opt/PostgreSQL/9.4/lib -L/opt/local/Current/lib -Wl,--as-needed -Wl,-rpath,'/opt/PostgreSQL/9.4/lib',--enable-new-dtags -lpgcommon -lpgport -lssl -lcrypto -lgssapi_krb5 -lz -ledit -lrt -lcrypt -ldl -lm -o pg_repack
/usr/bin/ld: warning: libssl.so.1.0.0, needed by /opt/PostgreSQL/9.4/lib/libpq.so, may conflict with libssl.so.10
/lib64/libldap_r-2.4.so.2: undefined reference to `ber_sockbuf_io_udp'
collect2: ld returned 1 exit status
make[1]: *** [pg_repack] Error 1
make[1]: Leaving directory `/root/pg_repack/bin'
make: *** [all] Error 2

Ups…!!! interesujące, przeszedł błąd -ledit, a teraz raportuje o bibliotece libldap [ libldap_r-2.4.so.2 ]. Nie jestem pewien, dlaczego szuka w katalogu /lib64, gdy mój pg_config wskazuje na /opt/PostgreSQL/9.4/lib. Sprawdźmy, co mamy w obu lokalizacjach.

[root@localhost pg_repack]# ls -l /lib64/libldap*
lrwxrwxrwx. 1 root root 21 Jan 6 22:05 libldap-2.4.so.2 -> libldap-2.4.so.2.10.2
-rwxr-xr-x. 1 root root 329696 Oct 15 2014 libldap-2.4.so.2.10.2
lrwxrwxrwx. 1 root root 23 May 19 06:43 libldap_r-2.4.so.2 -> libldap_r-2.4.so.2.10.2
-rwxr-xr-x. 1 root root 351920 Oct 15 2014 libldap_r-2.4.so.2.10.2

[root@localhost pg_repack]# ls -l /opt/PostgreSQL/9.4/lib/libldap*
-rwxr-xr-x. 1 root daemon 404761 Mar 22 23:32 /opt/PostgreSQL/9.4/lib/libldap-2.4.so.2
-rwxr-xr-x. 1 root daemon 442657 Mar 22 23:32 /opt/PostgreSQL/9.4/lib/libldap_r-2.4.so.2

Wygląda na to, że istnieją dwie kopie „libldap_r-2.4.so.2”, jedna w formie dowiązania symbolicznego, a druga w formie papierowej. Zgaduję, że jest to spowodowane wieloma kopiami biblioteki, usuńmy dowiązanie symboliczne i zachowajmy wydruk biblioteki i spróbuj ponownie.

[root@localhost lib64]# unlink libldap_r-2.4.so.2

[root@localhost pg_repack]# make
make[1]: Entering directory `/root/pg_repack/bin'
....
....
....
sed 's,REPACK_VERSION,1.3.1,g' pg_repack.sql.in > pg_repack--1.3.1.sql;
sed 's,REPACK_VERSION,1.3.1,g' pg_repack.control.in > pg_repack.control
make[1]: Leaving directory `/root/pg_repack/lib'
make[1]: Entering directory `/root/pg_repack/regress'
make[1]: Nothing to be done for `all'.
make[1]: Leaving directory `/root/pg_repack/regress'

wow… w końcu się skompilowało. Uruchom „make install” dla plików binarnych i bibliotek pg_repack.

[root@localhost pg_repack]# make install
make[1]: Entering directory `/root/pg_repack/bin'
/bin/mkdir -p '/opt/PostgreSQL/9.4/bin'
/usr/bin/install -c pg_repack '/opt/PostgreSQL/9.4/bin'
make[1]: Leaving directory `/root/pg_repack/bin'
make[1]: Entering directory `/root/pg_repack/lib'
/bin/mkdir -p '/opt/PostgreSQL/9.4/lib/postgresql'
/bin/mkdir -p '/opt/PostgreSQL/9.4/share/postgresql/extension'
/bin/mkdir -p '/opt/PostgreSQL/9.4/share/postgresql/extension'
/usr/bin/install -c -m 755 pg_repack.so '/opt/PostgreSQL/9.4/lib/postgresql/pg_repack.so'
/usr/bin/install -c -m 644 pg_repack.control '/opt/PostgreSQL/9.4/share/postgresql/extension/'
/usr/bin/install -c -m 644 pg_repack--1.3.1.sql pg_repack.control '/opt/PostgreSQL/9.4/share/postgresql/extension/'
make[1]: Leaving directory `/root/pg_repack/lib'
make[1]: Entering directory `/root/pg_repack/regress'
make[1]: Nothing to be done for `install'.
make[1]: Leaving directory `/root/pg_repack/regress'

Po kompilacji będzie narzędzie pg_repack w $PGHOME/bin oraz biblioteka pg_repack.so w katalogu $PGHOME/lib/postgresql/.

[root@localhost pg_repack]# ls -l /opt/PostgreSQL/9.4/bin/pg_rep*
-rwxr-xr-x. 1 root root 84030 May 20 00:07 /opt/PostgreSQL/9.4/bin/pg_repack

[root@localhost postgresql]# ls -l /opt/PostgreSQL/9.4/lib/postgresql/pg_rep*
-rwxr-xr-x. 1 root root 31028 May 20 00:07 /opt/PostgreSQL/9.4/lib/postgresql/pg_repack.so

Teraz możemy utworzyć rozszerzenie pg_repack w bazie danych.

-bash-4.1$ psql
Password:
psql.bin (9.4.1)
Type "help" for help.

postgres=# select * from pg_available_extensions where name='pg_repack';
name | default_version | installed_version | comment
-----------+-----------------+-------------------+--------------------------------------------------------------
pg_repack | 1.3.1 | 1.3.1 | Reorganize tables in PostgreSQL databases with minimal locks
(1 row)

postgres=# create extension pg_repack;
CREATE EXTENSION

Podobnie próbowałem skompilować prekompilowany pakiet binarny za pomocą produktu EnterpriseDB PostgresPlus Advanced Server 9.4[PPAS]. Miałem podobne problemy z biblioteką, dlatego użyłem opcji linkera „LDFLAGS” wskazującej na katalog biblioteki i skompilowałem.

[root@localhost ~]# export PATH=/opt/PostgresPlus/9.4AS/bin:$PATH
[root@localhost ~]# export LDFLAGS=-L/opt/PostgresPlus/9.4AS/lib
[root@localhost ~]# cd pg_repack/
[root@localhost pg_repack]# make
[root@localhost pg_repack]# make install


[root@localhost pg_repack]# ls -l /opt/PostgresPlus/9.4AS/bin/pg_rep*
-rwxr-xr-x. 1 root root 201877 May 15 11:06 /opt/PostgresPlus/9.4AS/bin/pg_repack
[root@localhost pg_repack]# ls -l /opt/PostgresPlus/9.4AS/lib/pg_rep*
-rwxr-xr-x. 1 root root 94516 May 15 11:06 /opt/PostgresPlus/9.4AS/lib/pg_repack.so

Fajnie, to też skompilowane gładko. Teraz utwórz rozszerzenie w PPAS 9.4

-bash-4.1$ psql
Welcome
psql.bin (9.4.1.4)
Type "help" for help.

edb=# create extension pg_repack;
CREATE EXTENSION
edb=#

Dziękuję.


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Instalowanie sterowników PDO dla PostgreSQL na Macu (używając Zend dla Eclipse)

  2. GROUP BY w Postgres - brak równości dla typu danych JSON?

  3. Sortowanie alfanumeryczne w PostgreSQL

  4. Nie można połączyć się z serwerem Postgres w dockerze z zadokowanej aplikacji

  5. Wyzwalacz Postgres po uzyskaniu dostępu do insertu NOWOŚĆ