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、从www.php.net官网下载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:
<?php


$dbconn=OCILogon("system","manager","(DESCRIPTION=(ADDRESS=(PROTOCOL =TCP)(HOST=远程数据库IP地址)(PORT = 1521))(CONNECT_DATA =(SID=远程数据库全局名)))"); 
if($dbconn!=false) 
{
echo "连接成功"; 
if(OCILogOff($dbconn)==true) 
    {
    echo "关闭连接成功!";
    } 

else 
{
echo "连接失败"; 



?>
用浏览器打开test.php,结果为连接成功关闭连接成功!。说明连接oracle成功。

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

转载于:http://blog.itpub.net/9606200/viewspace-1435659/

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值