linux php7.0 安装oci8 和pdo_oci

2023-11-25 05:30
文章标签 linux 安装 pdo oci php7.0 oci8

本文主要是介绍linux php7.0 安装oci8 和pdo_oci,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.下载oracle文件:必须和连接的oracle数据库一致,如:连接的是11.0.2.4的oracle,下载的文件就需要是11版本的。

以下的用11.0.2.4的oracle举例操作:

下载地址:https://www.oracle.com/cn/database/technologies/instant-client/linux-x86-64-downloads.html

注:需要注册,免费的

下载的文件:

         1.oracle-instantclient11.1-basic-11.1.0.7.0-1.x86_64.rpm

         2.oracle-instantclient11.1-devel-11.1.0.7.0-1.x86_64.rpm

         3.oracle-instantclient11.1-sqlplus-11.1.0.7.0-1.x86_64.rpm

2.安装oracle-instantclien

  1. 进入到/usr/local/src/目录,把下载好的rpm全部拷贝到该目录下
  2. 安装:rpm -Uvh oracle-instantclient11.1-basic-11.1.0.7.0-1.x86_64.rpm
  3. 安装:rpm -Uvh oracle-instantclient11.1-devel-11.1.0.7.0-1.x86_64.rpm
  4. 确认安装完成:

3. 添加php的oci扩展

  1. 下载oci8扩展,地址:http://pecl.php.net/package/oci8
  2. 把tgz包放到 /usr/local/php/etc/oci8 下,其中oci8是我新建的文件夹
  3. 解压 tar zxvf oci8-2.2.0.tgz
  4. [root@bm19-jyj-jygzglxt-yy-001 oci8]# ls
    oci8-2.2.0.tgz
    [root@bm19-jyj-jygzglxt-yy-001 oci8]# tar zxvf oci8-2.2.0.tgz
    

     

  5. 进入到oci8-2.2.0
  6. [root@bm19-jyj-jygzglxt-yy-001 oci8]# ls
    oci8-2.2.0  oci8-2.2.0.tgz  package.xml
    [root@bm19-jyj-jygzglxt-yy-001 oci8]# cd oci8-2.2.0
    

     

  7. 运行phpize 生成configure配置文件
  8. [root@bm19-jyj-jygzglxt-yy-001 oci8]# cd oci8-2.2.0
    [root@bm19-jyj-jygzglxt-yy-001 oci8-2.2.0]# /usr/local/php/bin/phpize
    

     

  9. 执行代码
  10. [root@bm19-jyj-jygzglxt-yy-001 oci8-2.2.0]# ./configure --with-php-config=/usr/local/php/bin/php-config --with-oci8=shared,instantclient,/usr/lib/oracle/11.1/client64/lib
    

     

  11. 执行make,如果出现checking Oracle Instant Client SDK header directory... configure: error: Oracle Instant Client SDK header files not found

  12. [root@bm19-jyj-jygzglxt-yy-001 oci8-2.2.0]# make
    

     

  13. 应该是你php版本问题,查看下php版本,再次执行上面操作

  14. make install

  15. [root@bm19-jyj-jygzglxt-yy-001 oci8-2.2.0]# make install
    Installing shared extensions:     /usr/local/php/lib/php/extensions/no-debug-non-zts-20170718/
    [root@bm19-jyj-jygzglxt-yy-001 oci8-2.2.0]# 

     

4.配置PHP支持oci扩展

  1. 在php.ini最后加入extension="oci8.so"

 

5. 查看phpinfo,oci8是否安装完成

6.安装pdo_oci扩展

  1. 下载地址:https://pecl.php.net/package/PDO_OCI
  2. 进入php的源码安装包:cd /usr/local/src/php-7.1.25/ext/pdo_oci
  3. 编译已支持11,12版本
  4. 参考地址:https://my.oschina.net/grail/blog/891795 或者直接下载已编译完成的,地址为:https://download.csdn.net/download/qq_16088377/13662512
  5. 以免pdo_oci对oracle11支持不足,做一个假的ln,骗过编译
    # ln -s /usr/include/oracle/xxxxx /usr/include/oracle/10.2.0.1
    # ln -s /usr/lib/oracle/xxxxx /usr/lib/oracle/10.2.0.1
  6. 配置环境变量
  7. vim /etc/profile

     加入以下几行

     

     

     

    export ORACLE_HOME=/usr/lib/oracle/11.2/client64/  
    export LD_LIBRARY_PATH=$ORACLE_HOME/lib  
    export NLS_LANG="AMERICAN_AMERICA.AL32UTF8"  
  8. 命令行输入以下语句使环境配置立即生效

     

    #source /etc/profile
  9. 执行/usr/local/php/bin/phpize
  10.  然后执行 ./configure --with-php-config=/usr/local/php/bin/php-config --with-pdo-oci=instantclient,/usr,10.2.0.1

  11. 出现报错checking for oci.h... configure: error: I'm too dumb to figure out where the include dir is in your Instant Client install
    1. 应该是没有找到oci.h,后来用strace跟踪了一下,发现它会找/usr/lib/oracle/11.1/client目录下,
    2. 于是 # ln -s /usr/include/oracle/11.1/client64/ /usr/include/oracle/11.1/client
    3. # ln -s /usr/lib/oracle/11.1/client64/ /usr/lib/oracle/11.1/client
  12. # make
  13. # make install
  14. 最后在php.ini中添加下 "extension=pdo_oci.so

 

