反向代理到两个单独的nginx实例

如何解决反向代理到两个单独的nginx实例

我有几个存储库,它们需要能够独立运行,或在同一主机上一起运行。在这种情况下,我有两个应用程序:A和B。两者都使用docker compose运行。

每个人都有:

  • API(Django):应用程序A的API在端口5000上运行;应用程序B的API在端口5001上运行(通过channels套接字)
  • 其自己的数据库:数据库A在5432上运行;数据库B在5433上运行
  • 它自己的nginx反向代理:应用程序A监听端口8001;应用程序B监听端口8002

这两个对象均应通过侦听端口80和443的反向代理来访问。这是“主要” nginx实例的配置:

ssl_password_file /etc/nginx/certificates/global.pass;
ssl_session_cache shared:SSL:10m;
ssl_session_timeout 10m;
ssl_protocols TLSv1.2 TLSv1.1;

server {
    listen 80;
    server_name _;
    return 301 https://$host$request_uri;
}

server {
    listen 443 ssl;
    ssl_certificate /etc/nginx/certificates/certificate.crt;
    ssl_certificate_key /etc/nginx/certificates/privatekey.key;

    proxy_set_header X-Forwarded-Proto $scheme;

    server_name a.my.domain.com;
    location / {
        proxy_redirect off;
        proxy_pass http://a.my.domain.com:8001;
    }
}

server {
    listen 443 ssl;
    ssl_certificate /etc/nginx/certificates/certificate.crt;
    ssl_certificate_key /etc/nginx/certificates/privatekey.key;

    proxy_set_header X-Forwarded-Proto $scheme;

    server_name b.my.domain.com;
    location / {
        proxy_redirect off;
        proxy_pass http://b.my.domain.com:8002;
    }
}

这是应用程序A的配置:

upstream channels-backend {
    server api:5000;
}

server {
    listen 8001 default_server;
    server_name a.my.domain.com [local IP address];

    access_log /var/log/nginx/access.log;
    underscores_in_headers on;

    location /static {
        alias /home/docker/code/static;
    }

    location / {
        try_files $uri @proxy_to_app;
    }

    location @proxy_to_app {
        proxy_read_timeout 30;
        proxy_http_version 1.1;
        proxy_set_header Host $host;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $scheme;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-Host $server_name;
        proxy_redirect off;
        proxy_pass http://channels-backend;
    }
}

这是与应用程序B几乎相同的配置:

upstream channels-backend {
    server api:5001;
}

server {
    listen 8002 default_server;
    server_name b.my.domain.com [same local IP address];

    keepalive_timeout 70;
    access_log /var/log/nginx/access.log;
    underscores_in_headers on;

    location /static {
        alias /home/docker/code/static;
    }

    location / {
        try_files $uri @proxy_to_app;
    }

    location @proxy_to_app {
        proxy_read_timeout 30;
        proxy_http_version 1.1;
        proxy_set_header Host $host;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $scheme;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-Host $server_name;
        proxy_redirect off;
        proxy_pass http://channels-backend;
    }
}

当我使用docker-compose up --build运行所有三个应用程序时,从应用程序A开始,然后是应用程序B,然后是“主”反向代理,我可以打开Web浏览器,转到b.my.domain.com并使用应用程序B很好。但是,如果尝试a.my.domain.com,则会得到502 Bad Gateway。 Nginx显示:

[error] 27#27: *10 connect() failed (111: Connection refused) while connecting to upstream,client: [my IP address],server: a.my.domain.com,request: "GET / HTTP/1.1",upstream: "http://[local IP address]:8001/",host: "a.my.domain.com"

因此,我假设存在某种冲突。因为如果我独立运行应用程序A并直接通过http://a.my.domain.com:8001访问它,它就可以正常工作。

有什么想法吗?也欢迎提出更好的设置建议,尽管我非常喜欢易于维护而不是性能。我不想将两个应用程序都放在同一个存储库中。我不想依赖第三个(“主”)反向代理,我只是想能够在需要的情况下在同一服务器上快速添加更多应用程序,并根据请求的子域代理一个或另一个

编辑::如果我切换构建和运行应用程序的顺序,则应用程序B将返回502 Bad Gateway而不是应用程序A,因此两个应用程序均不存在此问题

解决方法

有两个问题:容器名称相同,channels的配置已过时。这是一个非常具体的情况,因此我怀疑这对任何人都将有所帮助,但是我为每个撰写文件的每个服务指定了唯一的名称,并确保没有端口冲突。我还更改了compose文件,例如,端口8001映射到端口80,因此nginx配置不需要知道任何异常的端口号。我更新了通道配置以反映新的容器名称,现在它可以正常工作了。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?