1. 安装InstantClient

instantclient是oracle的连接数据库的简单客户端,不用安装一个500Moracle客户端就可以连接oracle数据库,有windows和linux版本。从 这里 选择需要的版本下载,只需Basic和Devel两个rpm包。
官方下载地址:https://www.oracle.com/technetwork/topics/linuxx86-64soft-092277.html
官方下载需要帐号登录,可以注册一下。
下载完成 我这边放在一个文件夹里方便管理。

mkdir oracle_src
cd oracle_src
wget ....
#我当前服务器用的是php56,所以下载了instantclient11.2,本教程以instantclient11.2为例

安装

# rpm -ivh oracle-instantclient11.2-basic-11.2.0.4.0-1.x86_64.rpm
# rpm -ivh oracle-instantclient11.2-devel-11.2.0.4.0-1.x86_64.rpm

软链接

# ln -s /usr/include/oracle/11.2/client64 /usr/include/oracle/11.2/client
# ln -s /usr/lib/oracle/11.2/client64 /usr/lib/oracle/11.2/client

64位系统需要创建32位的软链接,这里可能是一个遗留bug,不然后面编译会出问题。

接下来还要让系统能够找到oracle客户端的库文件,修改LD_LIBRARY_PATH:

# vim /etc/profile.d/oracle.sh
export ORACLE_HOME=/usr/lib/oracle/11.2/client64
export LD_LIBRARY_PATH=$ORACLE_HOME/lib
#执行source /etc/profile.d/oracle.sh使环境变量生效。

2. 安装PDO_OCI

从https://pecl.php.net/package/PDO_OCI下载 PDO_OCI源文件。
这里以PDO_OCI-1.0为例子

# wget https://pecl.php.net/get/PDO_OCI-1.0.tgz
# tar -xvf PDO_OCI-1.0.tgz
# cd PDO_OCI-1.0

由于PDO_OCI很久没有更新,所以下面需要编辑ODI_OCI-1.0文件夹里的config.m4文件来让它支持11g:

# 在第10行左右找到与下面类似的代码,添加这两行:
elif test -f $PDO_OCI_DIR/lib/libclntsh.$SHLIB_SUFFIX_NAME.11.2; then
 PDO_OCI_VERSION=11.2
# 在第101行左右添加这几行:
11.2)
 PHP_ADD_LIBRARY(clntsh, 1, PDO_OCI_SHARED_LIBADD)
 ;;

编译安装pdo_oci扩展:(安装完成后可在 /usr/lib64/php/modules/pdo_oci.so 找到这个模块)

$ phpize
$ ./configure --with-pdo-oci=instantclient,/usr,11.2 --with-php-config=/usr/local/php7/bin/php-config
$ make
#报错解决:在make的时候可能会报错,可以尝试执行以下命令:
#ln -s pdo_oci.loT pdo_oci.lo
$ sudo make install

要启用这个扩展,在/etc/php.d/下新建一个pdo_oci.ini文件,内容:

extension=pdo_oci.so

验证安装成功:

# php -i|grep oci

看到类似下面的内容则安装成功:

/etc/php.d/pdo_oci.ini,
PDO drivers => oci, sqlite
或
# php -m 查看已安装拓展列表

如果动态编译的pdo_oci.so不能正常使用,那只能通过重新编译php的静态形式安装该拓展,操作如下:

#进入源php安装源文件目录
cd /usr/local/src/php-5.6.10/
#原来编译成功会生成脚本文件config.nice ,所以我们只需要编辑一下这个文件
vim config.nice
#在"$@"之前参照其他参数增加一行
--with-pdo-oci=instantclient,/usr,11.2
#保存完毕后执行以下命令
sh config.nice
make && make install

3. 安装OCI8

https://pecl.php.net/package/oci8 下载oci8-2.0.8.tgz源文件。

# wget https://pecl.php.net/get/oci8-2.0.8.tgz
# tar -xvf oci8-2.0.8.tgz
# cd oci8-2.0.8

编译安装oci8扩展:

# phpize
# ./configure --with-oci8=shared,instantclient,/usr/lib/oracle/11.2/client64/lib
# make
# make install

要启用这个扩展,在/etc/php.d/下新建一个oci8.ini文件,内容:

extension=oci8.so

验证安装成功:

# php -i|grep oci8
/etc/php.d/oci8.ini,
oci8
oci8.connection_class => no value => no value
oci8.default_prefetch => 100 => 100
oci8.events => Off => Off
oci8.max_persistent => -1 => -1
oci8.old_oci_close_semantics => Off => Off
oci8.persistent_timeout => -1 => -1
oci8.ping_interval => 60 => 60
oci8.privileged_connect => Off => Off
oci8.statement_cache_size => 20 => 20
OLDPWD => /usr/local/src/oci8-2.0.8
_SERVER["OLDPWD"] => /usr/local/src/oci8-2.0.8

如果动态编译的oci8.so不能正常使用,可参考pdo_oci.so的重新编译php的方式安装。
最后别忘了重启web服务或者php-fpm,可以通过phpinfo()来确保扩展是否成功安装。

4. 测试连接

在你web服务器如nginx的php目录下创建testoci.php:

<?php
$conn = oci_connect('username', 'password', '172.29.88.178/DBTEST');
$stid = oci_parse($conn, 'select table_name from user_tables');
oci_execute($stid);
echo "<table>\n";
while (($row = oci_fetch_array($stid, OCI_ASSOC+OCI_RETURN_NULLS)) != false) {
  echo "<tr>\n";
  foreach ($row as $item) {
    echo " <td>".($item !== null ? htmlentities($item, ENT_QUOTES) : " ")."</td>\n";
  }
  echo "</tr>\n";
}
echo "</table>\n";
?>

php-fpm启动后报错解决:

error while loading shared libraries: libclntsh.so.11.1: cannot open shared object file: No
解决方法

vim /etc/ld.so.conf.d/oracle.conf
#或者
vim /etc/ld.so.conf
把库的目录/usr/lib/oracle/11.2/client/lib/ 写入该文件
#然后执行以下命令加载动态库
ldconfig

所有操作完 需要重启php-fpm才能生效

注意点:php-fpm.conf 中新增

env[LD_LIBRARY_PATH] = /usr/lib/oracle/11.2/client64/lib
env[ORACLE_HOME] = /usr/lib/oracle/11.2/client64