Linux安装cx_Oracles

简介:

Linux安装cx_Oracles

环境背景

系统:CentOS6.8

python:Python 2.7.13 |Anaconda 4.3.1 (64-bit)

cx_Oracle模块:5.0.4

Oracle:11.2.0.1.0

Oracle客户端:11.2.0.1.0

1、下载

http://www.oracle.com/technetwork/topics/linuxx86-64soft-092277.html

从 下载链接 下载下面两个文件

1
2
3
oracle-instantclient11.2-basic-11.2.0.1.0-1.x86_64.zip 
instantclient-sdk-linux.x64-11.2.0.1.0.zip
#注这里要根据连接数据库的版本来定,安装的客户端一定要选择基础版本,不要选instantclient11.2-basiclite


解压这两个文件到/opt/instantclient_11_2目录下

2、设置环境变量

1
2
3
4
# vim /etc/profile #文件尾部添加
export  ORACLE_HOME= /opt/instantclient_11_2/
export  LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$ORACLE_HOME
# source /etc/profile

3、安装cx_Oracle

安装cx_Oracle之前需要先建立一个链接libclntsh.so,如下:

1
2
cd  /opt/instantclient_11_2/
ln  -s libclntsh.so.11.1 libclntsh.so

下载cx_Oracle

https://sourceforge.net/projects/cx-oracle/files/5.0.4/

1
2
3
# tar -xf cx_Oracle-5.0.4.tar.gz
# cd cx_Oracle-5.0.4
# python setup.py install

测试:

1
2
3
4
5
>>>  import  cx_Oracle
/root/ .pyenv /versions/anaconda2-4 .3.1 /lib/python2 .7 /site-packages/cx_Oracle-5 .0.4-py2.7-linux-x86_64.egg /cx_Oracle .py:3: UserWarning: Module cx_Oracle was already imported from  /root/ .pyenv /versions/anaconda2-4 .3.1 /lib/python2 .7 /site-packages/cx_Oracle-5 .0.4-py2.7-linux-x86_64.egg /cx_Oracle .pyc, but  /opt/cx_Oracle-5 .0.4 is being added to sys.path
>>>
>>> print cx_Oracle.version
5.0.4

4、测试数据库连接

1
2
3
4
5
>>>  import  cx_Oracle as cx
>>> db=cx.connect( 'finchina/123456@192.168.1.236/orcl' )
>>> print db.version
11.2.0.1.0
>>> db.close()

FAQ整理:

问题1: conn0=cx.connect('finchina/123456@192.168.1.236:1521/orcl')

cx_Oracle.InterfaceError: Unable to acquire Oracle environment handle

解决方案:这里要保证你安装的instantclient和需要连接的数据库版本一致。下载

1
2
3
4
5
oracle-instantclient11.2-basic-11.2.0.1.0-1.x86_64.zip 
instantclient-sdk-linux.x64-11.2.0.1.0.zip
 
windows出现这个问题
复制 client下所有的.dll文件到python安装包site_pageages目录中即可

然后按照上文进行配置就即可。

问题2: conn0=cx.connect('finchina/123456@192.168.1.236:1521/orcl')

cx_Oracle.DatabaseError: ORA-28547: connection to server failed, probable Oracle Net admin error

解决方案:

重新安装 cx_Oracle5.0.4

重装安装 instantclient11.2-basic

下面选段来自Oracle客户端下载地址:http://www.oracle.com/technetwork/topics/linuxx86-64soft-092277.html

1
2
3
4
5
6
7
8
Instant Client Package - Basic: All files required to run OCI, OCCI, and JDBC-OCI applications
#注释:即时客户端软件包 - 基本:运行OCI,OCCI和JDBC-OCI应用程序所需的所有文件
oracle-instantclient11.2-basic-11.2.0.1.0-1.x86_64.zip (48,338,185 bytes) (cksum - 15985569)
oracle-instantclient11.2-basic-11.2.0.1.0-1.x86_64.rpm (47,811,007 bytes) (cksum - 4244105838)
Instant Client Package - Basic Light: Smaller version of the Basic, with only English error messages and Unicode, ASCII, and Western European character  set  support
#注释:即时客户端软件包 - 基本轻量:较小版本的Basic,只有英文错误消息和Unicode,ASCII和西欧字符集支持,阿西吧!,原来是字符集问题
oracle-instantclient11.2-basiclite-11.2.0.1.0-1.x86_64.zip (20,825,489 bytes) (cksum - 133027975)
oracle-instantclient11.2-basiclite-11.2.0.1.0-1.x86_64.rpm (20,649,392 bytes) (cksum - 1121446971)

