php - Codeigniter mysql无法在docker中连接

标签 php mysql codeigniter docker nginx

Codeigniter 3.0无法连接本地mysql,请告知原因。

错误消息是 SQLSTATE [HY000] [2002] 连接被拒绝。 我的 Codeigniter 正在 Docker 上运行。

特别是在 mac 中的 Docker

  • php-fpm 7.1
  • MySQL 5.7
  • Nginx 2.4

容器正在工作。

并且该 MySQL 容器可以从 Sequel Pro 或 Mac 终端连接,只有 Codeigniter 可以连接。

来 self 的 Mac 终端的成功连接代码

mysql -uroot -h 127.0.0.1-P 4306 -ppassword

db_test.php

<?php
  try {

    $pdo = new PDO(
    'mysql:dbname=******;host=127.0.0.1;charset=utf8',
    'root',
    'password',
    [
        PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
        PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC,
    ]
   );

} catch (PDOException $e) {

   header('Content-Type: text/plain; charset=UTF-8', true, 500);
   exit($e->getMessage()); 

}

结果 -- SQLSTATE [HY000] [2002] 连接被拒绝。

/config/database.php

}elseif (strpos($_SERVER['SERVER_NAME'],'myname') !== false && ENVIRONMENT != "test"){
// MyLocal Setting
$db['default'] = array(
        'dsn'   => '',
        'hostname' => '127.0.0.1',
  'port' => '4306',
        'username' => 'root',
        'password' => 'password',
        'database' => '******',
        'dbdriver' => 'mysqli',
        'dbprefix' => '',
        'pconnect' => FALSE,
        'db_debug' => TRUE,
        'cache_on' => FALSE,
        'cachedir' => '',
        'char_set' => 'utf8',
        'dbcollat' => 'utf8_general_ci',
        'swap_pre' => '',
        'encrypt' => FALSE,
        'compress' => FALSE,
        'stricton' => FALSE,
        'failover' => array(),
        'save_queries' => TRUE
);

docker-compose.yml

 version: '2'
   services:
     memcached:
     image: memcached:1.4

   data:
    image: busybox
    volumes:
      - ./misc/data:/var/lib/mysql

  mysql:
    image: mysql:5.7
    environment:
      MYSQL_ROOT_PASSWORD: password
      MYSQL_DATABASE: mysql_database
      MYSQL_USER: mysql_user
      MYSQL_PASSWORD: mysql_pw
      socket: /var/run/mysqld/mysqld.sock
    ports:
      - "4306:3306"
    volumes_from:
      - data
    volumes:
      - ../application/initial.sql:/docker-entrypoint-initdb.d/initial.sql
    container_name: mysql
nginx:
    build: ./nginx
    ports:
      - "80:80"
      - "443:443"
    volumes:
      - ./nginx/default.conf:/etc/nginx/conf.d/default.conf
    links:
      - web
    container_name: nginx
    environment:
     - CI_ENV=localhost

  web:
    build: ./php-fpm71
#    build: ./php-fpm56    <- if you want to use PHP5.6
    volumes:
      - /Users/alberorana/codeigniter/suke10:/var/www/html/suke10
      - ./php-fpm71/php.ini:/usr/local/etc/php/conf.d/php.ini
    links:
      - mysql
    environment:
      DATABASE_HOST: '0.0.0.0'
      DATABASE_NAME: 'suke10'
      DATABASE_USER: 'root'
      DATABASE_PASSWORD: 'password'
    container_name: web

MySQL 容器中的etc/mysql/mysql.conf.d/mysqld.cnf

[mysqld]
pid-file        = /var/run/mysqld/mysqld.pid
socket          = /var/run/mysqld/mysqld.sock
datadir         = /var/lib/mysql
#log-error      = /var/log/mysql/error.log
# By default we only accept connections from localhost
#bind-address   = 127.0.0.1
# Disabling symbolic-links is recommended to prevent assorted security risks
symbolic-links=0

最佳答案

您的 php 容器内的数据库连接是:

 mysql:3306

由于您在 Compioser 文件中将 phpcontainer“链接”到数据库容器,并且链接是在您的主机文件中添加一行的本质,因此 mysql 将为您指向内部 docker-network 中的 IP 。

关于php - Codeigniter mysql无法在docker中连接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48039626/

相关文章:

php - 使用 PHP SSH 连接

Javascript : Destroy tippy. js实例

javascript - jquery在点击时更改div的背景图片

php - php mysql替换中的英镑符号问题

php - 如何按 ON、OFF、SOLD 对行进行排序

php - 无法在 Codeigniter 中更新数据库查询

php - 将两个表中的重复记录合并到一个表中

php - 如果有的话,我需要做什么来确保 $mdb2->lastInsertID() 返回该连接的自动增量值?

javascript - 如果密码匹配则启用按钮

php - 将特定日期的多个时差相加