【问题标题】:Docker - nginx: host not found in upstreamDocker - nginx:在上游找不到主机
【发布时间】:2018-03-03 21:44:14
【问题描述】:

我下载了官方的 docker 包,然后我设置了 docker-compose。一切编译正常,但如果我得到 docker-compose up,我会收到以下错误消息:

project-websrv | 2017/09/22 10:18:35 [emerg] 1#1: host not found in upstream "php-fpm" in /etc/nginx/conf.d/default.conf:25
project-websrv | nginx: [emerg] host not found in upstream "php-fpm" in /etc/nginx/conf.d/default.conf:25
project-php exited with code 0

nginx.conf 第 25 行:

fastcgi_pass php-fpm:9000;

我的 docker-compose.yml

version: "3.1"
services:

    mysql:
      image: mariadb
      container_name: project-mariadb
      environment:
        MYSQL_ROOT_PASSWORD: root

    phpmyadmin:
      image: phpmyadmin/phpmyadmin
      container_name: project-pma
      restart: always
      links:
        - mysql
      ports:
        - 8183:80
      environment:
        PMA_HOST: mysql
        PMA_USER: root
        PMA_PASSWORD: root

    php-fpm:
      build: php
      container_name: project-php
      working_dir: /var/www/project
      volumes:
        - ../../Sources/project/trunk/src/:/var/www/project
        - ./php/php-ini-overrides.ini:/etc/php/7.0/fpm/conf.d/99-overrides.ini
      links:
        - mysql      

    webserver:
      image: nginx
      container_name: project-websrv
      working_dir: /var/www/project
      volumes:
          - ../../Sources/project/trunk/src/:/var/www/project
          - ./nginx/nginx.conf:/etc/nginx/conf.d/default.conf  
      ports:
       - "8080:80"
      links:
       - php-fpm

文件夹结构:

php/
 - Dockerfile
 - php-ini-overrides.ini
mysql/
nginx/
 - nginx.conf
*docker-compose.yml

完整的 nginx.conf

server {
    listen 80 default;

    client_max_body_size 108M;

    access_log /var/log/nginx/application.access.log;

    root /var/www/project/web;
    index app_dev.php;

    rewrite ^/app\.php/?(.*)$ /$1 permanent;

    try_files $uri @rewriteapp;

    location @rewriteapp {
        rewrite ^(.*)$ /app_dev.php/$1 last;
    }

    # Deny all . files
    location ~ /\. {
        deny all;
    }

    location ~ ^/(app|app_dev)\.php(/|$) {
        fastcgi_pass php-fpm:9000;
        fastcgi_split_path_info ^(.+\.php)(/.*)$;
        fastcgi_index app.php;
        send_timeout 1800;
        fastcgi_read_timeout 1800;
        fastcgi_param  SCRIPT_FILENAME $document_root$fastcgi_script_name;
        fastcgi_param PHP_VALUE "error_log=/var/log/nginx/application_php_errors.log";
        fastcgi_buffers 16 16k;
        fastcgi_buffer_size 32k;
        include fastcgi_params;
    }

    # Statics
        location /(bundles|media) {
        access_log off;
        expires 30d;
        try_files $uri @rewriteapp;
    }
}

我检查了两次 URL,一切似乎都正常,nginx.conf 已设置并存储在此 URL 中。我用于另一个容器的相同配置,只是没有 phpmyadmin 和 mariadb,它工作正常。

【问题讨论】:

  • 你能告诉我 /etc/nginx/conf.d/default.conf 吗?
  • 我把它加在上面,但这可能是 docker 缓存的问题,因为在我为另一个容器使用相同的名称之前,但在构建它之前我重新启动了 docker
  • 我不确定,但我认为运行 nginx 时它会尝试连接到 php-fpm 主机。而php-fpm 容器可能还没有启动。我没有使用fastcgi_pass,但对于proxy pass 工作解决方案:将resolver 127.0.0.11; 添加到location ~ ^/(app|app_dev)\.php(/|$) 部分。
  • 好的,我将 docker 重置为工厂,删除所有容器和图像。但我得到了这些错误:ERROR: for project-websrv Cannot start service webserver: oci runtime error: container_linux.go:262: starting container process caused "process_linux.go:339: . . . . : Are you trying to mount a directory onto a file (or vice-versa)? Check if the specified host path exists and is the expected type
  • 您解决过这个问题吗?我现在有一个确切的,我要失去理智了

标签: symfony docker nginx


【解决方案1】:

我在文档中找到了一些关于如何添加别名的帮助: https://docs.docker.com/compose/compose-file/#aliases

services:
  # ...
  php-fpm:
    # ... 
    networks:
      proxy: # maybe use "default" here
        aliases:
        - php-fpm
  webserver:
    # ...
    links: # seems to have no effect alone
    - php-fpm
    networks:
    - proxy # maybe you can also use the "default" network
    depends_on: # start this container after the dependencies
    - php-fpm

networks:
  proxy:

您的反馈可以简化此答案。您真正需要添加什么?

【讨论】:

  • 我正在寻找解决方案,这对我帮助很大...谢谢!
猜你喜欢
  • 2020-07-08
  • 2019-09-01
  • 2016-02-11
  • 1970-01-01
  • 2021-02-26
  • 1970-01-01
  • 2021-04-21
  • 2017-07-31
  • 2018-02-06
相关资源
最近更新 更多