1

我也搜索其他问题,但它们不适合我。(Docker nginx 反向代理给出“502 Bad Gateway”docker nginx 502 bad gateway

在我的情况下,我将 docker-ce 安装到我的个人 VPS 服务器上,如下所示:

Client:
 Version:      18.03.1-ce
 API version:  1.37
 Go version:   go1.9.5
 Git commit:   9ee9f40
 Built:        Wed Jun 20 21:43:51 2018
 OS/Arch:      linux/amd64
 Experimental: false
 Orchestrator: swarm

Server:
 Engine:
  Version:      18.03.1-ce
  API version:  1.37 (minimum version 1.12)
  Go version:   go1.9.5
  Git commit:   9ee9f40
  Built:        Wed Jun 20 21:42:00 2018
  OS/Arch:      linux/amd64
  Experimental: false

然后

拉取标准最新版本wordpress, mysqljwilder/nginx反向代理

并使用给定的标准代码

MYSQL:

docker run --name myweb_com_mysql -v /opt/docker-volumes/myweb_com_mysql:/var/lib/mysql -e MYSQL_ROOT_PASSWORD="myweb41#D_fG" --restart unless-stopped -d mysql

WordPress:

docker run --name myweb_com_wordpress --link myweb_com_mysql:mysql -p 127.0.0.1:48010:80 -v /opt/docker-volumes/myweb_com_wordpress:/var/www/html -e VIRTUAL_HOST="myweb.com,www.myweb.com" --restart unless-stopped -d wordpress

和 NGINX 反向代理:

docker run -d -p 80:80 --name nginx-proxy  -v /var/run/docker.sock:/tmp/docker.sock jwilder/nginx-proxy

那有什么问题?

问候

4

2 回答 2

1

Jason Wilder 在他的README.md:

用法

要运行它:

$ docker run -d -p 80:80 -v /var/run/docker.sock:/tmp/docker.sock:ro jwilder/nginx-proxy

然后使用 env var 启动您想要代理的任何容器VIRTUAL_HOST=subdomain.youdomain.com

$ docker run -e VIRTUAL_HOST=foo.bar.com ...

我看到您将命令以相反的顺序排列,从nginx-proxy最后开始。因此它不起作用。

一个小小的旁注:我非常尊重 Jason 所做的社区工作。但在某些时候,我自己停止使用他的,只是开始在我的 DevOps 过程中nginx-proxy使用简单的图像添加配置。nginx原因是映射/var/run/docker.sock到容器内部是一个巨大的安全风险。另一个原因是nginx-proxy当时不是很稳定,它没有将特定的东西转发到我的容器(比如 Jira 的一些标头)。不确定它现在是如何工作的,我的 DevOps 使用我自己的解决方案足够稳定,我永远不会将我的产品/测试/登台环境暴露在上述安全风险中。

无论如何。我生成类似的文件myweb.conf,其中包括:

server {
  server_name myweb.com;

  location / {
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header Host $host;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    proxy_pass http://myweb:80;
  }
}

注意proxy_pass http://myweb:80;——如果容器在同一个网络上,nginx 的/etc/hosts. 但我通常会从正在运行的容器中获取 IP 来生成conf文件。安全总比后悔好。

然后我启动一个nginx容器并在其中添加文件。通常我这样做docker-compose

version: '3.4'

services:
  service-nginx:
    image: nginx:latest
    container_name: service-nginx
    restart: always
    volumes:
      - ${nginx_basepath}/nginx.conf:/etc/nginx/nginx.conf
      - ${nginx_basepath}/conf.d/:/etc/nginx/conf.d/
    ports:
      - "80:80"

我保存myweb.conf${nginx_basepath}/conf.d/它并自动出现在 nginx 配置中,所以 nginx 知道它。之后,nginx 只需要重新加载docker exec -i service-nginx nginx -s reload.

祝你好运!

于 2018-07-08T23:12:02.250 回答
-1

你好,据我了解--link已弃用,建议创建自己的网络

https://docs.docker.com/network/links/#connect-using-network-port-mapping

我希望这可以帮助你

在此处输入链接描述

于 2018-07-08T22:03:47.457 回答