三个容器docker-composition:PHP无法连接到Maria DB

时间:2019-03-04 14:14:57

标签: php mysql docker mysqli docker-compose

我的docker-compose.yml:

version: '3'
services:
    php-apache:
        build:
            context: ./php-apache
        ports:
            - 80:80
        volumes:
            - ./DocumentRoot:/var/www/html
        links:
            - 'db'
        networks:
            - default

    db:
        image: mariadb:10.1
        volumes:
            - ./db:/var/lib/mysql
            - ./dump.sql:/docker-entrypoint-initdb.d/dump.sql            

        ports: 
            - "3306:3306"            
        environment:
            TZ: "Europe/London"
            MYSQL_ALLOW_EMPTY_PASSWORD: "no"
            MYSQL_ROOT_PASSWORD: "rootpwd"
            MYSQL_USER: 'testuser'
            MYSQL_PASSWORD: 'testpassword'
            MYSQL_DATABASE: 'testdb'
        networks:
            - default

    phpmyadmin:
        image: phpmyadmin/phpmyadmin
        links: 
            - 'db'
        ports:
            - 8000:80
        environment:
            MYSQL_USER: 'testuser'
            MYSQL_PASSWORD: 'testpassword'
            MYSQL_ROOT_PASSWORD: 'rootpwd'
            PMA_HOST: db
            PMA_PORT: 3306

这是基于我在网上找到的教程。

运行它时,可以看到PHP容器已启动。我可以看到db和php-mydmin已启动。实际上,我可以使用testuser / testpassword凭据从php-myadmin成功访问数据库。

但是当我尝试使用

从主PHP应用程序访问数据库时
$conn = mysqli_connect("localhost","testuser",'testpassword','testdb'); 

我知道

Warning: mysqli_connect(): (HY000/2002): No such file or directory in /var/www/html/index.php on line 8

这是docker config的问题吗?有人可以看到遗漏的东西吗?

0 个答案:

没有答案