dockers配置MySQL链接数据库的时候报错如何解决的?

<?php
 header('Content-type:text/html; charset=utf-8');
 $dbms='mysql';     //数据库类型
 $host='172.17.0.2'; //此处得写docker下对应的mysql对应的ip地址才可以
 $dbport = '3306';
 $dbName='user';    //使用的数据库
 $user='root';      //数据库连接用户名
 $pass='hongyou';          //对应的密码
 $dsn="$dbms:host=$host;port=$dbport;dbname=$dbName";

    $dbh = new PDO($dsn, $user, $pass); //初始化一个PDO对象
        $dbh->exec('set names utf8');//设置编码
        foreach ($dbh->query('SELECT id,name,mobile from user where status=0') as $row) {
         $list[] = $row;
     }

 

配置好lnmp环境,mysql没有安装成功,使用docker去安装的mysql

启动 MySQL 容器

docker pull mysql:5.7

docker run -d -p3307:3306 --name dockermysql -e MYSQL_ROOT_PASSWORD=jinlei mysql:5.7
当去测试一下,在php调用Mysql是否相通的时候,$host改成mysql容器的名称,报错,连接不成功

后来去查了资料需要找到对应容器的具体的ip地址才可以

具体用法是:

docker inspect mysql-container-id # 找到里面的IPAddress即可

docker ps 找到mysql的容器的id

docker inspect 86bd77c7f1ce 看到了对应的Ip,改成对应的Ip就可以了


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值