PHP oci8 在 Ubuntu 18 上安装失败

如何解决PHP oci8 在 Ubuntu 18 上安装失败

我正在尝试通过 pecl 安装 oci8,遵循 this link。去年,在 php8.0.0 发布之前,我按照这些步骤成功安装了 oci8。 这是我的配置:

  • Ubuntu 18.04.5
  • PHP7.3
  • Oracle 即时客户端 19.10 版(还尝试了 21.1 和 19.8,这是在 php8.0 发布之前对我有用的最后一个版本)

这是我解压 Instantclient 后所做的:

sudo echo /opt/oracle/instantclient_19_10 > /etc/ld.so.conf.d/oracle-instantclient.conf
sudo ldconfig
sudo apt install php7.3-dev php-pear build-essential libaio1
echo "instantclient,/opt/oracle/instantclient_19_10" | pecl install oci8-2.2.0

您可以在下面找到 echo "instantclient,/opt/oracle/instantclient_19_10" | pecl install oci8-2.2.0 的输出:

downloading oci8-2.2.0.tgz ...
Starting to download oci8-2.2.0.tgz (196,449 bytes)
.........................................done: 196,449 bytes
11 source files,building
running: phpize
Configuring for:
PHP Api Version:         20200930
Zend Module Api No:      20200930
Zend Extension Api No:   420200930
Please provide the path to the ORACLE_HOME directory. Use 'instantclient,/path/to/instant/client/lib' if you're compiling with Oracle Instant Client [autodetect] : building in /tmp/pear/temp/pear-build-rootF6jqsy/oci8-2.2.0
running: /tmp/pear/temp/oci8/configure --with-php-config=/usr/bin/php-config --with-oci8=instantclient,/opt/oracle/instantclient_19_10
checking for grep that handles long lines and -e... /bin/grep
checking for egrep... /bin/grep -E
checking for a sed that does not truncate output... /bin/sed
checking for pkg-config... /usr/bin/pkg-config
checking pkg-config is at least version 0.9.0... yes
checking for cc... cc
checking whether the C compiler works... yes
checking for C compiler default output file name... a.out
checking for suffix of executables...
checking whether we are cross compiling... no
checking for suffix of object files... o
checking whether we are using the GNU C compiler... yes
checking whether cc accepts -g... yes
checking for cc option to accept ISO C89... none needed
checking how to run the C preprocessor... cc -E
checking for icc... no
checking for suncc... no
checking for system library directory... lib
checking if compiler supports -R... no
checking if compiler supports -Wl,-rpath,... yes
checking build system type... x86_64-pc-linux-gnu
checking host system type... x86_64-pc-linux-gnu
checking target system type... x86_64-pc-linux-gnu
checking for PHP prefix... /usr
checking for PHP includes... -I/usr/include/php/20200930 -I/usr/include/php/20200930/main -I/usr/include/php/20200930/TSRM -I/usr/include/php/20200930/Zend -I/usr/include/php/20200930/ext -I/usr/include/php/20200930/ext/date/lib
checking for PHP extension directory... /usr/lib/php/20200930
checking for PHP installed headers prefix... /usr/include/php/20200930
checking if debug is enabled... no
checking if zts is enabled... no
checking for gawk... no
checking for nawk... nawk
checking if nawk is broken... no
checking for Oracle Database OCI8 support... yes,shared
checking PHP version... 8.0.3,ok
checking OCI8 DTrace support... no
checking size of long int... 8
checking checking if we're on a 64-bit platform... yes
checking Oracle Instant Client directory... /opt/oracle/instantclient_19_10
checking Oracle Instant Client SDK header directory... /opt/oracle/instantclient_19_10/sdk/include
checking Oracle Instant Client library version compatibility... 19.1
checking how to print strings... printf
checking for a sed that does not truncate output... (cached) /bin/sed
checking for fgrep... /bin/grep -F
checking for ld used by cc... /usr/bin/ld
checking if the linker (/usr/bin/ld) is GNU ld... yes
checking for BSD- or MS-compatible name lister (nm)... /usr/bin/nm -B
checking the name lister (/usr/bin/nm -B) interface... BSD nm
checking whether ln -s works... yes
checking the maximum length of command line arguments... 1572864
checking how to convert x86_64-pc-linux-gnu file names to x86_64-pc-linux-gnu format... func_convert_file_noop
checking how to convert x86_64-pc-linux-gnu file names to toolchain format... func_convert_file_noop
checking for /usr/bin/ld option to reload object files... -r
checking for objdump... objdump
checking how to recognize dependent libraries... pass_all
checking for dlltool... no
checking how to associate runtime and link libraries... printf %s\n
checking for ar... ar
checking for archiver @FILE support... @
checking for strip... strip
checking for ranlib... ranlib
checking for gawk... (cached) nawk
checking command to parse /usr/bin/nm -B output from cc object... ok
checking for sysroot... no
checking for a working dd... /bin/dd
checking how to truncate binary pipes... /bin/dd bs=4096 count=1
checking for mt... mt
checking if mt is a manifest tool... no
checking for dlfcn.h... yes
checking for objdir... .libs
checking if cc supports -fno-rtti -fno-exceptions... no
checking for cc option to produce PIC... -fPIC -DPIC
checking if cc PIC flag -fPIC -DPIC works... yes
checking if cc static flag -static works... yes
checking if cc supports -c -o file.o... yes
checking if cc supports -c -o file.o... (cached) yes
checking whether the cc linker (/usr/bin/ld -m elf_x86_64) supports shared libraries... yes
checking whether -lc should be explicitly linked in... no
checking dynamic linker characteristics... GNU/Linux ld.so
checking how to hardcode library paths into programs... immediate
checking whether stripping libraries is possible... yes
checking if libtool supports shared libraries... yes
checking whether to build shared libraries... yes
checking whether to build static libraries... no
configure: patching config.h.in
configure: creating ./config.status
config.status: creating config.h
config.status: executing libtool commands
running: make
/bin/bash /tmp/pear/temp/pear-build-rootF6jqsy/oci8-2.2.0/libtool --mode=compile cc -I. -I/tmp/pear/temp/oci8 -I/tmp/pear/temp/pear-build-rootF6jqsy/oci8-2.2.0/include -I/tmp/pear/temp/pear-build-rootF6jqsy/oci8-2.2.0/main -I/tmp/pear/temp/oci8 -I/usr/include/php/20200930 -I/usr/include/php/20200930/main -I/usr/include/php/20200930/TSRM -I/usr/include/php/20200930/Zend -I/usr/include/php/20200930/ext -I/usr/include/php/20200930/ext/date/lib -I/opt/oracle/instantclient_19_10/sdk/include  -DHAVE_CONFIG_H  -g -O2    -c /tmp/pear/temp/oci8/oci8.c -o oci8.lo
libtool: compile:  cc -I. -I/tmp/pear/temp/oci8 -I/tmp/pear/temp/pear-build-rootF6jqsy/oci8-2.2.0/include -I/tmp/pear/temp/pear-build-rootF6jqsy/oci8-2.2.0/main -I/tmp/pear/temp/oci8 -I/usr/include/php/20200930 -I/usr/include/php/20200930/main -I/usr/include/php/20200930/TSRM -I/usr/include/php/20200930/Zend -I/usr/include/php/20200930/ext -I/usr/include/php/20200930/ext/date/lib -I/opt/oracle/instantclient_19_10/sdk/include -DHAVE_CONFIG_H -g -O2 -c /tmp/pear/temp/oci8/oci8.c  -fPIC -DPIC -o .libs/oci8.o
/bin/bash /tmp/pear/temp/pear-build-rootF6jqsy/oci8-2.2.0/libtool --mode=compile cc -I. -I/tmp/pear/temp/oci8 -I/tmp/pear/temp/pear-build-rootF6jqsy/oci8-2.2.0/include -I/tmp/pear/temp/pear-build-rootF6jqsy/oci8-2.2.0/main -I/tmp/pear/temp/oci8 -I/usr/include/php/20200930 -I/usr/include/php/20200930/main -I/usr/include/php/20200930/TSRM -I/usr/include/php/20200930/Zend -I/usr/include/php/20200930/ext -I/usr/include/php/20200930/ext/date/lib -I/opt/oracle/instantclient_19_10/sdk/include  -DHAVE_CONFIG_H  -g -O2    -c /tmp/pear/temp/oci8/oci8_lob.c -o oci8_lob.lo
libtool: compile:  cc -I. -I/tmp/pear/temp/oci8 -I/tmp/pear/temp/pear-build-rootF6jqsy/oci8-2.2.0/include -I/tmp/pear/temp/pear-build-rootF6jqsy/oci8-2.2.0/main -I/tmp/pear/temp/oci8 -I/usr/include/php/20200930 -I/usr/include/php/20200930/main -I/usr/include/php/20200930/TSRM -I/usr/include/php/20200930/Zend -I/usr/include/php/20200930/ext -I/usr/include/php/20200930/ext/date/lib -I/opt/oracle/instantclient_19_10/sdk/include -DHAVE_CONFIG_H -g -O2 -c /tmp/pear/temp/oci8/oci8_lob.c  -fPIC -DPIC -o .libs/oci8_lob.o
/bin/bash /tmp/pear/temp/pear-build-rootF6jqsy/oci8-2.2.0/libtool --mode=compile cc -I. -I/tmp/pear/temp/oci8 -I/tmp/pear/temp/pear-build-rootF6jqsy/oci8-2.2.0/include -I/tmp/pear/temp/pear-build-rootF6jqsy/oci8-2.2.0/main -I/tmp/pear/temp/oci8 -I/usr/include/php/20200930 -I/usr/include/php/20200930/main -I/usr/include/php/20200930/TSRM -I/usr/include/php/20200930/Zend -I/usr/include/php/20200930/ext -I/usr/include/php/20200930/ext/date/lib -I/opt/oracle/instantclient_19_10/sdk/include  -DHAVE_CONFIG_H  -g -O2    -c /tmp/pear/temp/oci8/oci8_statement.c -o oci8_statement.lo
libtool: compile:  cc -I. -I/tmp/pear/temp/oci8 -I/tmp/pear/temp/pear-build-rootF6jqsy/oci8-2.2.0/include -I/tmp/pear/temp/pear-build-rootF6jqsy/oci8-2.2.0/main -I/tmp/pear/temp/oci8 -I/usr/include/php/20200930 -I/usr/include/php/20200930/main -I/usr/include/php/20200930/TSRM -I/usr/include/php/20200930/Zend -I/usr/include/php/20200930/ext -I/usr/include/php/20200930/ext/date/lib -I/opt/oracle/instantclient_19_10/sdk/include -DHAVE_CONFIG_H -g -O2 -c /tmp/pear/temp/oci8/oci8_statement.c  -fPIC -DPIC -o .libs/oci8_statement.o
/bin/bash /tmp/pear/temp/pear-build-rootF6jqsy/oci8-2.2.0/libtool --mode=compile cc -I. -I/tmp/pear/temp/oci8 -I/tmp/pear/temp/pear-build-rootF6jqsy/oci8-2.2.0/include -I/tmp/pear/temp/pear-build-rootF6jqsy/oci8-2.2.0/main -I/tmp/pear/temp/oci8 -I/usr/include/php/20200930 -I/usr/include/php/20200930/main -I/usr/include/php/20200930/TSRM -I/usr/include/php/20200930/Zend -I/usr/include/php/20200930/ext -I/usr/include/php/20200930/ext/date/lib -I/opt/oracle/instantclient_19_10/sdk/include  -DHAVE_CONFIG_H  -g -O2    -c /tmp/pear/temp/oci8/oci8_collection.c -o oci8_collection.lo
libtool: compile:  cc -I. -I/tmp/pear/temp/oci8 -I/tmp/pear/temp/pear-build-rootF6jqsy/oci8-2.2.0/include -I/tmp/pear/temp/pear-build-rootF6jqsy/oci8-2.2.0/main -I/tmp/pear/temp/oci8 -I/usr/include/php/20200930 -I/usr/include/php/20200930/main -I/usr/include/php/20200930/TSRM -I/usr/include/php/20200930/Zend -I/usr/include/php/20200930/ext -I/usr/include/php/20200930/ext/date/lib -I/opt/oracle/instantclient_19_10/sdk/include -DHAVE_CONFIG_H -g -O2 -c /tmp/pear/temp/oci8/oci8_collection.c  -fPIC -DPIC -o .libs/oci8_collection.o
/bin/bash /tmp/pear/temp/pear-build-rootF6jqsy/oci8-2.2.0/libtool --mode=compile cc -I. -I/tmp/pear/temp/oci8 -I/tmp/pear/temp/pear-build-rootF6jqsy/oci8-2.2.0/include -I/tmp/pear/temp/pear-build-rootF6jqsy/oci8-2.2.0/main -I/tmp/pear/temp/oci8 -I/usr/include/php/20200930 -I/usr/include/php/20200930/main -I/usr/include/php/20200930/TSRM -I/usr/include/php/20200930/Zend -I/usr/include/php/20200930/ext -I/usr/include/php/20200930/ext/date/lib -I/opt/oracle/instantclient_19_10/sdk/include  -DHAVE_CONFIG_H  -g -O2    -c /tmp/pear/temp/oci8/oci8_interface.c -o oci8_interface.lo
libtool: compile:  cc -I. -I/tmp/pear/temp/oci8 -I/tmp/pear/temp/pear-build-rootF6jqsy/oci8-2.2.0/include -I/tmp/pear/temp/pear-build-rootF6jqsy/oci8-2.2.0/main -I/tmp/pear/temp/oci8 -I/usr/include/php/20200930 -I/usr/include/php/20200930/main -I/usr/include/php/20200930/TSRM -I/usr/include/php/20200930/Zend -I/usr/include/php/20200930/ext -I/usr/include/php/20200930/ext/date/lib -I/opt/oracle/instantclient_19_10/sdk/include -DHAVE_CONFIG_H -g -O2 -c /tmp/pear/temp/oci8/oci8_interface.c  -fPIC -DPIC -o .libs/oci8_interface.o
/tmp/pear/temp/oci8/oci8_interface.c: In function ‘zif_oci_fetch_all’:
/tmp/pear/temp/oci8/oci8_interface.c:1476:3: warning: implicit declaration of function ‘Z_PARAM_ZVAL_DEREF_EX’; did you mean ‘Z_PARAM_ZVAL_EX’? [-Wimplicit-function-declaration]
   Z_PARAM_ZVAL_DEREF_EX(array,1)
   ^~~~~~~~~~~~~~~~~~~~~
   Z_PARAM_ZVAL_EX
