php oci 扩展安装

windows

  1. 下载: instant-client
    Oracle Instant Client Downloads
    image.png

Instant Client for Microsoft Windows (x64) 64-bit (oracle.com)

image.png

下载12.1.*****版本的


image.png

打开压缩包将 oci.dll 复制到
C:\Windows\System32目录(网上说64位系统复制到 C:\Windows\SysWOW64目录,其实不管用)

  1. 下载 oci dll 库文件,根据php的版本选择
    PECL :: Package :: oci8 (php.net)

  2. 编辑php.ini
    extension=php_oci8_12c.dll

Q: error:oci_connect(): OCIEnvNlsCreate() failed. ...... please check that PATH includes the directory with Oracle Instant Client libraries

A: instantlient 目录下的 dll 复制到system32目录


图片.png

CI3

$db['GAME_DB']['dsn'] = '(DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=172.16.201.18)(PORT=1521))(CONNECT_DATA=(SID=xe)))';
$db['GAME_DB']['username'] = 'dbxxxx';
$db['GAME_DB']['password'] = '123456';
$db['GAME_DB']['database'] = 'R2BEAT';
$db['GAME_DB']['dbdriver'] = 'oci8';
$db['GAME_DB']['dbprefix'] = '';
$db['GAME_DB']['pconnect'] = false;
$db['GAME_DB']['db_debug'] = TRUE;
$db['GAME_DB']['cache_on'] = FALSE;
$db['GAME_DB']['cachedir'] = '';
$db['GAME_DB']['char_set'] = '';//'utf8';
$db['GAME_DB']['dbcollat'] = '';
$db['GAME_DB']['swap_pre'] = '';
$db['GAME_DB']['autoinit'] = TRUE;
$db['GAME_DB']['stricton'] = FALSE;

ok啦 , 老铁们~~~~

LINUX (CentOS Linux release 7.9.2009)

Instant Client for Linux x86-64 (64-bit) (oracle.com)

php.net 官网下载 php7.4 编译安装

// 安装编译工具
yum groupinstall 'Development Tools'

// 安装依赖包
yum install oniguruma-devel
yum install libsqlite3x-devel -y
yum install -y epel-release

yum install libxml2 libxml2-devel openssl openssl-devel bzip2 bzip2-devel libcurl libcurl-devel libjpeg libjpeg-devel libpng libpng-devel freetype freetype-devel gmp gmp-devel libmcrypt libmcrypt-devel readline readline-devel libxslt libxslt-devel zlib zlib-devel glibc glibc-devel glib2 glib2-devel ncurses curl gdbm-devel db4-devel libXpm-devel libX11-devel gd-devel gmp-devel expat-devel xmlrpc-c xmlrpc-c-devel libicu-devel libmcrypt-devel libmemcached-devel

./configure --prefix=/usr/local/php7 --with-config-file-path=/usr/local/php7/etc--with-fpm-user=www --with-fpm-group=www --with-curl --with-freetype-dir --enable-gd --with-gettext --with-iconv-dir --with-kerberos --with-libdir=lib64 --with-libxml-dir --with-mysqli --with-openssl --with-pcre-regex --with-pdo-mysql --with-pdo-sqlite --with-pear --with-png-dir --with-jpeg-dir --with-xmlrpc --with-xsl--with-zlib --with-bz2--with-mhash --enable-bcmath --enable-libxml --enable-inline-optimization --enable-mbregex --enable-mbstring --enable-opcache --enable-pcntl --enable-shmop --enable-soap --enable-sockets --enable-sysvsem --enable-sysvshm --enable-xml  --enable-zip --enable-fpm


Installing shared extensions:     /usr/local/php7/lib/php/extensions/no-debug-non-zts-20190902/
Installing PHP CLI binary:        /usr/local/php7/bin/
Installing PHP CLI man page:      /usr/local/php7/php/man/man1/
Installing PHP FPM binary:        /usr/local/php7/sbin/
Installing PHP FPM defconfig:     /usr/local/php7/etc/
Installing PHP FPM man page:      /usr/local/php7/php/man/man8/
Installing PHP FPM status page:   /usr/local/php7/php/php/fpm/
Installing phpdbg binary:         /usr/local/php7/bin/
Installing phpdbg man page:       /usr/local/php7/php/man/man1/
Installing PHP CGI binary:        /usr/local/php7/bin/
Installing PHP CGI man page:      /usr/local/php7/php/man/man1/
Installing build environment:     /usr/local/php7/lib/php/build/
Installing header files:          /usr/local/php7/include/php/
Installing helper programs:       /usr/local/php7/bin/
  program: phpize
  program: php-config
Installing man pages:             /usr/local/php7/php/man/man1/
  page: phpize.1
  page: php-config.1
