Docker NGINX反向代理502虚拟机上的坏网关

Docker NGINX反向代理502虚拟机上的坏网关,docker,nginx,Docker,Nginx,我正在尝试在VM上设置Gitea实例。 为此,我使用了docker compose 现在我的问题是,我运行我的VM和docker compose,但我无法访问webapp。浏览器提示我一个502坏网关 我的虚拟机的IP是:192.168.33.10。 在浏览器中,我正在键入192.168.33.10:80 docker logs production\u nginx为我提供以下输出: 2020/06/23 14:26:11 [error] 28#28: *7 connect() failed

我正在尝试在VM上设置Gitea实例。 为此,我使用了docker compose

现在我的问题是,我运行我的VM和docker compose,但我无法访问webapp。浏览器提示我一个
502坏网关

我的虚拟机的IP是:192.168.33.10。 在浏览器中,我正在键入
192.168.33.10:80

docker logs production\u nginx
为我提供以下输出:

2020/06/23 14:26:11 [error] 28#28: *7 connect() failed
 (111: Connection refused) while connecting to upstream,
 client: 192.168.33.1, server: , request: "GET / 
HTTP/1.1", upstream: "http://172.27.0.2:3000/", host:
 "192.168.33.10"
192.168.33.1 - - [23/Jun/2020:14:26:11 +0000] "GET / 
HTTP/1.1" 502 157 "-" "Mozilla/5.0 (X11; Ubuntu; Linux 
x86_64; rv:77.0) Gecko/20100101 Firefox/77.0"
但是我不明白这里发生了什么。。。 任何建议都将受到高度赞赏

My docker-compose.yml:

version: "2"

networks:
  proxy:
  gitea:
    external: false

services:
  nginx:
    image: nginx:latest
    container_name: production_nginx
    volumes:
      - ./nginx.conf:/etc/nginx/nginx.conf
    ports:
      - "80:80"
      - "443:443"
      - "222:22"
    networks:
      - proxy

  server:
    container_name: gitea_server
    image: gitea/gitea:latest
    environment:
      - APP_NAME=Gitea
      - USER_UID=1000
      - USER_GID=1000
      - DB_TYPE=postgres
      - DB_HOST=db:5432
      - DB_NAME=gitea
      - DB_USER=gitea
      - DB_PASSWD=gitea
      - DOMAIN=localhost
      - SSH_DOMAIN=localhost
      - HTTP_PORT=80
      - SSH_PORT=22
      - SSH_LISTEN_PORT=22
    restart: always
    networks:
      gitea:
        aliases:
          - gitea_server
      proxy:
        aliases:
          - gitea_server
    volumes:
      - gitea_data:/data
      - /etc/timezone:/etc/timezone:ro
      - /etc/localtime:/etc/localtime:ro
    expose:
      - "3000"
      - "2222"
    depends_on:
        - db

  db:
    container_name: postgres
    image: postgres:9.6
    restart: always
    environment:
      - POSTGRES_USER=gitea
      - POSTGRES_PASSWORD=gitea
      - POSTGRES_DB=gitea
    networks:
      - gitea
    volumes:
      - postgres:/var/lib/postgresql/data

volumes:
  gitea_data: {}
  postgres: {}

My nginx.conf:

events {}
http {
  upstream gitea{
    server gitea_server:3000;
  }

  server {
    listen 80;

    location / {
      proxy_pass http://gitea;
    }
  }
}

似乎不允许
gitea
映像中的用户使用端口
server_1  | 2020/06/23 17:20:49 ...s/graceful/server.go:55:NewServer() [I] Starting new server: tcp:0.0.0.0:80 on PID: 14
server_1  | 2020/06/23 17:20:49 ...s/graceful/server.go:79:ListenAndServe() [E] Unable to GetListener: listen tcp 0.0.0.0:80: bind: permission denied
server_1  | 2020/06/23 17:20:49 cmd/web.go:204:runWeb() [C] Failed to start server: listen tcp 0.0.0.0:80: bind: permission denied
server_1  | 2020/06/23 17:20:49 cmd/web.go:206:runWeb() [I] HTTP Listener: 0.0.0.0:80 Closed