Laravel 502使用反向代理nginx时网关损坏

Laravel 502使用反向代理nginx时网关损坏,laravel,docker,nginx,Laravel,Docker,Nginx,在过去的几天里,我一直在尝试与docker和nginx建立反向代理,但收效甚微。当我运行docker compose up并试图通过我的IP地址访问我的服务器时,我确实得到了相应的页面。但是,当尝试卷曲我的/etc/hosts文件中列出的域时,它只返回一个502坏网关。我的主要项目是一系列laravel项目,我正在使用以下docker compose.yml文件 version: '2' services: web: build: context:

在过去的几天里,我一直在尝试与docker和nginx建立反向代理,但收效甚微。当我运行
docker compose up
并试图通过我的IP地址访问我的服务器时,我确实得到了相应的页面。但是,当尝试卷曲我的
/etc/hosts
文件中列出的域时,它只返回一个
502坏网关
。我的主要项目是一系列laravel项目,我正在使用以下
docker compose.yml
文件

version: '2'
services:
    web:
        build:
            context: ./
            dockerfile: docker/web.docker           
        volumes:
            - ./:/var/www
        expose:
            - "8080"
        links:
            - app
    app:
        build:
            context: ./
            dockerfile: docker/app.docker
        volumes:
            - ./:/var/www
        links:
            - mysql
            - redis
            - beanstalk
            - cache
        environment:
            - "DB_PORT=3307"
            - "DB_HOST=mysql"
            - "REDIS_PORT=6379"
            - "REDIS_HOST=redis"
    mysql:
        image: mysql:5.7.18
        environment:
            - "MYSQL_ROOT_PASSWORD=secret"
            - "MYSQL_DATABASE=db"
        ports:
            - "3307:3307"
    redis:
        image: redis:3.0
        ports:
            - "6379:6379"
    beanstalk:
        image: schickling/beanstalkd
        ports:
            -  "11300:11300"
    cache:
        image: memcached:alpine
        ports:
            - "11211:11211"
使用以下nginx conf文件

server {
    listen 80;
    index index.php index.html;
    root /var/www/public;

    location / {
        try_files $uri /index.php?$args;
    }

    location ~ \.php$ {
        fastcgi_split_path_info ^(.+\.php)(/.+)$;
        fastcgi_pass app:9000;
        fastcgi_index index.php;
        include fastcgi_params;
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
        fastcgi_param PATH_INFO $fastcgi_path_info;
    }
}
我的代理的
docker compose.yml
当前为:

version: '3'
services:
  proxy:
    build: ./
    networks:
      - project1
      - project2
    ports:
      - 80:80

networks:
  project1:
    external:
      name: projec1_default
  project2:
    external:
      name: project2_default
我还有一个nginx conf文件,在其中我以以下方式定义了所有项目

server {
  listen 80;
  server_name project1.xxx.tech www.project1.xxx.tech;

  location / {
    include /etc/nginx/includes/proxy.conf;
    proxy_pass http://project1_web_1:8080/;
  }

  access_log off;
  error_log  /var/log/nginx/error.log error;
}
运行
docker network ls
显示docker容器文件中列出的服务正在其分配的端口上运行,有一点相当混乱,即服务的web部分显示它正在侦听80以及8080或8081,具体取决于项目。我不确定这是否会引起冲突


我还尝试使用nginx代理项目获得类似的结果。任何帮助都将不胜感激。

因此,问题最终通过使用jwilder的项目得以解决

我只需要指定虚拟主机和虚拟端口就可以了。我不确定为什么虚拟端口必须显式设置为80,但这似乎解决了问题。这是我的laravel项目的
docker compose.yml
文件:

version: '2'
services:
    web:
        build:
            context: ./
            dockerfile: docker/web.docker           
        volumes:
            - ./:/var/www
        links:
            - app
        environment: 
            - VIRTUAL_HOST=appname.com
            - VIRTUAL_PORT=80
        expose:
            - "80"
    app:
        build:
            context: ./
            dockerfile: docker/app.docker
        volumes:
            - ./:/var/www
        links:
            - mysql
        environment:
            - "DB_PORT=3307"
            - "DB_HOST=mysql"
            - "REDIS_PORT=6379"
            - "REDIS_HOST=redis"
    mysql:
        image: mysql:5.7.18
        environment:
            - "MYSQL_ROOT_PASSWORD=secret"
            - "MYSQL_DATABASE=db"
        ports:
            - "3307:3307"

我想
proxy\u通行证http://project1_web_1:8080/;应该是
代理\u passhttp://web:8080/;,如果它在容器内运行,则包含该nginx conf文件的容器是我的反向代理,因此这两个容器是完全分开的。不过我可以试一试——这似乎无法在docker compose或默认网桥网络创建的同一网络上启动外部nginx容器?启动nginx容器时,我没有指定任何内容,但是当我用
docker compose down
停止时,它确实会说我的网络是外部的,而且这个过程正在跳过这些。因此,我假设nginx容器在实际查看laravel项目时没有问题。您是否发布了用于启动外部
nginx
容器的命令?