怎么在CentOS8系统中安装oracle客户端

88次阅读
没有评论

共计 4625 个字符,预计需要花费 12 分钟才能阅读完成。

自动写代码机器人,免费开通

怎么在 CentOS8 系统中安装 oracle 客户端?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

oracle32 位客户端安装

首先 uname -a

Linux localhost.localdomain 4.18.0-80.el8.x86_64 #1 SMP Tue Jun 4
09:19:46 UTC 2019 x86_64 x86_64 x86_64 GNU/Linux

cat /etc/redhat-release

CentOS Linux release 8.0.1905 (Core)

可以看到我的电脑是 64 位,系统版本是 CentOS8,然而服务器 oracle 数据库是 32 位的,所以我首先想到安装 32 位的 oracle 客户端

进入 oracle 官网下载

oracle-instantclient19.5-basic-19.5.0.0.0-1.i386.rpm
oracle-instantclient19.5-sqlplus-19.5.0.0.0-1.i386.rpm
oracle-instantclient19.5-devel-19.5.0.0.0-1.i386.rpm(听别人说这个包也可以不下,我懒,不试)

rpm 格式包详解

oracle-instantclient19.5-basic-19.5.0.0.0-1.i386.rpm
–基础包,为了运行 OCI、OCCI、JDBC-OCI  这几个应用程序;oracle-instantclient19.5-sqlplus-19.5.0.0.0-1.i386.rpm
–补充包 / 文件,是为了运行 sql*plus 的即时客户端;oracle-instantclient19.5-devel-19.5.0.0.0-1.i386.rpm
–包含头文件和示例文件,为开发 Oracle 应用程序的即时客户端;oracle-instantclient19.5-odbc-19.5.0.0.0-1.i386.rpm
–补充包 / 文件,为运行 ODBC 环境附加库;oracle-instantclient19.5-jdbc-19.5.0.0.0-1.i386.rpm
–补充 JDBC 下的 XA、国际标准、行集操作;

依次安装

rpm -ivh oracle-instantclient19.5-basic-19.5.0.0.0-1.i386.rpm
rpm -ivh oracle-instantclient19.5-sqlplus-19.5.0.0.0-1.i386.rpm
rpm -ivh oracle-instantclient19.5-devel-19.5.0.0.0-1.i386.rpm

安装的文件默认放在两个位置:

头文件:/usr/include/oracle/19.5/client/ 下,如果在使用时报错找不到头文件,记得看路径是否是这个。

包文件:/usr/lib/oracle/19.5/client/ 下,包含 {bin、lib} 两个文件夹;

创建监听文件,并添加内容

vim /usr/lib/oracle/19.5/client/lib/network/admin/tnsnames.ora
ORCL =
 (DESCRIPTION =
 (ADDRESS = (PROTOCOL = TCP)(HOST = *IP*)(PORT = 1521))
 (CONNECT_DATA =
 (SERVER = DEDICATED)
 (SERVICE_NAME = *SID*)
 )
 )

这里我是要连公司的 oracle 服务器,所以是直接复制服务器下的 tnsnames.ora 文件放到 admin 下就可以了

配置环境变量 vim /etc/profile,添加

#oracle19.5
export ORACLE_BASE=/usr/lib/oracle/19.5
export ORACLE_VERSION=19.5
export ORACLE_HOME=/usr/lib/oracle/$ORACLE_VERSION/client
export LD_LIBRARY_PATH=$ORACLE_HOME/lib:$LD_LIBRARY_PATH
export SQLPATH=$ORACLE_HOME/lib/network/admin
export TNS_ADMIN=$ORACLE_HOME/lib/network/admin
export NLS_LANG=AMERICAN_AMERICA.AL32UTF8
#export NLS_LANG= Simplified Chinese_china .ZHS16GBK
export PATH=$PATH:$HOME/bin:$ORACLE_HOME/bin

配置保存后

source /etc/profile

即可使配置即时生效

之后连接数据库测试

sqlplus /nolog

尴尬,提示:

bash: /bin/sqlplus: 沒有此一檔案或目錄

排查原因,这位老哥让我死心了:ubuntu 14.04 oracle 11g 64 位数据库安装图文教程

老老实实卸载重装 64 位嗷 T_T

