如何解决如何在Docker上进行反向代理
我有一台服务器,我正在使用Ubuntu 20.04,nginx,mosquitto和node-red和docker,我们将其称为网站http://mywebsite.com
。我已经创建了一个客户端,我面临的问题是在docker中将其称为client1,因此URL为http://mywebsite.com/client1
我想通过mosquitto建立MQTT连接,我正在发送有关主题test
当我写入mosquitto容器的IP地址时,在MQTT的红色节点上它起作用的问题
但是,如果我使用mywebsite.com/client1更改IP地址192.144.0.5,则无法连接到mosquitto,也无法发送或接收任何形式的数据
有关如何解决此问题的任何想法
解决方法
好的,您这里将遇到几个问题。
-
您不能使用MQTT进行基于路径的代理。如果您希望将多个MQTT代理(每个客户端1个)绑定到一个面向公众的域/ IP地址,则它们都必须在单独的端口(默认端口1883除外)上运行。
Nginx可以执行MQTT协议代理(例如,像this),因此您可以使用它来公开不同的端口,并将它们转发到mosquitto的单独实例,即使您使用不同的主机名(所有指向nginx无法知道使用了哪个主机名,因为没有等效于
HOST
HTTP标头的主机名。如果您要将MQTT与TLS结合使用,则可以使它与SNI一起使用,,但我从未见过有人这样做(基于SNI的路由here的可能文档)可以正常运作,并提供有关here的解释。如果通过Websockets使用MQTT,则应该能够使用基于主机名的路由。
如果启用管理员身份验证,则 -
基于路径的Node-RED代理当前无法正常工作,因为管理员身份验证令牌当前存储在浏览器本地存储中,并且仅作用于主机名,而不是主机名+路径。这意味着客户端一次只能登录一个实例。
您可以通过使用基于主机的代理来解决此问题,例如
http://client1.mywebsite.com
针对此问题的修复程序在Node-RED的待办事项列表中,可能(不保证)在1.2.0版发布后进行查看
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。