前言

由于公司某项目需要连接oracle数据库,该项目使用的开发语言为PHP,故需要对PHP进行扩展

环境说明

服务器:Centos7

PHP:7.2, 源码安装;安装路径:/usr/local/xxx/php-7.2

扩展过程

前期准备

下载oracle所需客户端,我这里使用的是zip包.

下载地址

下载后存放到某路径下,我这里为/data/soft目录下

注意,php7版本的某些扩展已经集合到php的源码中,我们可以直接对php的源码进行重新编译,而不需要再下载所谓的其他软件包

如果php在安装完后删除了,需要去官网找寻对应的版本下载并解压,我这里用的是7.2.11的

安装oracle的客户端

解压instantclient-basic-linux.x64-12.2.0.1.0.zip,并移动到/usr/lib/目录下

unzip instantclient-basic-linux.x64-12.2.0.1.0.zip
mv instantclient_12_2/ /usr/lib

解压instantclient-sdk-linux.x64-12.2.0.1.0.zip,将解压后的instantclient_12_2目录下sdk目录移动到/usr/lib/instantclient_12_2/下

unzip instantclient-sdk-linux.x64-12.2.0.1.0.zip
cp -rf instantclient_12_2/sdk/ /usr/lib/instantclient_12_2/

配置环境变量

vim ~/.bash_profile

export ORACLE_HOME=/usr/lib/instantclient_12_2
export LD_LIBRARY_PATH=/usr/lib/instantclient_12_2
export PATH=$ORACLE_HOME:$LD_LIBRARY_PATH:$PATH
source ~/.bash_profile
//查看环境变量,检验配置是否正确
echo $PATH

创建软连接

进入oracle目录

cd /usr/lib/instantclient_12_2
ln -s libclntsh.so.12.1 libclntsh.so
ln -s libclntshcore.so.12.1 libclntshcore.so 注意 libclntsh.so.12.1 根据下载版本不同而不同。如在 Oracle11.* 的版本则为 libclntsh.so.11.1。
而且该链接必须配置,否则在以下的 configure 配置步骤将会报错而导致配置失败。

编译扩展oci8

cd /data/soft/php-7.2.11/ext/oci8
//执行phpize
/usr/local/xxx/php-7.2/bin/phpize
//生成configure文件后执行configure
./configure --with-php-config=/usr/local/xxx/php-7.2/bin/php-config --with-oci8=shared,instantclient,/usr/lib/instantclient_12_2
//编辑过程中如果有问题就解决问题,如果没有继续执行
make && make install

将生成的oci8.so 添加到php.ini

vim /usr/local/xxx/php-7.2/lib/php.ini

重启php查看扩展是否添加

systemctl restart php-fpm7

/usr/local/xxx/php-7.2/bin/php -m

如果添加扩展后执行php -m 报错则使用第二方法

报错信息如下
libaio.so.1: cannot open shared object file: No such file or director
解决
yum install libaio
/usr/local/xxx/php-7.2.11/bin/pecl install oci8
之后输入如下安装即可.
instantclient,/usr/lib/instantclient_12_2/ 然后重启php

编译扩展pdo_oci

cd /data/soft/php-7.2.11/ext/pdo_oci
//执行phpize
/usr/local/xxx/php-7.2/bin/phpize
//生成configure文件后执行configure
./configure --with-php-config=/usr/local/xxx/php-7.2/bin/php-config --with-pdo-oci=instantclient,/usr/lib/instantclient_12_2
//编辑过程中如果有问题就解决问题,如果没有继续执行
make && make install

将生成的pdo_oci.so 添加到php.ini

vim /usr/local/xxx/php-7.2/lib/php.ini

重启php查看扩展是否添加

systemctl restart php-fpm7

/usr/local/xxx/php-7.2/bin/php -m

总结

在进行php扩展的过程中,走了很多的坑,前前后后忙活了大约一天多的时间,总算是处理好了.

前期看各种博客,发现很多是类似的,都无法实现.上面说有用rpm,有用zip包的,

也有使用的版本为11.2的,也有12.2的.经过自己不断的摸索,加上网上的文章

后来终于使用12.2版本的zip包安装上了.

参考文献:

https://www.jianshu.com/p/664bff2cbae6#fn2

https://www.jianshu.com/p/3628374e9f91