oracle64 位客户端安装

先看看安装了哪些

rpm -qa | grep oracle

发现 3 个待宰羔羊

oracle-instantclient19.5-sqlplus-19.5.0.0.0-1.i386
oracle-instantclient19.5-basic-19.5.0.0.0-1.i386
oracle-instantclient19.5-devel-19.5.0.0.0-1.i386

考虑到三者之间可能会有依赖关系,rpm - e 不够强力,所以直接加上–nodeps,简单粗暴

rpm -e --nodeps oracle-instantclient19.5-sqlplus-19.5.0.0.0-1.i386
rpm -e --nodeps oracle-instantclient19.5-basic-19.5.0.0.0-1.i386
rpm -e --nodeps oracle-instantclient19.5-devel-19.5.0.0.0-1.i386

然后老套路,下载 64 位包:oracle 官网下载

oracle-instantclient19.5-basic-19.5.0.0.0-1.x86_64.rpm
oracle-instantclient19.5-sqlplus-19.5.0.0.0-1.x86_64.rpm
oracle-instantclient19.5-devel-19.5.0.0.0-1.x86_64.rpm

安装

rpm -ivh oracle-instantclient19.5-basic-19.5.0.0.0-1.x86_64.rpm
rpm -ivh oracle-instantclient19.5-sqlplus-19.5.0.0.0-1.x86_64.rpm
rpm -ivh oracle-instantclient19.5-devel-19.5.0.0.0-1.x86_64.rpm

创建监听文件,并添加内容,这边 19.5 后面的 client 多了个 64~

vim /usr/lib/oracle/19.5/client64/lib/network/admin/tnsnames.ora 加入
ORCL =
 (DESCRIPTION =
 (ADDRESS = (PROTOCOL = TCP)(HOST = *IP*)(PORT = 1521))
 (CONNECT_DATA =
 (SERVER = DEDICATED)
 (SERVICE_NAME = *SID*)
 )
 )

这里我是要连公司的 oracle 服务器,所以是直接复制服务器下的 tnsnames.ora 文件来用就可以了

配置环境变量 vim /etc/profile,添加

#oracle19.5
export ORACLE_BASE=/usr/lib/oracle/19.5
export ORACLE_VERSION=19.5
export ORACLE_HOME=/usr/lib/oracle/$ORACLE_VERSION/client64
export LD_LIBRARY_PATH=$ORACLE_HOME/lib:$LD_LIBRARY_PATH
export SQLPATH=$ORACLE_HOME/lib/network/admin
export TNS_ADMIN=$ORACLE_HOME/lib/network/admin
export NLS_LANG=AMERICAN_AMERICA.AL32UTF8
#export NLS_LANG= Simplified Chinese_china .ZHS16GBK
export PATH=$PATH:$HOME/bin:$ORACLE_HOME/bin

配置保存后

source /etc/profile

即可使配置即时生效

之后连接数据库测试

sqlplus /nolog
sqlplus: error while loading shared libraries: libnsl.so.1: cannot open shared object file: No such file or directory

咋又报错了,我容易吗我,555~

可以看到,这个错误的关键字是 libnsl.so.1,biying 一下~

原来是缺少库文件

这里安装库包

dnf install libnsl

再输入

sqlplus /nolog
SQL*Plus: Release 19.0.0.0.0 - Production on Sat Dec 28 14:21:33 2019
Version 19.5.0.0.0
Copyright (c) 1982, 2019, Oracle. All rights reserved.
SQL

到这里证明已经安装成功,远程连接可用如下形式:

sqlplus scott/123456:192.168.111.111:1521/orcl

按理来说目前我是可以连接 oracle 数据库了,但是,没有那么简单。。。。输入连接命令后提示:

ERROR:
ORA-12170: TNS:Connect timeout occurred

照例,biying 一下~

这位老哥说的不错,ORA-12170:TNS connect timeout occurred

果然,ping 不通服务器。

下面就是联系网管打一顿了

~————————————-

ping 通网络后,连接如下

Connected to:
Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 – 64bit Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options

关于怎么在 CentOS8 系统中安装 oracle 客户端问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注丸趣 TV 行业资讯频道了解更多相关知识。

向 AI 问一下细节

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-12-04发表,共计4625字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)