【问题标题】:Not able to connect to mysql container from php container无法从 php 容器连接到 mysql 容器
【发布时间】:2020-04-17 14:11:36
【问题描述】:

我有 2 个用于 php 应用程序和 mysql 的 docker 容器。两者都可以完美地单独工作。我可以在localhost:8000 访问我的php 应用程序,并且可以使用MySQL Workbench 在localhost:3306 连接mysql。

但是,我在容器内的 php 应用程序无法连接到另一个容器内的 mysql db。

我的 docker-compose.yml 文件如下:

    version: '3'
    services:
      website:
        container_name: php-app
        image: php-app
        build:
          context: ./
        volumes:
          - php-app:/var/www/html/
        ports:
          - 8000:80
        depends_on:
          - mysql
      mysql:
        image: mysql:8.0
        container_name: mysql-server-80
        command: --default-authentication-plugin=mysql_native_password
        volumes:
          - .:/application
        restart: always
        environment:
          - MYSQL_ROOT_PASSWORD=123456
          - MYSQL_DATABASE=testdb
          - MYSQL_USER=root
          - MYSQL_PASSWORD=123456
        ports:
          - "3306:3306"
    volumes:
      jayde-ci:
      mysql:

我在基于 codeigniter 的 php 应用程序中的数据库配置文件如下:

    $db['default'] = array(
        'dsn'   => '',
        'hostname' => 'mysql',
        'username' => 'root',
        'password' => '123456',
        'database' => 'test',
        'dbdriver' => 'mysqli',
        'dbprefix' => '',
        'pconnect' => FALSE,
        'db_debug' => (ENVIRONMENT !== 'production'),
        'cache_on' => FALSE,
        'cachedir' => '',
        'char_set' => 'utf8',
        'dbcollat' => 'utf8_general_ci',
        'swap_pre' => '',
        'encrypt' => FALSE,
        'compress' => FALSE,
        'stricton' => FALSE,
        'failover' => array(),
        'save_queries' => TRUE
    );

【问题讨论】:

  • 您是否也尝试过在配置中使用 localhost -'hostname' => 'localhost',
  • @NigelRen 我也试过 localhost
  • 假设php-app 是一个普通的命名卷,您的volumes: ['php-app:/var/www/html/'] 声明将阻止容器查看镜像源代码的更新。如果有一次您在此文件中包含不正确的信息,它会一直停留在那里,直到您明确删除该卷。

标签: php mysql docker docker-compose containers


【解决方案1】:

您应该将本地主机上的密码设置为空白。试试这个

$db['default'] = array(
        'dsn'   => '',
        'hostname' => 'mysql',
        'username' => 'root',
        'password' => '',
        'database' => 'test',
        'dbdriver' => 'mysqli',
        'dbprefix' => '',
        'pconnect' => FALSE,
        'db_debug' => (ENVIRONMENT !== 'production'),
        'cache_on' => FALSE,
        'cachedir' => '',
        'char_set' => 'utf8',
        'dbcollat' => 'utf8_general_ci',
        'swap_pre' => '',
        'encrypt' => FALSE,
        'compress' => FALSE,
        'stricton' => FALSE,
        'failover' => array(),
        'save_queries' => TRUE
    );

【讨论】:

    猜你喜欢
    • 2020-01-20
    • 2020-02-25
    • 1970-01-01
    • 1970-01-01
    • 2020-12-30
    • 2020-07-29
    • 1970-01-01
    • 2022-01-22
    • 2019-11-25
    相关资源
    最近更新 更多