设为首页 收藏本站
查看: 1043|回复: 0

[经验分享] linux系统下php oracle扩展OCI8的安装与配置

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2014-9-3 09:09:47 | 显示全部楼层 |阅读模式
linux系统下php oracle扩展OCI8的安装与配置
实现PHP程序访问oracle DB
时间:2014.09.02
写作者:刘群英(qunyingliu)
  • 环境描述:apache版本,PHP版本,oracle DB版本,linux发行版本
  • RPM包安装oracle-instantclient客户端
  • 源码编译安装oci8扩展
  • 系统环境与php配置修改:ld.so.conf.d目录配置文件与php.ini中扩展字段信息修改
  • 重启apache使修改生效
  • 测试链接代码,确认配置成功


  • 环境描述:

  • 本地系统:centos linux 6.4 x64
  • apache 2.2.22:/usr/local/apache2
  • PHP 5.4 : /usr/local/php
  • oracle DB 11.2.0.4

RPM包安装本地oracle client:
从[oracle Instant Client 官网 下载以下RPM包:
http://www.oracle.com/technetwork/cn/topics/linuxx86-64soft-092277.html

oracle-instantclient11.2-basic-11.2.0.4.0-1.x86_64.rpm
oracle-instantclient11.2-devel-11.2.0.4.0-1.x86_64.rpm
oracle-instantclient11.2-sqlplus-11.2.0.4.0-1.x86_64.rpm
使用以下命令进行安装:
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
rpm -ivh oracle-instantclient11.2-sqlplus-11.2.0.4.0-1.x86_64.rpm

源码编译安装oci8扩展下载:
wget http://pecl.php.net/get/oci8-1.4.10.tgz
解压:tar -zxvf oci8-1.4.10.tgz
安装:
cd oci8-1.4.10/usr/local/php/bin/phpize CFLAGS="-I/usr/lib/oracle/11.2.0.4.0/client64/" CXXFLAGS="-I/usr/lib/oracle/11.2.0.4.0/client64/"
./configure --with-php-config=/usr/local/php/bin/php-config --with-oci8=instantclient,/usr/lib/oracle/11.2.0.4.0/client64/lib/
make
make instal
lphp路径和oracle client的路径需根据实际情况进行修改。

如果系统中存在pecl程序,可通过以下命令来安装oci8扩展:
pecl install oci8

系统环境与php配置修改修改系统配置:
echo    "/usr/lib/oracle/11.2.0.4.0/client64//lib/"
>/etc/ld.so.conf.d/oracle_client.conf/sbin/ldconfig

修改php.ini配置文件:
extension_dir = "/usr/local/php5/lib/ext"
extension = "oci8.so"
oci8.privileged_connect = on

重启apache使修改生效

/usr/local/apache2/bin/apachectl restart

测试链接代码,确认配置成功
<?php
$conn = oci_connect('qunyingliu', 'testqunyingliu', 'oracle.test.localhost/orcl');
//需要根据实际配置信息进行修改
$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 "
\n";
foreach ($row as $item) {
echo "<td>".($item !== null ? htmlentities($item, ENT_QUOTES) : " ")."\n";
}
echo "\n";
}
echo "</table>\n";
?>


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-24310-1-1.html 上篇帖子: Oracle 11g rac 生产环境部署详录 下篇帖子: 查找Oracle高消耗语句 oracle linux
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表