PHP516 用phpize增加扩展PDO
环境: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
# 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:
用浏览器打开test.php,结果为连接成功关闭连接成功!。说明连接oracle成功。
页:
[1]