In file included from /usr/include/php/20200930/main/php.h:36:0,from /tmp/pear/temp/oci8/oci8_interface.c:32:
/usr/include/php/20200930/Zend/zend_API.h:1349:2: error: expected ‘;’ before ‘_optional’
  _optional = 1;
  ^
/tmp/pear/temp/oci8/oci8_interface.c:1477:3: note: in expansion of macro ‘Z_PARAM_OPTIONAL’
   Z_PARAM_OPTIONAL
   ^~~~~~~~~~~~~~~~
Makefile:219: recipe for target 'oci8_interface.lo' failed
make: *** [oci8_interface.lo] Error 1
ERROR: `make' failed

我已经在网上搜索过,但 this 是我能找到的关于我的问题的唯一答案。

编辑:经过进一步检查,即使上面的答案也没有解决我的问题。对不起。

解决方法

检查您是否拥有正确的 PHP 头文件 - 路径中的 20200930 看起来很可疑。即使在 Ubuntu 20.20 上,默认的 PHP 7.4 也会将标头安装到 /usr/include/php/20190902 中,那么为什么您的 7.3 标头在 /usr/include/php/20200930 中?

如果这不是问题,请检查您的编译器是否太旧?尝试 'phpize' 安装(参见 here)并添加编译选项以查看宏扩展到的内容。尝试从与您的版本匹配的 PHP 源包中获取 OCI8 目录(并使用 phpize 方法进行安装)。问题不在于 Instant Client。

最后,为什么不升级 Ubuntu 和/或 PHP?

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams['font.sans-serif'] = ['SimHei'] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -> systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping("/hires") public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate<String
使用vite构建项目报错 C:\Users\ychen\work>npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-
参考1 参考2 解决方案 # 点击安装源 协议选择 http:// 路径填写 mirrors.aliyun.com/centos/8.3.2011/BaseOS/x86_64/os URL类型 软件库URL 其他路径 # 版本 7 mirrors.aliyun.com/centos/7/os/x86
报错1 [root@slave1 data_mocker]# kafka-console-consumer.sh --bootstrap-server slave1:9092 --topic topic_db [2023-12-19 18:31:12,770] WARN [Consumer clie
错误1 # 重写数据 hive (edu)> insert overwrite table dwd_trade_cart_add_inc > select data.id, > data.user_id, > data.course_id, > date_format(
错误1 hive (edu)> insert into huanhuan values(1,'haoge'); Query ID = root_20240110071417_fe1517ad-3607-41f4-bdcf-d00b98ac443e Total jobs = 1
报错1:执行到如下就不执行了,没有显示Successfully registered new MBean. [root@slave1 bin]# /usr/local/software/flume-1.9.0/bin/flume-ng agent -n a1 -c /usr/local/softwa
虚拟及没有启动任何服务器查看jps会显示jps,如果没有显示任何东西 [root@slave2 ~]# jps 9647 Jps 解决方案 # 进入/tmp查看 [root@slave1 dfs]# cd /tmp [root@slave1 tmp]# ll 总用量 48 drwxr-xr-x. 2
报错1 hive> show databases; OK Failed with exception java.io.IOException:java.lang.RuntimeException: Error in configuring object Time taken: 0.474 se
报错1 [root@localhost ~]# vim -bash: vim: 未找到命令 安装vim yum -y install vim* # 查看是否安装成功 [root@hadoop01 hadoop]# rpm -qa |grep vim vim-X11-7.4.629-8.el7_9.x
修改hadoop配置 vi /usr/local/software/hadoop-2.9.2/etc/hadoop/yarn-site.xml # 添加如下 <configuration> <property> <name>yarn.nodemanager.res