php连接docker-compose里面的mysql数据库

docker-compose配置文件:

version: '3'
services:
  mysql:
   image: "mysql:5.7.19"
   container_name: ysp_mysql_57
   environment:
       TZ: Asia/Shanghai
       MYSQL_ROOT_PASSWORD: "123456"
   restart: always
   command:
       --character-set-server=utf8mb4
       --collation-server=utf8mb4_general_ci
       --explicit_defaults_for_timestamp=true
       --lower_case_table_names=1
       --max_allowed_packet=128M
       --default-authentication-plugin=mysql_native_password
       --sql-mode="STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION,NO_ZERO_DATE,NO_ZERO_IN_DATE,ERROR_FOR_DIVISION_BY_ZERO"
   volumes:
       - mysql-data:/var/lib/mysql
   ports:
       - "3357:3306"

  web:
   image: nginx:latest
   container_name: ysp_nginx
   ports:
   - "80:80"
   - "89:89"
   restart: always
   volumes:
   - D:\www:/opt/WebRoot

   - ./nginx/nginx.conf:/etc/nginx/nginx.conf
   - ./nginx/conf.d:/etc/nginx/conf.d/:ro
   environment:
   - TZ=Asia/Shanghai
   links:
   - php

  php:
   image: registry.gz.xx.cn/xx/php:7.3.0
   container_name: ysp_php_70
   ports:
   - "9000"
   restart: always
   volumes:
   - D:\www:/opt/WebRoot
   - ./php/conf/php-fpm.conf:/usr/local/etc/php-fpm.conf
   - ./php/conf/www.conf:/usr/local/etc/php-fpm.d/www.conf
   environment:
   - TZ=Asia/Shanghai
   - LC_ALL=C.UTF-8
   links:
   - mysql

  redis:
   image: redis
   container_name: ysp_redis
   ports:
   - "6379:6379"
   environment:
   - TZ=Asia/Shanghai
   volumes:
       - redis_data:/var/lib/redis
volumes:
  mysql-data:
  redis_data:

docker-compose启动:

docker-compose up -d

注意修改 docker-compose.yml之后,需要运行:

docker-compose down

这个命令会删除原来的容器,并重新加载yml配置文件。

php连接docker-compose里面的mysql:

class TestController extends AppController {

    public function test() {
        $dsn = 'mysql:dbname=mysql;host=mysql;port=3306';
        $username = 'root';
        $password = '123456';
        try {
            $db = new PDO($dsn, $username, $password);
        } catch (PDOException $e) {
            die('Could not connect to the database:' . $e);
        }
        $statement = <<<SQL
    	    SELECT *
    	    FROM `user`
SQL;
        $sth = $db->prepare($statement);
        $sth->execute();

/* 获取结果集中所有剩余的行 */
        print("Fetch all of the remaining rows in the result set:\n");
        $result = $sth->fetchAll();
        echo "<pre>";
        print_r($result); // phpinfo();
        echo "</pre>";
        exit;
        die('safdsa');
    }

在这里插入图片描述

参考:

https://www.digitalocean.com/community/tutorials/how-to-set-up-laravel-nginx-and-mysql-with-docker-compose

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

SHUIPING_YANG

你的鼓励是我创作的最大动力。

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值