找不到PHP docker pdo_mysql驱动程序

时间:2018-03-27 19:47:55

标签: php symfony docker pdo docker-compose

我正在尝试用php7.1 docker创建一个开发环境。无论我出于某种原因尝试什么,它都说“驱动程序中出现异常:无法找到驱动程序 “。

我搜索了很多帖子,但没有找到解决我问题的答案。

我正在使用以下dockerfile和docker-compose.yml:

FROM php:7.1-apache
COPY dockerConfig/php.ini /usr/local/etc/php/
RUN apt-get update \
    && apt-get install -y libfreetype6-dev libjpeg62-turbo-dev libpng12-dev \
    && docker-php-ext-configure gd --with-freetype-dir=/usr/include/ --with-jpeg-dir=/usr/include/ \
    && docker-php-ext-install gd

# Install MCrypt
RUN apt-get update \
    && apt-get install -y libmcrypt-dev \
    && docker-php-ext-install mcrypt

# Install Intl
RUN apt-get update \
    && apt-get install -y libicu-dev \
    && docker-php-ext-install intl



# Install Mysql
RUN docker-php-ext-install pdo pdo_mysql

# Install opcache
RUN docker-php-ext-install opcache


# Configure Apache Document Root
ENV APACHE_DOC_ROOT /var/www/html

# Enable Apache mod_rewrite
RUN a2enmod rewrite


COPY dockerConfig/mysite.local.conf /etc/apache2/sites-available/mysite.local.conf
RUN a2ensite mysite.local.conf
RUN a2dissite 000-default.conf

COPY / /var/www/html


RUN service apache2 restart



version: '3'
services:
    mysite-web:
        networks:
            mysite:
                ipv4_address: 178.17.10.3
        build:
            context: .
            dockerfile: Dockerfile
        volumes:
            - $PWD:/var/www/html

        container_name: mysite-dev-running

networks:
    mysite:
        driver: bridge
        ipam:
            config:
                - subnet: 178.17.10.0/24

构建步骤:

  1. docker image rm(手动删除所有图像)
  2. docker rm xxxxx(手动删除所有容器)
  3. docker-compose build --no-cache
  4. docker-compose up -d
  5. 导航到网站symfony页面,我找不到驱动程序。转储php信息,我得到enter image description here

    enter image description here

    然后我创建了一个脚本来调用来自exec的“php -m”的url和var_dumps给我的结果

    array(42) { [0]=> string(13) "[PHP Modules]" [1]=> string(4) "Core" [2]=> string(5) "ctype" [3]=> string(4) "curl" [4]=> string(4) "date" [5]=> string(3) "dom" [6]=> string(8) "fileinfo" [7]=> string(6) "filter" [8]=> string(3) "ftp" [9]=> string(2) "gd" [10]=> string(4) "hash" [11]=> string(5) "iconv" [12]=> string(4) "intl" [13]=> string(4) "json" [14]=> string(6) "libxml" [15]=> string(8) "mbstring" [16]=> string(6) "mcrypt" [17]=> string(7) "mysqlnd" [18]=> string(7) "openssl" [19]=> string(4) "pcre" [20]=> string(3) "PDO" [21]=> string(9) "pdo_mysql" [22]=> string(10) "pdo_sqlite" [23]=> string(4) "Phar" [24]=> string(5) "posix" [25]=> string(8) "readline" [26]=> string(10) "Reflection" [27]=> string(7) "session" [28]=> string(9) "SimpleXML" [29]=> string(3) "SPL" [30]=> string(7) "sqlite3" [31]=> string(8) "standard" [32]=> string(9) "tokenizer" [33]=> string(3) "xml" [34]=> string(9) "xmlreader" [35]=> string(9) "xmlwriter" [36]=> string(12) "Zend OPcache" [37]=> string(4) "zlib" [38]=> string(0) "" [39]=> string(14) "[Zend Modules]" [40]=> string(12) "Zend OPcache" [41]=> string(0) "" }
    

    所以pdo_mysql看起来似乎是从apache的角度安装的,但不知何故没有启用。

    奇怪的是,我有另一个使用symfony和几乎相同的docker配置的项目,并且该项目有效。

    有什么想法吗?

    谢谢!

    更新

    事实证明我的一些遗留代码包含了一个php.ini文件apache正在使用那个而不是/ usr / local / etc / php中的正确代码,而且那个代码没有包含pdo_mysql的必要配置。

1 个答案:

答案 0 :(得分:1)

试试这个。 使用以下任何一种方法找到您的php.ini文件。

<?php phpinfo(); ?>
<?php echo php_ini_loaded_file(); ?> 

- OR / bin / bash到您的容器中并运行其中一个命令

php --ini
php -i | grep 'php.ini'
find / -name php.ini

从以下行取消注释(删除;)

extension=pdo.so
extension=pdo_mysql.so
extension=pdo_sqlite.so
extension=mysql.so

保存,退出并运行

service apache2 restart