总结:

问题很严重,遇到问题,胡乱百度,无思路的Google,反而拖慢解决问题的节奏。希望这次之后,遇到任何问题都能:理清思路,将问题拆分,然后逐个击破

问题3:ImportError: libclntsh.so.11.1: cannot open shared object file: No such file or directory

解决方案:

1
2
cd  /opt/instantclient_11_2
ln  -sv libclntsh.so.11.1 libclntsh.so



本文转自 ljohnmail 51CTO博客,原文链接:http://blog.51cto.com/ljohn/1940904,如需转载请自行联系原作者
相关文章
|
7天前
|
安全 Linux iOS开发
Nessus Professional 10.10 Auto Installer for RHEL 10, AlmaLinux 10, Rocky Linux 10 - Nessus 自动化安装程序
Nessus Professional 10.10 Auto Installer for RHEL 10, AlmaLinux 10, Rocky Linux 10 - Nessus 自动化安装程序
56 6
Nessus Professional 10.10 Auto Installer for RHEL 10, AlmaLinux 10, Rocky Linux 10 - Nessus 自动化安装程序
|
2月前
|
Ubuntu Linux
计算机基础知识:linux系统怎么安装?
在虚拟机软件中创建一个新的虚拟机,并选择相应操作系统类型和硬盘空间大小等参数。将下载的 ISO 镜像文件加载到虚拟机中。启动虚拟机,进入安装界面,并按照步骤进行安装。安装完成后,可以在虚拟机中使用 Linux 系统。
|
2月前
|
Ubuntu Linux
任何Ubuntu用户都应安装的四大Linux应用程序
当然,这款程序不需要太多介绍。我们面对的是网上最庞大最完整的多媒体中心,由于丰富的插件,我们能够高度细化地定制其每一项功能。这是我们的Linux发行版不可或缺的必备软件。 我们可以通过运行以下命令来轻松安装Kodi:sudo apt install kodi。
|
2月前
|
Ubuntu 物联网 Linux
从零安装一个Linux操作系统几种方法,以Ubuntu18.04为例
一切就绪后,我们就可以安装操作系统了。当系统通过优盘引导起来之后,我们就可以看到跟虚拟机中一样的安装向导了。之后,大家按照虚拟机中的顺序安装即可。 好了,今天主要介绍了Ubuntu Server版操作系统的安装过程,关于如何使用该操作系统,及操作系统更深层的原理,还请关注本号及相关圈子。
|
2月前
|
Ubuntu Linux 网络安全
Linux服务器之Ubuntu的安装与配置
Ubuntu Desktop是目前最成功、最流行的图形界面的Linux发行版;而Ubuntu Server也在服务器端市场占据了较大的份额。今天为大家详细介绍了Ubuntu Server的安装与配置,希望对你能有所帮助。关于VMware、VirtualBox等虚拟化软件的使用,朱哥还会在后续的文章中为大家详细介绍,敬请关注!
|
3月前
|
Linux 网络安全 Apache
针对在Centos/Linux安装Apache过程中出现的常见问题集锦
以上每个问题的解决方案应深入分析错误日志、系统消息和各种配置文件,以找到根本原因并加以解决。务必保持系统和Apache软件包更新到最新版本,以修复已知的bugs和安全漏洞。安装和管理Web服务器是一项需要细致关注和不断学习的任务。随着技术的发展,推荐定期查看官方文档和社区论坛,以保持知识的更新。
200 80
|
7天前
|
消息中间件 Kafka Linux
Linux下安装Kafka 3.9.1
本文介绍Kafka 3.9.1版本的安装与配置,包括通过ZooKeeper或KRaft模式启动Kafka。涵盖环境变量设置、日志路径修改、集群UUID生成、存储格式化及服务启停操作,适用于Linux环境下的部署实践。
132 0
|
2月前
|
网络协议 关系型数据库 Linux
【App Service Linux】在Linux App Service中安装 tcpdump 并抓取网络包
在App Service for Linux环境中,无法像Windows一样直接使用网络排查工具抓包。本文介绍了如何通过TCPDUMP在Linux环境下抓取网络包,包括SSH进入容器、安装tcpdump、执行抓包命令及下载分析文件的完整操作步骤。
157 5
|
2月前
|
弹性计算 安全 Linux
阿里云服务器ECS安装宝塔Linux面板、安装网站(新手图文教程)
本教程详解如何在阿里云服务器上安装宝塔Linux面板,涵盖ECS服务器手动安装步骤,包括系统准备、远程连接、安装命令执行、端口开放及LNMP环境部署,手把手引导用户快速搭建网站环境。