前言

由于公司某项目需要连接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. Kettle中ETL的效率优化

    ETL效率优化 开启数据库日志记录及性能监控 如果我们想要优化一个ETL(KTR或者KJB)的性能,我们首先需要知道的就是它的瓶颈在哪里.而这些信息一般只能在ETL运行的步骤度量中看到,并且是不会持久 ...

  2. js 检测链接是否有效(包含跨域)

    const checkUrl = function (url) { const promise = new Promise(function (resolve, reject) { if (!url) ...

  3. webpack介绍和使用

    一webpack介绍1由来2介绍3作用4拓展说明5webpack整体认知二webpack安装1安装node2安装cnpm3安装nrm的两种方法4安装webpack三webpack配置0搭建项目结构1初 ...

  4. 目标检测中的选择性搜索-selective search-没弄

    https://blog.csdn.net/small_munich/article/details/79595257 https://www.cnblogs.com/zyly/p/9259392.h ...

  5. AtomicInteger的CAS算法浅析

    之前浅析过自旋锁(自旋锁浅析),我们知道它的实现原理就是CAS算法.CAS(Compare and Swap)即比较并交换,作为著名的无锁算法,它也是乐观锁的实现方式之一.JDK并发包里也有许多代码中 ...

  6. matlab学习——05插值和拟合(一维二维插值,拟合)

    05插值和拟合 1.一维插值 (1) 机床加工零件,试用分段线性和三次样条两种插值方法计算.并求x=0处的曲线斜率和13<=x<=15范围内y的最小值. x0=[0 3 5 7 9 11 ...

  7. react——Table组件列中靠左 靠右对齐解决方案

    最近项目中遇到一个需求调整:table中的文字过长居左排列,数字居右排列 然后看了一下官方文档: 先上图展示一下 左边是需要的效果: className: 'column-left', { title ...

  8. WordPress主题制作:基础样式文件

    1.style.css文件,其中必须包含 /* Theme Name:主题名称 Theme URI: 主题链接 Version: 版本 Description: 主题简介 Author: 主题作者 A ...

  9. 当你登录Github要求你邮箱验证身份,但是你的邮箱登录不了?

    事情发送在两天前,我如标题所示......,它给出的tyningling@163我真的不知道什么时候注册的了,尝试了N个密码登录不上,验证密保吧,看到手机号突然想起来,这是拿以前同学的手机号注册的.. ...

  10. Swagger API文档

    Swagger API文档集中化注册管理   接口文档是前后端开发对接时很重要的一个组件.手动编写接口文档既费时,又存在文档不能随代码及时更新的问题,因此产生了像swagger这样的自动生成接口文档的 ...