2512380815 发表于 2015-12-24 10:14:12

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]
查看完整版本: PHP516 用phpize增加扩展PDO