我有一个工作的php-fpm docker容器,充当nginx前端的php后端。我的意思是,它可以按预期方式在浏览器中呈现phpinfo输出。
我的php-fpm容器是由devilbox docker repo的php-fpm-7.4产品生产的。它具有OCI8使能。
问题:尝试oci_connect时,我一直收到ORA-28547
我做了什么:
1-将/ usr / lib / oracle / client64 / lib添加到ld.so.conf.d中的文件并运行ldconfig -v
2-重新启动Docker容器。
3--现在phpinfo显示ORACLE_HOME = / usr / lib / oracle / client64 / lib
4--将tnsnames.ora添加到/ usr / lib / oracle / client6 / lib / network / admin(该文件夹中有一个README.md文件,甚至告诉您执行此操作)
5-重新启动Docker容器。
6-oci_connect仍然失败,并显示相同的错误。
我缺少什么?
非常感谢您提出任何建议,我想我已经浏览了互联网的尽头,没有找到解决方案。
----解决方案:重新安装InstantClient,重新链接库(ldconfig)以使用新的InstantClient库。创建修改后的dockerfile以在创建容器时执行此操作。
我修改了php-fpm的Dockerfile文件,以添加新的即时客户端文件,而不是原始文件提供的文件。我无法使其与他们合作。我尝试了几次重建镜像(docker-compose up --build),这是完成技巧的文件:
来自devilbox / php-fpm:7.4-work
#instantclient.conf内容:/ opt / instantclient
RUN echo“/ opt / instantclient”> /etc/ld.so.conf.d/instantclient.conf
WORKDIR / opt
运行wget https://download.oracle.com/otn_software/linux/instantclient/19800/instantclient-sdk-linux.x64-19.8.0.0.0dbru.zip
运行wget https://download.oracle.com/otn_software/linux/instantclient/19800/instantclient-sqlplus-linux.x64-19.8.0.0.0dbru.zip
运行wget https://download.oracle.com/otn_software/linux/instantclient/19800/instantclient-basic-linux.x64-19.8.0.0.0dbru.zip
运行解压缩Instantclient-sdk-linux.x64-19.8.0.0.0dbru.zip
运行解压Instantclient-sqlplus-linux.x64-19.8.0.0.0dbru.zip
运行解压Instantclient-basic-linux.x64-19.8.0.0.0dbru.zip
运行MV Instantclient_19_8 InstantClient
添加tnsnames.ora / opt / instantclient / network / admin
运行ldconfig -v
CMD [“php-fpm”]
暴露9000
最佳答案
你能检查一下吗
https://github.com/caffeinalab/php-fpm-oci8/blob/master/Dockerfile
这似乎会创建一个p-fpm-oci8 docker 形象
“wget”的
wget -qO- https://raw.githubusercontent.com/caffeinalab/php-fpm-oci8/master/oracle/instantclient-basic-linux.x64-12.2.0.1.0.zip | bsdtar -xvf- -C / usr / local &&
wget -qO- https://raw.githubusercontent.com/caffeinalab/php-fpm-oci8/master/oracle/instantclient-sdk-linux.x64-12.2.0.1.0.zip | bsdtar -xvf- -C / usr / local &&
wget -qO- https://raw.githubusercontent.com/caffeinalab/php-fpm-oci8/master/oracle/instantclient-sqlplus-linux.x64-12.2.0.1.0.zip | bsdtar -xvf- -C / usr / local && \
将下载的即时客户端文件放入本地主机目录时可以删除
/ usr /本地
并提取它们-导致
/ usr / local / instantcient_12_2
或18、19c当量
必须调整4个“ln”命令以反射(reflect)本地主机InstantClient目录
主机可通过VOLUME命令访问InstantClient的tnsnames.ora
-------------最终解决方案------------((与网络无关,我对文件做了几处更改,还尝试了另一种数据库,同时解决了所有问题,这让我认为是由不同的数据库解决了该问题)
经过多次尝试和错误之后,我想到了一个Dockerfile,该文件创建正确的文件配置并连接到数据库,而没有任何问题:
--Dockerfile:(使用devilbox镜像构建php-fpm 7.4)
Final solution:
我修改了php-fpm的Dockerfile文件,以添加新的即时客户端文件,而不是原始文件提供的文件。我无法使其与他们合作。我尝试了几次重建镜像(docker-compose up --build),这是完成技巧的文件:来自devilbox / php-fpm:7.4-work
添加Instantclient.conf /etc/ld.so.conf.d/
WORKDIR / opt
运行wget https://download.oracle.com/otn_software/linux/instantclient/19800/instantclient-sdk-linux.x64-19.8.0.0.0dbru.zip
运行wget https://download.oracle.com/otn_software/linux/instantclient/19800/instantclient-sqlplus-linux.x64-19.8.0.0.0dbru.zip
运行wget https://download.oracle.com/otn_software/linux/instantclient/19800/instantclient-basic-linux.x64-19.8.0.0.0dbru.zip
运行解压缩Instantclient-sdk-linux.x64-19.8.0.0.0dbru.zip
运行解压Instantclient-sqlplus-linux.x64-19.8.0.0.0dbru.zip
运行解压Instantclient-basic-linux.x64-19.8.0.0.0dbru.zip
运行MV Instantclient_19_8 InstantClient
添加tnsnames.ora / opt / instantclient / network / admin
运行ldconfig -v
CMD [“php-fpm”]
暴露9000
关于php - 在Docker容器中使用php-fpm的ORA-28547,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/64403671/