php pdo oci8,PHP516 用phpize增加扩展PDO_OCI和OCI8

环境:centos5.5、PHP5.1.6、oracle10.2.0.5 客户端

1、从oracle官网下载oracle客户端包

oracle-instantclient-basic-10.2.0.5-1.i386.rpm

oracle-instantclient-devel-10.2.0.5-1.i386.rpm

oracle-instantclient-sqlplus-10.2.0.5-1.i386.rpm

2、从官网下载PHP5.1.6的安装包,要下有带有源代码的:php-5.1.6.tar.gz

3、安装oracle客户端

rpm -ivh oracle-instantclient*

4、修改/etc/ld.so.conf文件,添加:/usr/lib/oracle/10.2.0.5/client/lib/,这个需要和你自己的配置相关。

5、修改/etc/profile文件,最后加入如下内容:

export ORACLE_HOME=/usr/lib/oracle/10.2.0.5/client/

export LD_LIBRARY_PATH=/usr/lib/oracle/10.2.0.5/client:$LD_LIBRARY_PATH

export NLS_LANG="AMERICAN_AMERICA.US7ASCII" //具体字符集,请查看你的oracle服务端sql

保存后,执行命令,使其起效:

source /etc/profile

6、安装模块,要使用源代码安装方式,源代码位置在php-5.1.6.tar.gz解压缩出来的文件夹里面的ext里面。

7、安装pdo_oci

1)进入文件夹

# cd php-5.1.6/ext/pdo_oci/

2) 用phpize来扩展,文件夹内执行: phpize

[root@jinniu-test3 pdo_oci]# phpize

Configuring for:

PHP Api Version:         20090626

Zend Module Api No:      20090626

Zend Extension Api No:   220090626

3) 编译安装

# ./configure --with-php-config=/usr/bin/php-config --with-pdo-oci=instantclient,/usr,10.2.0.5

# make && make install

这是静态编译方式,尽量使用这个方式来,如果不加后面--with-pdo-oci=instantclient,/usr,10.2.0.5,应该是动态方式,动态方式好像有时候会出错,安装之后,识别不到SO文件。

8、安装OCI8

基本一样,进入php5.1.6/oci8/文件夹,phpize命令,编译安装

# ./configure --with-php-config=/usr/bin/php-config --with-oci8=instantclient,/usr,10.2.0.5

# make && make install

同样要采用静态编译,要不然可能出错。

9、到此基本安装就算完成了,后面就是如何启用的问题,我出问题,主要出在这里。

PHP对模块的启用,应该是有两种方式,一是PHP.INI中增加,二是在/etc/php.d/文件夹下增加INI文件。这两种启用的方式,具体是那个参数配置的,我不知道。

推荐办法是,先确定安装没有出错,全部是使用静态编译的办法,然后现在PHP.INI文件中,增加

extension=oci8.so

extension=pdo_oci.so

然后使用php -v命令来检测配置文件是否正确,如果出错,表示无法加载,那么可能要使用第二种配置方式:

在/etc/php.d/文件夹下增加特定的INI文件。

启用OCI8,增加oci8.ini,内容是extension=oci8.so。

启用pdo_oci,增加pdo_oci.ini,内容是extension=pdo_oci.so。

然后再用php -v来检测,如果没有报错,说明正确了,然后重启HTTPD服务,service httpd restart 。

10、说明,OCI8和PDO_OCI这个编译过程,是可以重复进行的,如果已经安装了,没有成功,可以直接进行再次安装,不需要卸载过程,安装过程会覆盖之前安装的文件。

11、新建test.php:

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/9606200/viewspace-1435659/,如需转载,请注明出处,否则将追究法律责任。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值