繁体   English   中英

Docker容器已链接但mysql无法连接

[英]Docker containers linked but mysql cannot be connected to

我是docker的新手,并且为使我的系统运行而奋斗了两天。 我的撰写文件创建了nginx,php-fpm,mysql和phpmyadmin容器。 我可以互相ping通所有容器。 但是,当我尝试将已安装的public_html卷中的任何内容安装到数据库中时(例如安装需要在数据库中创建表的应用程序),该应用程序完全无法连接到数据库。 我已确保一遍又一遍的凭据是正确的。 对于我的一生,我不知道我要去哪里错。 任何帮助将不胜感激。 我在下面包括我的撰写文件:

version: '3'
services:   
www:
container_name: site1-www
image: nginx:1.13.7-alpine
expose:
  - "80"
ports: 
  - 8001:80
networks:
  datacentre:
    aliases:
      - site1www  
env_file:
  - ".env"
environment:
  - NGINX_HOST=localhost
volumes:
  - /mnt/www/site1.test/public_html:/usr/share/nginx/html/
  - 
/mnt/www/site1.test/conf/default.conf:/etc/nginx/conf.d/default.conf
depends_on:
  - db
links
  - db

phpfpm:
build: ./phpfpm
container_name: site1-phpfpm
networks:
  datacentre:
    aliases:
      - site1php
volumes:
  - /mnt/www/site1.test/public_html:/usr/share/nginx/html
  - /mnt/www/site1.test/conf/php.ini:/usr/local/etc/php/php.ini
depends_on:
  - db
links
  - db

db:
container_name: site1-db
image: mariadb:10.3.2
ports:
  - 3400:3306  
env_file:
  - ".env"
environment:
  - MYSQL_DATABASE=test1db
  - MYSQL_ROOT_PASSWORD=password
  - MYSQL_USER=test1user
  - MYSQL_PASSWORD=password
networks:
  datacentre:
    aliases:
      - site1db
volumes:
  - /mnt/dbdata:/var/lib/mysql

dbadmin:
image: phpmyadmin/phpmyadmin:latest
container_name: site1-dbadmin
ports:
  - 8000:80
networks:
  datacentre:
    aliases:
      - site1dbadmin
environment:
  - PMA_ARBITRARY=1
  - PMA_HOST=mysql
depends_on:
  - db
links
  - db

networks:
  datacentre:
    external:
      name: datacentre_net

初拍时的构图设置看起来有些复杂。 删除所有名称和别名,并使用服务名称进行连接。 然后从那里开始。

对于www服务,nginx应该将phpfpm:9000配置为FastCGI worker。

您的PHP应用程序和phpMyAdmin应该配置为连接到db:3306

version: '3'

services:   
  www:
    image: nginx:1.13.7-alpine
    ports: 
      - 8001:80
    env_file:
      - ".env"
    environment:
      - NGINX_HOST=localhost
    volumes:
      - /mnt/www/site1.test/public_html:/usr/share/nginx/html/
      - /mnt/www/site1.test/conf/default.conf:/etc/nginx/conf.d/default.conf
    depends_on:
      - phpfpm

  phpfpm:
    build: ./phpfpm
    volumes:
      - /mnt/www/site1.test/public_html:/usr/share/nginx/html
      - /mnt/www/site1.test/conf/php.ini:/usr/local/etc/php/php.ini
    depends_on:
      - db

  db:
    image: mariadb:10.3.2
    ports:
      - 3400:3306  
    env_file:
      - ".env"
    environment:
      - MYSQL_DATABASE=test1db
      - MYSQL_ROOT_PASSWORD=password
      - MYSQL_USER=test1user
      - MYSQL_PASSWORD=password
    volumes:
      - /mnt/dbdata:/var/lib/mysql

  dbadmin:
    image: phpmyadmin/phpmyadmin:latest
    ports:
      - 8000:80
    environment:
      - PMA_ARBITRARY=1
      - PMA_HOST=db
    depends_on:
      - db

不需要links即可访问用户定义的网络上的服务。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM