sql >> Databáze >  >> RDS >> PostgreSQL

CHYBA:Nelze načíst knihovnu „/opt/PostgreSQL/9.0/lib/postgresql/plperl.so“:libperl.so:

Výše uvedená chyba, když jsem se snažil vytvořit jazyk plperlu. Znamená to, že chybí knihovna libperl.so. Podívejte se na kroky provedené k překonání tohoto problému a úspěšnému vytvoření jazyka plperlu v PostgreSQL.

Metoda 1 (vyhledání souboru libperl.so a vytvoření softwarového odkazu na toto umístění)

postgres=# create LANGUAGE plperlu;
ERROR: could not load library "/opt/PostgreSQL/9.0/lib/postgresql/plperl.so": libperl.so: cannot open shared object file: No such file or directory
postgres=# q

Nyní vyhledejte v krabici soubor libperl.so a přidejte toto umístění do své LD_LIBRARY PATH. Nezapomeňte přepnout uživatele na postgres.

[root@localhost /]# find -name libperl.so
./usr/lib/perl5/5.10.0/i386-linux-thread-multi/CORE/libperl.so
./usr/lib/perl5/CORE/libperl.so
./usr/lib/perl5/5.10.0/i386-linux-thread-multi/CORE

[root@localhost /]# su - postgres

Nastavte LD_LIBRARY_PATH

-bash-4.1$ export LD_LIBRARY_PATH=/usr/lib/perl5/5.10.0/i386-linux-thread-multi/CORE:$LD_LIBRARY_PATH

Restartujte cluster, aby se změny projevily.

-bash-4.1$ pg_ctl restart
waiting for server to shut down....... done
server stopped
server starting

Nyní jste připraveni vytvořit jazyk.

-bash-4.1$ psql
psql (9.0.1)
Type "help" for help.

postgres=# create LANGUAGE plperlu;
CREATE LANGUAGE

Metoda 2 (instalací nejnovější verze ActivePerl)

Krok 1:
Po instalaci ActivePerl nastavte LD_LIBRARY_PATH.

postgres@localhost:/opt/ActivePerl-5.12/lib/CORE> export LD_LIBRARY_PATH=/opt/ActivePerl-5.12/lib/CORE:/opt/PostgreSQL/9.0/lib/postgresql

Krok 2:

postgres@localhost:/opt/PostgreSQL/9.0/lib/postgresql> ldd plperl.so 
linux-vdso.so.1 => (0x00007fff8cf79000)
libperl.so => /opt/ActivePerl-5.12/lib/CORE/libperl.so (0x00007fbd3d654000)
libnsl.so.1 => /lib64/libnsl.so.1 (0x00007fbd3d40a000)
libdl.so.2 => /lib64/libdl.so.2 (0x00007fbd3d206000)
libm.so.6 => /lib64/libm.so.6 (0x00007fbd3cfb0000)
libcrypt.so.1 => /lib64/libcrypt.so.1 (0x00007fbd3cd74000)
libutil.so.1 => /lib64/libutil.so.1 (0x00007fbd3cb71000)
libpthread.so.0 => /lib64/libpthread.so.0 (0x00007fbd3c954000)
libc.so.6 => /lib64/libc.so.6 (0x00007fbd3c5f5000)
/lib64/ld-linux-x86-64.so.2 (0x00007fbd3dad8000)

Krok 3:

postgres@localhost:/opt/PostgreSQL/9.0/lib/postgresql> pg_ctl restart
postgres@localhost:/opt/PostgreSQL/9.0/lib/postgresql> psql
psql (9.0.2)
Type "help" for help.

postgres=# create language plperlu;
CREATE LANGUAGE

Pište své komentáře.


  1. Řídké sloupce v SQL Server:Dopad na čas a prostor

  2. Vzorec Pearsonova korelačního koeficientu v SQL

  3. Jak zakázat všechny spouštěče v databázi SQL Server

  4. Získejte datum začátku týdne a datum konce týdne z čísla týdne