欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

CentOS8下安装oracle客户端完整(填坑)过程分享(推荐)

程序员文章站 2022-07-06 10:30:44
oracle32位客户端安装 首先uname -a linux localhost.localdomain 4.18.0-80.el8.x86_64 #1 smp tue...

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-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: 沒有此一檔案或目錄

排查原因,这位老哥让我死心了:

老老实实卸载重装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-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

原来我们公司服务器oracle也是64位t-t。。。。

总结

以上所述是小编给大家介绍的centos8下安装oracle客户端完整(填坑)过程分享,希望对大家有所帮助!