OCI8 未通过 Docker 出现在 PHP-FPM7.2 中

OCI8 not showing up in PHP-FPM7.2 via Docker

下面是我的 Dockerfile。 instantclient、php.ini 和其他复制的文件与 Dockerfile 在相同的上下文中。

FROM ubuntu
# Forward request logs to Docker log collector
#RUN ln -sf /dev/stdout /var/log/nginx/access.log && ln -sf /dev/stderr /var/log/nginx/error.log
ENV TZ=America/Denver
RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone
ENV DEBIAN_FRONTEND noninteractive
ENV DEBIAN_FRONTEND teletype

RUN mkdir -p /etc/php/7.2/fpm
COPY php.ini /etc/php/7.2/fpm/php.ini
COPY php-fpm.conf /etc/php/7.2/fpm/php-fpm.conf

# General image, nginx and php-fpm7.2
RUN apt update
RUN apt-get install -y apt-utils
RUN apt-get install -y gnupg
RUN apt-get install -y curl
RUN apt-get install -y libaio1
RUN apt-get install -y php-pear
RUN apt-get install -y supervisor
RUN pecl config-set php_ini /etc/php/7.2/fpm/php.ini
RUN pear config-set php_ini /etc/php/7.2/fpm/php.ini
RUN mkdir -p /var/log/supervisor
RUN apt-get install -y nginx php7.2-fpm php7.2-bcmath php7.2-bz2 php7.2-curl \
php7.2-dba php7.2-dev php7.2-gd php7.2-imap php7.2-intl php7.2-json php7.2-ldap \
php7.2-mbstring php7.2-mysql php7.2-odbc php7.2-opcache php7.2-pspell \
php7.2-readline php7.2-snmp php7.2-soap php7.2-sqlite3 php7.2-tidy php7.2-xml \
php7.2-xmlrpc php7.2-zip php7.2-cli php-memcached php7.2-common

# Oracle OCI8 php driver install
RUN mkdir -p /opt/oracle
COPY instantclient /opt/oracle/instantclient
RUN cd /opt/oracle/instantclient/ && ln -s libclntsh.so.12.1 libclntsh.so && ln -s libocci.so.12.1 libocci.so
RUN echo /opt/oracle/instantclient > /etc/ld.so.conf.d/oracle-instantclient
RUN cd /opt/oracle/instantclient/ && ldconfig
RUN pecl channel-update pecl.php.net
RUN echo 'instantclient,/opt/oracle/instantclient' | pecl install oci8

# Microsft SQL driver install
RUN curl https://packages.microsoft.com/keys/microsoft.asc | apt-key add -
RUN curl https://packages.microsoft.com/config/ubuntu/18.04/prod.list | tee /etc/apt/sources.list.d/mssql-tools.list
RUN apt update
RUN echo 'y' | ACCEPT_EULA=Y apt-get install mssql-tools
RUN apt-get install unixodbc-dev
RUN pecl install sqlsrv pdo_sqlsrv

EXPOSE 80

STOPSIGNAL SIGTERM

COPY supervisord.conf /etc/supervisor/supervisord.conf

CMD ["/usr/bin/supervisord", "-n"]

一切安装正常,所有模块在 phpinfo() 中显示为已配置模块,但 OCI8 除外。这是构建 php 模块时的输出。这意味着它安装正确。

Libraries have been installed in:
   /tmp/pear/temp/pear-build-defaultuserAp5K7k/oci8-2.1.8/modules

Build complete.
Don't forget to run 'make test'.

running: make INSTALL_ROOT="/tmp/pear/temp/pear-build-defaultuserAp5K7k/install-oci8-2.1.8" install
Installing shared extensions:     /tmp/pear/temp/pear-build-defaultuserAp5K7k/install-oci8-2.1.8/usr/lib/php/20170718/
running: find "/tmp/pear/temp/pear-build-defaultuserAp5K7k/install-oci8-2.1.8" | xargs ls -dils
557351   4 drwxr-xr-x 3 root root   4096 Nov  6 15:03 /tmp/pear/temp/pear-build-defaultuserAp5K7k/install-oci8-2.1.8
557355   4 drwxr-xr-x 3 root root   4096 Nov  6 15:03 /tmp/pear/temp/pear-build-defaultuserAp5K7k/install-oci8-2.1.8/usr
557356   4 drwxr-xr-x 3 root root   4096 Nov  6 15:03 /tmp/pear/temp/pear-build-defaultuserAp5K7k/install-oci8-2.1.8/usr/lib
557357   4 drwxr-xr-x 3 root root   4096 Nov  6 15:03 /tmp/pear/temp/pear-build-defaultuserAp5K7k/install-oci8-2.1.8/usr/lib/php
557358   4 drwxr-xr-x 2 root root   4096 Nov  6 15:03 /tmp/pear/temp/pear-build-defaultuserAp5K7k/install-oci8-2.1.8/usr/lib/php/20170718
552433 664 -rwxr-xr-x 1 root root 676904 Nov  6 15:03 /tmp/pear/temp/pear-build-defaultuserAp5K7k/install-oci8-2.1.8/usr/lib/php/20170718/oci8.so

Build process completed successfully
Installing '/usr/lib/php/20170718/oci8.so'
install ok: channel://pecl.php.net/oci8-2.1.8
Extension oci8 enabled in php.ini

原来你需要两个环境变量

RUN echo "LD_LIBRARY_PATH=\"/opt/oracle/instantclient\"" >> /etc/environment \
&& echo "ORACLE_HOME=\"/opt/oracle/instantclient\"" >> /etc/environment