python 安装cx_oracle_python 安装cx_Oracle模块, MySQLdb模块, Tornado

本文详细介绍了在没有root权限的情况下,如何在Python中安装cx_Oracle模块来连接Oracle数据库,包括设置Oracle Instant Client、解决依赖问题和配置环境变量。同时,还提及了安装MySQLdb模块以及Tornado非阻塞web服务器的步骤。最后,提到了使用IPython进行交互式Spark操作。
摘要由CSDN通过智能技术生成

一,想访问远程Oracle数据库,本地又不想安装几百兆的Oracle Client(也木有root权限),安装python的cx_Oralce 模块需要依赖Oracle Instant Client 代替完整的Oracle Client。

下载:

instantclient-basic-linux.x64-11.2.0.4.0.zip

instantclient-sqlplus-linux.x64-11.2.0.4.0.zip

instantclient-sdk-linux.x64-11.2.0.4.0.zip

解压文件放到如下目录:

$HOME/oracle/instantclient_11_2

拷贝tnsnames.ora文件,在/home/oracle/instantclient_11_2目录下创建network/admin目录,并将tnsnames.ora文件拷贝进去(这个貌似不是必要条件,出了问题的话就补上吧)

~/.bashrc设置:

export ORACLE_HOME=$HOME/oracle/instantclient_11_2export TNS_ADMIN=$ORACLE_HOME/network/admin

export DYLD_LIBRARY_PATH=$ORACLE_HOME

export PATH=$ORACLE_HOME:$PATH

下面就是该安装cx_Oracle的python模块了,下载直接python setup.py install

由于非root的权限,会报无/lib64/python2.6/site-packages/目录读写权限

可以改写python的安装目录

export PYTHONPATH=$HOME/.local/lib64/python2.6/site-packages/

export PATH=$HOME/.local/bin:$PATH

然后source .bashrc生效

接下来可以安装了:python setup.py install --prefix=~/.local (牛逼闪闪啊,直接在原目录前加了个本地目录前缀,华丽丽的解决非root的壁垒)

顺其自然的又报错了(奔溃呀),/usr/bin/ld: cannot find -lclntsh

这个错误之前在mac上装cx_Oracle时候没遇到,百度解决方案,得知是没有找到lib下的libclntsh.so函数库

其实是有的,只不过名字改了,加软链接:

ln -s libclntsh.so.11.1 libclntsh.so

再次安装解决。

补充:

非root安装rpm包

首先把RPM包解压出来,然后放在自己的目录下,并且添加好环境变量

解压的命令为:

rpm2cpio ctags-5.8-2.el6.x86_64.rpm | cpio -idvm

这样就会按包里的目录结构解压到当前目录,如果是家目录的话,可以在家目录下的.bashrc这样添加环境变量

vim ~/.bashrc

export PATH=$PATH:$HOME/usr/bin/

重新登录或者source ~/.bashrc文件,就可以使用这个程序了

easy_install --prefix=~/.local cx_Oracle

卸载:

python setup.py install --record record.txt --prefix=~/.local

然后删除record.txt里的所有文件

贴段cx_Oracle 使用代码,作为备忘:

importcx_OracleclassConnectOracle:def __init__(self, username, passwd, locate):

self.login={}

self.db=None

self.cursor=None

self.login['username'] =username

self.login['passwd'] =passwd

self.login['locate'] =locatedefconnect_oracle(self):try:

self.db= cx_Oracle.connect(self.login['username'], self.login['passwd'], self.login['locate']) #登录内搜数据库

self.db.autocommit = False #关闭自动提交

self.cursor = self.db.cursor() #设置cursor光标

returnTrueexcept:print 'can not connect oracle'

returnFalsedefclose_oracle(self):

self.cursor.close()

self.db.close()def select_oracle(self, sql, num=0, temp=None):ifself.connect_oracle():iftemp:

self.cursor.executemany(sql, temp)else:

self.cursor.execute(sql)ifnum:

content=self.cursor.fetchmany(num)else:

content=self.cursor.fetchall()

self.close_oracle()returncontentreturnFalsedef insert_oracle(self, sql, temp=None):try:

self.connect_oracle()iftemp:

self.cursor.executemany(sql, temp)#执行多条sql命令

else:

self.cursor.execute(sql)except:print "insert异常"self.db.rollback()#回滚

finally:

self.db.commit()

self.close_oracle()

二 安装mysql的操作模型:MySQLdb

先安装依赖程序:yum install python-devel mysql-devel zlib-devel openssl-devel

三 安装mysql的操作模型:Tornado

Tornado是非阻塞的开源的web服务器

tar xvzf tornado-1.2.1.tar.gz

cd tornado-1.2.1

python setup.py build

sudo python setup.py install

四, ipython

IPYTHON=1 ./bin/pyspark

IPYTHON_OPTS="notebook"  ./bin/pyspark

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值