用php连接mysql的docker问题

beq87vna  于 2021-06-15  发布在  Mysql
关注(0)|答案(1)|浏览(481)

我从docker开始,我想使用pdo驱动程序连接到我的数据库。但不幸的是,我有一个错误,出现在我的网页,我不知道如何解决它。你能帮帮我吗?
这是我的错误:
致命错误:未捕获的pdoexception:pdo::uuuu construct():php\u network\u getaddresses:getaddrinfo失败:没有与主机名关联的地址
以下是my index.php:

<?php
    $db = new PDO('mysql:host=db:3306;dbname:DockerProject', "root", "root");
?>

这是我的文件:

FROM php:7.2-apache
RUN apt-get update && apt-get install -y libpng-dev libjpeg-dev libpq-dev \
&& rm -rf /var/lib/apt/lists/* \
&& docker-php-ext-configure gd --with-png-dir=/usr --with-jpeg-dir=/usr \
&& docker-php-ext-install gd mbstring pdo pdo_mysql pdo_pgsql

这是我的docker-compose.yaml:

version: '3'

services:
  db:
    image: mysql:5.7
    environment:
      MYSQL_ROOT_PASSWORD: root
      MYSQL_DATABASE: DockerProject
      MYSQL_USER: devuser
      MYSQL_PASSWORD: devpass
    ports:
      - "3306:3306"
  web:
    image: php_pdo:latest
    container_name: php_web
    depends_on:
      - db
    volumes:
      - ./php/:/var/www/html/
    ports:
      - "8100:80"
    stdin_open: true
    tty: true
  myadmin:
    image: phpmyadmin/phpmyadmin
    ports:
        - "8080:80"
    links:
        - db:db
nfeuvbwi

nfeuvbwi1#

将dsn定义为

$db = new PDO('mysql:host=db;dbname=DockerProject', "root", "root");

如果需要显式定义端口,请使用:

$db = new PDO('mysql:host=db;port=3306;dbname=DockerProject', "root", "root");

还有,不知道为什么 dbname:DockerProject 按照正确的语法工作 dbname=DockerProject .

相关问题