Linux下PHP7.2扩展的更多相关文章

  1. linux下php7安装memcached、redis扩展

    linux下php7安装memcached.redis扩展 1.php7安装Memcached扩展 比如说我现在使用了最新的 Ubuntu 16.04,虽然内置了 PHP 7 源,但 memcache ...

  2. linux下安装opcache扩展

    linux下安装opcache扩展   参考:http://www.php.net/manual/zh/opcache.installation.php 1 2 3 4 5 6 7 wget http ...

  3. 总结 Linux 下安装 PHP 扩展步骤

    总结一下 Linux 下安装 PHP 扩展步骤,这里以安装 PHP 的 redis 扩展为例. 一.拿到扩展包下载地址,下载扩展包 pecl 上搜索 redis wget http://pecl.ph ...

  4. linux 下安装php扩展

    linux下安装php扩展 步骤: 1.在扩展解压包目录执行 phpize 2.执行 ./configure --with-php-config=/usr/local/php/bin/php-conf ...

  5. linux下安装PHP扩展memcache

    公司的服务器 CentOS 7.5,PHP 5.6 下面都是最新的版本(支持到PHP5.6) 如需php7  下支持memcache扩展,请移步   https://www.cnblogs.com/h ...

  6. linux安装PHP7以及扩展

    Linux下安装PHP7 事先升级gcc4.8,然后安装PHP7,安装步骤参考:CentOS安装PHP7 1.Linux下编译的php没有php.ini 解决办法:从源代码目录中复制php.ini-d ...

  7. linux下PHP7安装memcache

    1.memcache服务器的安装 .分别把memcached和libevent下载回来,放到 /tmp 目录下: # cd /tmp # wget http://www.danga.com/memca ...

  8. linux下安装swoole扩展

    一.下载swoole 地址:https://github.com/swoole/swoole-src二.将下载好的压缩包放在linux服务器下三.解压压缩包到任意目录 # unzip swoole-s ...

  9. Linux下,PHP扩展安装(使用yum安装)

    直接操作linux,在命令模式下用yum 来安装PHP的扩展: 扩展:mysqli 命令: yum install php-mysqli 扩展:pdo 命令: yum install php-pdo

随机推荐

  1. 《基于Python的GMSSL实现》课程设计个人报告

    <基于Python的GMSSL实现>课程设计个人报告 一.基本信息 姓名:刘津甫 学号:20165234 题目:GMSSL基于python的实现 指导老师:娄嘉鹏 完成时间:2019年5月 ...

  2. markdown文件的基本常用编写语法

    .md即markdown文件 1.标题的几种写法: 第一种:     前面带#号,后面带文字,分别表示h1-h6,上图可以看出,只到h6,而且h1下面会有一条横线,注意,#号后面有空格 第二种:   ...

  3. (转)MitmProxy+APPnium安装使用

    MitmProxy+APPnium安装使用 2019年08月19日 11:09:48 jiageibuuuyi 阅读数 61更多 分类专栏: python学习笔记   版权声明:本文为博主原创文章,遵 ...

  4. Qt之模型/视图(自定义风格)

    Qt之模型/视图(自定义风格) 关于自定义风格是针对视图与委托而言的,使用事件与QSS都可以进行处理,今天关于美化的细节讲解一下. 先看下图: 先撇开界面的美观性(萝卜青菜,各有所爱),就现有的这些风 ...

  5. OpenJudge计算概论-找出第k大的数

    /*================================================ 找出第k大的数 总时间限制: 1000ms 内存限制: 1000kB 描述 用户输入N和K,然后接 ...

  6. 阿里巴巴高可用技术专家襄玲:压测环境的设计和搭建 PTS - 襄玲 云栖社区 今天

    阿里巴巴高可用技术专家襄玲:压测环境的设计和搭建 PTS - 襄玲 云栖社区 今天

  7. PHP根据传入的经纬度,和距离范围,返回所有在距离范围内的经纬度的取值范围

    /** * 根据传入的经纬度,和距离范围,返回所有在距离范围内的经纬度的取值范围 * @param float $lng 经度 * @param float $lat 纬度 * @param floa ...

  8. LEFT JOIN 关键字语法

    SQL LEFT JOIN 关键字 LEFT JOIN 关键字会从左表 (table_name1) 那里返回所有的行,即使在右表 (table_name2) 中没有匹配的行. LEFT JOIN 关键 ...

  9. Hibernate 自动更新表出错 More than one table found in namespace

    报错:Caused by: org.hibernate.tool.schema.extract.spi.SchemaExtractionException: More than one table f ...

  10. Eclipse中把项目导出为war包【我】

    项目右键,Export 全部默认一路下一步,选择一个目标文件夹,确定即可.