php 编译安装oracel扩展

第一步安装Oracle客户端

1,需要下载基础包和sdk

oracle客户端下载链接:Oracle Instant Client Downloads for Linux x86-64 (64-bit)

https://www.oracle.com/database/technologies/instant-client/linux-x86-64-downloads.html

选择最新版本 version:21.13,基础包和sdk包都默认选的第一个

2.解压文件 将下载的instantclient-basic-linux.x64-21.13.0.0.0.zip以及sdk文件进行解压,本人文件所放的位置是(opt/oracle)

cd /opt/oracle 
unzip instantclient-basic-linux.x64-21.13.0.0.0.zip(基础包)unzip instantclient-basic-SDK-linux.x64-21.13.0.0.0.zip(对应的sdk)

3.安装libaio软件包:安装 libaio 软件包,使用sudo或者root用户,输入sudo apt-get install libaio进行安装,在ubuntu中包名为libaio1(本人的是Ubuntu

sudo apt-get install libaio1

4.添加环境变量 在~/.bashrc文件中添加如下配置

vim ~/.bashrc#然后加入如下配置
export ORACLE_BASE=/opt/oracle
export ORACLE_HOME=$ORACLE_BASE/instantclient_21_13
export PATH=$ORACLE_HOME:$PATH
export TNS_ADMIN=$ORACLE_HOME/network/admin
export LD_LIBRARY_PATH=$ORACLE_HOME

保存后运行source ~/.bashrc,使配置文件及时生效,可以通过命令printenv PATH检查配置变量是否生效。

第二步安装PHP扩展

安装 oci8 一点准备(各自需找各自对应版本的php):

apt-get install make  //为了后面的编译软件使用 
apt-get install php-pear  //为了得到 pecl 这个程序 
apt-get install php8.2-dev  //为了得到 phpize 这个程序

开始安装

 sudo pecl install oci8-2.2.0 // 找到和自己php版本匹配的参考http://pecl.php.net/package/oci8

按提示输入:instantclient,/opt/oracle/instantclient_21_13/

注意:/opt/oracle/instantclient_21_13/是我安装的oracle客户端的路径

按提示,把 extension=oci8.so 添加到 /etc/php/8.2/fpm/php.ini 和 /etc/php/8.2/cli/php.ini 中,可通过 php -m 或 echo phpinfo() 查看

写在最后的注意点(pdo_cli需要编译安装参考 https://www.cnblogs.com/starfish29/p/18009925):

第二步骤注意事项:
1.首先需要下载sdt的安装包和instantclient-basic-linux.x64-21.1.0.0.0.zip放在一起2.执行pecl install oci8时有出现输入的内容,一定要写对应的路径:instantclient,/opt/oracle/instantclient_21_14/3.如果pecl install oci8出现版本不对,可在官网https://pecl.php.net/package/oci8查看对应php版本的安装命令4.如果出现--with-php-config路径不对,需要通过find / -name php-config查找phpize文件路径,根据对应的php版本例如/www/server/php/82/bin/php-config,到/www/server/php/82/bin/文件夹中查看是否有phpize文件,如果没有,则通过apt install php-dev(注意需要安装对应php版本的phpize文件)安装,然后再执行pecl install oci8命令

参考链接: https://www.cnblogs.com/starfish29/p/18009925(请仔细研读此文档)
https://hefengbao.github.io/helloworld/ubuntu-install-oracle-instant-client-and-oci.html 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/651843.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

[C++基础学习]----03-程序流程结构之循环结构详解

前言 在C程序中,循环结构在用于重复执行一段代码块,直到满足某个条件为止。循环结构有多种形式,包括while循环、do-while循环和for循环。 正文 01-循环结构简介 1、while循环语句: while循环在每次循环开始前检查条件是否为真&a…

clickhouse与oracle传输数据

参考 https://github.com/ClickHouse/clickhouse-jdbc-bridge https://github.com/ClickHouse/clickhouse-jdbc-bridge/blob/master/docker/README.md clickhouse官方提供了一种方式,可以实现clickhouse与oracle之间传输数据,不仅仅是oracle&#xff0…

python 使用flask_httpauth和pyjwt实现登录权限控制

最近需要用到,学习了一下记录 首先安装依赖 pip install Flask-HTTPAuth pyjwt passlib Welcome to Flask-HTTPAuth’s documentation! — Flask-HTTPAuth documentation Welcome to PyJWT — PyJWT 2.8.0 documentation Passlib 1.7.4 documentation — Passl…

【北京迅为】《iTOP龙芯2K1000开发指南》-第四部分 ubuntu开发环境搭建

龙芯2K1000处理器集成2个64位GS264处理器核,主频1GHz,以及各种系统IO接口,集高性能与高配置于一身。支持4G模块、GPS模块、千兆以太网、16GB固态硬盘、双路UART、四路USB、WIFI蓝牙二合一模块、MiniPCIE等接口、双路CAN总线、RS485总线&#…

Linux驱动开发——(七)Linux阻塞和非阻塞IO

目录 一、阻塞和非阻塞IO简介 二、等待队列 2.1 等待队列头 2.2 等待队列项 2.3 将队列项添加/移除等待队列头 2.4 等待唤醒 2.5 等待事件 三、轮询 四、驱动代码 4.1 阻塞IO 4.2 非阻塞IO 一、阻塞和非阻塞IO简介 IO指的是Input/Output,也就是输入/输…

Ubuntu16.04搭建webrtc服务器

本人查阅无数资料,历时3周搭建成功 一、服务器组成 AppRTC 房间+Web服务器 https://github.com/webrtc/apprtcCollider 信令服务器,在AppRTC源码里CoTurn coturn打洞+中继服务器 Nginx 服务器,用于Web访问代理和Websocket代理。AppRTC 房间+Web服务器使用python+js语言 App…

数字文旅重塑旅游发展新格局:以数字化转型为突破口,提升旅游服务的智能化水平,为游客带来全新的旅游体验

随着信息技术的迅猛发展,数字化已成为推动各行各业创新发展的重要力量。在旅游业领域,数字文旅的兴起正以其强大的驱动力,重塑旅游发展的新格局。数字文旅以数字化转型为突破口,通过提升旅游服务的智能化水平,为游客带…

硬件21、接线端子XH2.54、2.54排针排母、2510接插件、PH2.0、町洋接线端子5.08、ISP接口JTAG插座

XH2.54端子的间距为2.54毫米,2.54排针排母的间距也是2.54mm,2510接插件也是2.54、而PH2.0端子的间距为2.0毫米,町洋接线端子插针间的距离是5.08mm,ISP接口JTAG插座针脚的间距一般也是2.54mm XH2.54 针脚间距为2.54mm 插头 接线…

【算法基础实验】图论-UnionFind连通性检测之quick-find

Union-Find连通性检测之quick-find 理论基础 在图论和计算机科学中,Union-Find 或并查集是一种用于处理一组元素分成的多个不相交集合(即连通分量)的情况,并能快速回答这组元素中任意两个元素是否在同一集合中的问题。Union-Fin…

实验7:路由冗余协议HSRP配置管理(课内实验以及解答)

实验目的及要求: 理解首跳冗余协议(FHRP)的工作原理,掌握热备份路由器协议 (HSRP)(思科私有协议)原理和配置。能够实现网络终端设备虚拟网关的配置和网络故障的灵活切换,完成相应网络的联通性测…

【教程】Google AdSense填报美国和新加坡免税税务信息

转载请注明出处:小锋学长生活大爆炸[xfxuezhagn.cn] 如果本文帮助到了你,请不吝给个[点赞、收藏、关注]哦~ 美国免税 如何填写 Google Adsense 税务信息可以免税 | W-8BEN | 紫竹的博客 新加坡免税 中国区AdSense如何添加新加坡税务信息?税…

光伏无人机:巡检无人机解决巡检难题

随着科技的飞速发展,无人机技术已经广泛应用于各个领域,其中光伏无人机在解决光伏电站巡检难题方面发挥了重要作用。光伏无人机以其高效、精准、安全的特点,为光伏电站的巡检工作带来了革命性的变革。 光伏电站通常位于广阔的户外场地&#x…