Installing PEAR environment:      /usr/local/php7/lib/php/
[PEAR] Archive_Tar    - already installed: 1.4.14
[PEAR] Console_Getopt - already installed: 1.4.3
[PEAR] Structures_Graph- already installed: 1.1.1
[PEAR] XML_Util       - already installed: 1.4.5
[PEAR] PEAR           - already installed: 1.10.13
Warning! a PEAR user config file already exists from a previous PEAR installation at '/root/.pearrc'. You may probably want to remove it.
Wrote PEAR system config file at: /usr/local/php7/etc/pear.conf
You may want to add: /usr/local/php7/lib/php to your php.ini include_path
/opt/softwares/php-7.4.23/build/shtool install -c ext/phar/phar.phar /usr/local/php7/bin/phar.phar
ln -s -f phar.phar /usr/local/php7/bin/phar
Installing PDO headers:           /usr/local/php7/include/php/ext/pdo/
[root@vstat-web php-7.4.23]# /usr/local/php7/bin/php --ini
Configuration File (php.ini) Path: /usr/local/php7/etc
Loaded Configuration File:         (none)
Scan for additional .ini files in: (none)
Additional .ini files parsed:      (none)



//  配置php-fpm

cp php.ini-production /etc/php.ini
cp /usr/local/php7/etc/php-fpm.conf.default /usr/local/php7/etc/php-fpm.conf
cp /usr/local/php7/etc/php-fpm.d/www.conf.default /usr/local/php7/etc/php-fpm.d/www.conf
cp sapi/fpm/init.d.php-fpm /etc/init.d/php-fpm
chmod +x /etc/init.d/php-fpm

启动php-fpm
groupadd www
useradd -g www www

/etc/init.d/php-fpm start
或者
service php-fpm start

// PECL config
#!/bin/bash

update-alternatives --set php /usr/local/php7/bin/php

pecl config-set php_ini /etc/php/7.0/cli/php.ini
pecl config-set ext_dir  /usr/local/php7/lib/php/extensions/no-debug-non-zts-20190902/
pecl config-set bin_dir /usr/local/php7/bin/
pecl config-set php_bin /usr/local/php7
pecl config-set php_suffix 7.4
// pecl 配置失败,这方法安装不了,直接编译把
instantclient-basic-linux.x64-12.1.0.2.0.zip  
instantclient-sdk-linux.x64-12.1.0.2.0.zip

php编译包里ext目录有oci8,如果没有 下载:
cd ext/oci8
ln -s /usr/lib/oracle/instantclient_12_1/libclntsh.so.12.1 /usr/lib/oracle/instantclient_12_1/libclntsh.so
./configure --with-php-config=/usr/local/php7/bin/php-config --with-oci8=shared,instantclient,/usr/lib/oracle/instantclient_12_1

pdo_sqlsrv.so:

wget http://pecl.php.net/get/pdo_sqlsrv-5.9.0.tgz
tar xzvf pdo_sqlsrv-5.9.0.tgz 
cd pdo_sqlsrv-5.9.0/
/usr/local/php7/bin/phpize
./configure --with-php-config=/usr/local/php7/bin/php-config


Q: sql.h: No such file or directory
A: yum install unixODBC-devel

mac OS 安装OCI

在Oracle官网下载instant client for os x。 下载 instantclient-basic-macos和 instantclient-sdk-macos两个包

Instant Client for macOS (Intel x86) (oracle.com)
配置环境变量:ORACLE_HOME
ORACLE_HOME=/data/tools/instantclient
使用上面的方法 无法安装

下载源码编译安装吧:

> /data/tools/instantclient/instantclient_12_1 这个目录是instantclient (basic和sdk解压缩的目录,两个包下载下来后直接解压缩就好了)
下载:oci8-2.2.0: wget https://pecl.php.net/get/oci8-2.2.0.tgz
tar xzvf oci8-2.2.0.targs
cd oci8-2.2.0
phpize
./configure --with-php-config=php-config --with-oci8=shared,instantclient,/data/tools/instantclient/instantclient_12_1
ln -s  /data/tools/instantclient/instantclient_12_1/libclntsh.dylib.12.1  /data/tools/instantclient/instantclient_12_1/libclntsh.dylib

由于需要Mac OS 安装mssql 扩展同上:

wget [http://pecl.php.net/get/pdo_sqlsrv-5.9.0.tgz](http://pecl.php.net/get/pdo_sqlsrv-5.9.0.tgz)
tar xzvf pdo_sqlsrv-5.9.0.tgz
cd pdo_sqlsrv-5.9.0/
/usr/local/php7/bin/phpize
./configure --with-php-config=/usr/local/php7/bin/php-config

PHP7.4 安装部分参考: centos7 编译安装 php7.4 - bobiscool - 博客园 (cnblogs.com)

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,937评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,503评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,712评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,668评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,677评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,601评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,975评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,637评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,881评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,621评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,710评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,387评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,971评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,947评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,189评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,805评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,449评论 2 342

推荐阅读更多精彩内容