Laravel Docker - SQLSTATE[HY000] [2002] php_network_getaddresses:getaddrinfo 失败:名称或服务未知

joh*_*ith 3 php laravel docker docker-compose

在我的容器中,当我运行php artisan migrate 时,我不断收到此错误

In Connector.php line 67:

  SQLSTATE[HY000] [2002] php_network_getaddresses: getaddrinfo failed: Name or service not known


In Connector.php line 67:

  PDO::__construct(): php_network_getaddresses: getaddrinfo failed: Name or service not known
Run Code Online (Sandbox Code Playgroud)

这是我的 .ENV 文件

APP_NAME=Laravel
APP_ENV=local
APP_KEY=base64:etukbJpSLgbRsdf5uOEGtLT5Qw+XB6y06Q38HPr
APP_DEBUG=true
APP_LOG_LEVEL=debug
APP_URL=http://127.0.0.1:8000/

DB_CONNECTION=mysql
DB_HOST=localhost
DB_PORT=3306
DB_DATABASE=project
DB_USERNAME=root
DB_PASSWORD=


BROADCAST_DRIVER=log
CACHE_DRIVER=file
SESSION_DRIVER=file
SESSION_LIFETIME=120
QUEUE_DRIVER=sync

PUSHER_APP_ID=
PUSHER_APP_KEY=
PUSHER_APP_SECRET=
PUSHER_APP_CLUSTER=mt1
Run Code Online (Sandbox Code Playgroud)

我试图将 DB_HOST 更改为 mysql 但结果仍然相同,并将其更改为 mariadb

这是我的 docker-compose 文件

version: '3'
services:

 # The Application
  app:
    build:
      context: ./
      dockerfile: app.dockerfile
    working_dir: /var/www
    volumes:
      - ../.:/var/www
      - ./custom.ini:/usr/local/etc/php/conf.d/custom.ini
    environment:
      - "DB_PORT=3306"
      - "DB_HOST=database"

 # The Web Server
  web:
    build:
      context: ./
      dockerfile: web.dockerfile
    working_dir: /var/www
    volumes:
      - ../.:/var/www
      - ./vhost.conf:/etc/nginx/conf.d/default.conf
    ports:
      - 8082:80

  # The Database
  database:
    image: mysql:5.7
    volumes:
      - dbdata:/var/lib/mysql
    environment:
      MYSQL_USER: ${DB_USERNAME}
      MYSQL_DATABASE: ${DB_DATABASE}
      MYSQL_ROOT_PASSWORD: ${DB_PASSWORD}
    ports:
        - "33061:3306"

volumes:
  dbdata:
Run Code Online (Sandbox Code Playgroud)

我在网上搜索了解决方案,但没有一个有帮助。有没有人对我为什么不断收到该错误有任何建议?

Ram*_*med 6

您应该将 container_name 添加到您的数据库服务

database:
image: mysql:5.7
container_name: database
Run Code Online (Sandbox Code Playgroud)

并在您的 .env MYSQL_HOST 中引用该名称:

MYSQL_CONNECTION=mysql
MYSQL_HOST=database
MYSQL_PORT=3306
Run Code Online (Sandbox Code Playgroud)

而不是使用本地主机

您还应该使用网络连接数据库服务和应用程序

在 docker-compose 的末尾添加一个网络块

networks:
  app-network:
    driver: bridge
Run Code Online (Sandbox Code Playgroud)

并将此块添加到数据库服务和应用程序服务的末尾

demo_db:
   .
   .
   .    
   networks:
      - app-network
  app:
   .
   .
   .
   networks:
      - app-network
Run Code Online (Sandbox Code Playgroud)

这是一个用于 dockerizing 一个简单的 laravel 应用程序的工作演示

https://bitbucket.org/RamiAmro/hello-laravel-docker/

  • 除了 Compose 提供的“default:”之外,您既不需要“container_name:”也不需要网络来进行容器间通信。在原始问题的“docker-compose.yml”文件中,“database”应该可以用作 DNS 名称,无需任何修改。 (2认同)