错误:

  1. : OCIEnvNlsCreate: Check the character set is valid and that PHP has access to Oracle libraries and NLS data (/usr/local/php7.2/etc/PDO_OCI-1.0/oci_driver.c:619)

    1. 解决:把下面的代码拷贝到php-fpm.conf 里面

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

    3.  

  2.  :ORA-12541:TNS:no listener

    1. 解决:查看database配置的charset是否正确

  3.  

 

 

 

这篇关于linux php7.0 安装oci8 和pdo_oci的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/423190

相关文章

ubuntu20.0.4系统中安装Anaconda的超详细图文教程

《ubuntu20.0.4系统中安装Anaconda的超详细图文教程》:本文主要介绍了在Ubuntu系统中如何下载和安装Anaconda,提供了两种方法,详细内容请阅读本文,希望能对你有所帮助... 本文介绍了在Ubuntu系统中如何下载和安装Anaconda。提供了两种方法,包括通过网页手动下载和使用wg

ubuntu如何部署Dify以及安装Docker? Dify安装部署指南

《ubuntu如何部署Dify以及安装Docker?Dify安装部署指南》Dify是一个开源的大模型应用开发平台,允许用户快速构建和部署基于大语言模型的应用,ubuntu如何部署Dify呢?详细请... Dify是个不错的开源LLM应用开发平台,提供从 Agent 构建到 AI workflow 编排、RA

如何在Ubuntu上安装NVIDIA显卡驱动? Ubuntu安装英伟达显卡驱动教程

《如何在Ubuntu上安装NVIDIA显卡驱动?Ubuntu安装英伟达显卡驱动教程》Windows系统不同,Linux系统通常不会自动安装专有显卡驱动,今天我们就来看看Ubuntu系统安装英伟达显卡... 对于使用NVIDIA显卡的Ubuntu用户来说,正确安装显卡驱动是获得最佳图形性能的关键。与Windo

ubuntu16.04如何部署dify? 在Linux上安装部署Dify的技巧

《ubuntu16.04如何部署dify?在Linux上安装部署Dify的技巧》随着云计算和容器技术的快速发展,Docker已经成为现代软件开发和部署的重要工具之一,Dify作为一款优秀的云原生应用... Dify 是一个基于 docker 的工作流管理工具,旨在简化机器学习和数据科学领域的多步骤工作流。它

Docker安装MySQL镜像的详细步骤(适合新手小白)

《Docker安装MySQL镜像的详细步骤(适合新手小白)》本文详细介绍了如何在Ubuntu环境下使用Docker安装MySQL5.7版本,包括从官网拉取镜像、配置MySQL容器、设置权限及内网部署,... 目录前言安装1.访问docker镜像仓库官网2.找到对应的版本,复制右侧的命令即可3.查看镜像4.启

Linux高并发场景下的网络参数调优实战指南

《Linux高并发场景下的网络参数调优实战指南》在高并发网络服务场景中,Linux内核的默认网络参数往往无法满足需求,导致性能瓶颈、连接超时甚至服务崩溃,本文基于真实案例分析,从参数解读、问题诊断到优... 目录一、问题背景:当并发连接遇上性能瓶颈1.1 案例环境1.2 初始参数分析二、深度诊断:连接状态与

debian12安装docker的实现步骤

《debian12安装docker的实现步骤》本文主要介绍了debian12安装docker的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录步骤 1:更新你的系统步骤 2:安装依赖项步骤 3:添加 docker 的官方 GPG 密钥步骤

Linux系统调试之ltrace工具使用与调试过程

《Linux系统调试之ltrace工具使用与调试过程》:本文主要介绍Linux系统调试之ltrace工具使用与调试过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、ltrace 定义与作用二、ltrace 工作原理1. 劫持进程的 PLT/GOT 表2. 重定

Linux区分SSD和机械硬盘的方法总结

《Linux区分SSD和机械硬盘的方法总结》在Linux系统管理中,了解存储设备的类型和特性是至关重要的,不同的存储介质(如固态硬盘SSD和机械硬盘HDD)在性能、可靠性和适用场景上有着显著差异,本文... 目录一、lsblk 命令简介基本用法二、识别磁盘类型的关键参数:ROTA查询 ROTA 参数ROTA

嵌入式Linux之使用设备树驱动GPIO的实现方式

《嵌入式Linux之使用设备树驱动GPIO的实现方式》:本文主要介绍嵌入式Linux之使用设备树驱动GPIO的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、设备树配置1.1 添加 pinctrl 节点1.2 添加 LED 设备节点二、编写驱动程序2.1