2012-06-08 251 views
1

我一直在尝试在Centos 6.2上安装Oracle 11g R2一段时间。我知道Oracle发行版没有通过Centos认证(但是它已经通过了RHEL认证),因此我并不期望这是简单明了的。不过,我总算通过固定大多认为到来的时候,除了现在的问题以完成安装,当我尝试运行SQL * Plus中我得到这个恼人的消息:在Centos上安装Oracle 11g

[[email protected] ~]$ sqlplus 
sqlplus: error while loading shared libraries: libclntsh.so.11.1: wrong ELF class: ELFCLASS64 

我认为这指出了一个损坏文件,但是我已经从Oracle网站复制了该文件,但仍无济于事。下面有一些有趣的结果,请注意ldd根本没有找到这个文件,尽管它在lib文件夹中。

[[email protected] ~]$ echo $LD_LIBRARY_PATH 
/u01/app/oracle/product/11.2.0/dbhome_1/lib:/lib:/usr/lib </code> 
[[email protected] lib]$ ldd $ORACLE_HOME/bin/sqlplus 
linux-gate.so.1 => (0x00497000) 
libsqlplus.so => /u01/app/oracle/product/11.2.0/dbhome_1/lib/libsqlplus.so (0x00110000) 
libclntsh.so.11.1 => not found 
libnnz11.so => /u01/app/oracle/product/11.2.0/dbhome_1/lib/libnnz11.so (0x001c0000) 
libdl.so.2 => /lib/libdl.so.2 (0x00d5c000) 
libm.so.6 => /lib/libm.so.6 (0x0040d000) 
libpthread.so.0 => /lib/libpthread.so.0 (0x00d63000) 
libnsl.so.1 => /lib/libnsl.so.1 (0x00eae000) 
libc.so.6 => /lib/libc.so.6 (0x00bca000) 
/lib/ld-linux.so.2 (0x00ba8000) 
libclntsh.so.11.1 => not found 
[[email protected] lib]$ ls -ll | grep libclntsh.so.11.1 <br/> 
-rwxr-xr-x 1 oracle oinstall 52761218 Jun 7 22:27 libclntsh.so.11.1</code> 

任何指针将不胜感激。

我也粘贴输出下方ID和env

[[email protected] ~]$ id 
uid=501(oracle) gid=501(oinstall) groups=501(oinstall),502(dba) 


[[email protected] ~]$ env 
ORBIT_SOCKETDIR=/tmp/orbit-oracle 
HOSTNAME=centos 
IMSETTINGS_INTEGRATE_DESKTOP=yes 
TERM=xterm 
SHELL=/bin/bash 
XDG_SESSION_COOKIE=9265be1ee083d7ad74d1cee300000019-1339121593.639472-887657473 
HISTSIZE=1000 
TMPDIR=/tmp 
ORACLE_UNQNAME=DB11G 
GTK_RC_FILES=/etc/gtk/gtkrc:/home/oracle/.gtkrc-1.2-gnome2 
WINDOWID=39845891 
QTDIR=/usr/lib64/qt-3.3 
QTINC=/usr/lib64/qt-3.3/include 
IMSETTINGS_MODULE=none 
USER=oracle 
LS_COLORS=rs=0:di=01;34:ln=01;36:mh=00:pi=40;33:so=01;35:do=01;35:bd=40;33;01:cd=40;33;01:or=40;31;01:mi=01;05;37;41:su=37;41:sg=30;43:ca=30;41:tw=30;42:ow=34;42:st=37;44:ex=01;32:*.tar=01;31:*.tgz=01;31:*.arj=01;31:*.taz=01;31:*.lzh=01;31:*.lzma=01;31:*.tlz=01;31:*.txz=01;31:*.zip=01;31:*.z=01;31:*.Z=01;31:*.dz=01;31:*.gz=01;31:*.lz=01;31:*.xz=01;31:*.bz2=01;31:*.tbz=01;31:*.tbz2=01;31:*.bz=01;31:*.tz=01;31:*.deb=01;31:*.rpm=01;31:*.jar=01;31:*.rar=01;31:*.ace=01;31:*.zoo=01;31:*.cpio=01;31:*.7z=01;31:*.rz=01;31:*.jpg=01;35:*.jpeg=01;35:*.gif=01;35:*.bmp=01;35:*.pbm=01;35:*.pgm=01;35:*.ppm=01;35:*.tga=01;35:*.xbm=01;35:*.xpm=01;35:*.tif=01;35:*.tiff=01;35:*.png=01;35:*.svg=01;35:*.svgz=01;35:*.mng=01;35:*.pcx=01;35:*.mov=01;35:*.mpg=01;35:*.mpeg=01;35:*.m2v=01;35:*.mkv=01;35:*.ogm=01;35:*.mp4=01;35:*.m4v=01;35:*.mp4v=01;35:*.vob=01;35:*.qt=01;35:*.nuv=01;35:*.wmv=01;35:*.asf=01;35:*.rm=01;35:*.rmvb=01;35:*.flc=01;35:*.avi=01;35:*.fli=01;35:*.flv=01;35:*.gl=01;35:*.dl=01;35:*.xcf=01;35:*.xwd=01;35:*.yuv=01;35:*.cgm=01;35:*.emf=01;35:*.axv=01;35:*.anx=01;35:*.ogv=01;35:*.ogx=01;35:*.aac=01;36:*.au=01;36:*.flac=01;36:*.mid=01;36:*.midi=01;36:*.mka=01;36:*.mp3=01;36:*.mpc=01;36:*.ogg=01;36:*.ra=01;36:*.wav=01;36:*.axa=01;36:*.oga=01;36:*.spx=01;36:*.xspf=01;36: 
ORACLE_SID=DB11G 
GNOME_KEYRING_SOCKET=/tmp/keyring-rhL82I/socket 
SSH_AUTH_SOCK=/tmp/keyring-rhL82I/socket.ssh 
ORACLE_HOSTNAME=ol5-112.localdomain 
ORACLE_BASE=/u01/app/oracle 
SESSION_MANAGER=local/unix:@/tmp/.ICE-unix/2361,unix/unix:/tmp/.ICE-unix/2361 
USERNAME=oracle 
DESKTOP_SESSION=gnome 
MAIL=/var/spool/mail/oracle 
PATH=/u01/app/oracle/product/11.2.0/dbhome_1/bin:/usr/sbin:/usr/lib64/qt-3.3/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin:/u01/app/oracle/product/11.2.0/dbhome_1/bin:/home/oracle/bin 
QT_IM_MODULE=xim 
PWD=/home/oracle 
[email protected]=none 
GDM_KEYBOARD_LAYOUT=us 
LANG=en_US.UTF-8 
GNOME_KEYRING_PID=2352 
GDM_LANG=en_US.UTF-8 
GDMSESSION=gnome 
SSH_ASKPASS=/usr/libexec/openssh/gnome-ssh-askpass 
HISTCONTROL=ignoredups 
HOME=/home/oracle 
SHLVL=2 
GNOME_DESKTOP_SESSION_ID=this-is-deprecated 
LOGNAME=oracle 
TMP=/tmp 
QTLIB=/usr/lib64/qt-3.3/lib 
CVS_RSH=ssh 
CLASSPATH=/u01/app/oracle/product/11.2.0/dbhome_1/jlib:/u01/app/oracle/product/11.2.0/dbhome_1/rdbms/jlib 
DBUS_SESSION_BUS_ADDRESS=unix:abstract=/tmp/dbus-XYJwhzf59A,guid=01cea4b5cde33013e1cab40300000023 
LESSOPEN=|/usr/bin/lesspipe.sh %s 
WINDOWPATH=1 
DISPLAY=:0.0 
ORACLE_HOME=/u01/app/oracle/product/11.2.0/dbhome_1 
G_BROKEN_FILENAMES=1 
XAUTHORITY=/var/run/gdm/auth-for-oracle-lg5ZGT/database 
COLORTERM=gnome-terminal 
_=/bin/env 
+0

这是SO的话题;属于[sf] –

+0

您的LD_LIBRARY_PATH看起来不正确。它找不到库libclntsh.so.11.1 – steve

回答

1

11gR2的是不是一个版本。你在安装什么具体版本?

请注意,您必须拥有最新的11gR2版本11.2.0.3.0。

11.2.0.x.0,其中x < 3不受RHEL 6.x(或CentOS 6.x)或Oracle Linux 6.x支持。

此外,请确保您正在运行64位Linux。

希望有所帮助。

+0

得到它与11.2.0.3.0一起工作,谢谢! –

0

是centos box是64bit还是32bit安装。看起来像oracle安装是64位,但机器上的操作系统不是。您可以在64位操作系统上运行32位服务器,但不能以其他方式运行。如果你想使用32bit的centos,你需要安装32bit的oracle 11.

0

这是一个经典的ldconfig问题。

执行以下操作:

1)找到缺少的库“你的情况” libclntsh.so.11.1',有可能是其他人(检查LDD输出正如你所提到)。

对于这一点,使用'发现 '' 或 '' 查找 '' 命令:

查找/ -name libclntsh.so.11.1 *

2)记下目录的那包含缺少的库,可能有多个目录。

3)在目录/etc/ldd.so.conf.d/ 中创建一个名为(例如)oracle64.conf的文件,并将该文件中的所有目录(每行一个目录!)。

4)以root身份运行''ldconfig''。

5)在''sqlplus''上执行'ldd'',现在应该正确配置丢失的库。

6)正常运行sqlplus。

7)利润! ;-)

希望这会有所帮助。