javascript 的 websockets 和 docker 上的 nginx
websockets with javascript and nginx on docker
我有一个 docker compose,其中包含 3 个容器“node-red,influxdb,一个 html with JavaScript webpage with nginx:alpine image”
在 html 和 JavaScript 网页中,我有一个图像列表,我根据来自节点红色的数据通过 websockets
更改图像
我用这个 JavaScript 函数接收数据
function startConnect() {
document.getElementById('dt').click();
socket = new WebSocket("ws://mywebsite.com:1880/ws/test");
socket.onmessage = function(e) {onMessageArrived(e.data)}
console.log("connected");
socket.onopen = function() {socket.send("1")};
}
// Called when a message arrives
function onMessageArrived(message) {
console.log("onMessageArrived: " + message);
var obj = JSON.parse(message);
document.getElementById("image1").src = "myimage/" + obj.L + "_DL.png";
document.getElementById("image2").src = "myimage/" + obj.M + obj.F + obj.S + "_" + obj.Z48_70 + "_M.png";
document.getElementById("image3").src = "myimage"+ obj.V + obj.V + "_X";
}
一切正常,直到我决定将 docker 用于“node-red 和 influx 以及 html 网页”并使用没有 docker 的 nginx 和 letsencrypt 证书来处理我的 3 个容器的反向代理。
我面临的问题是我无法使用 websockets 接收数据,即使我将 socket = new WebSocket("ws://mywebsite.com:1880/ws/test")
更改为 socket = new WebSocket("ws://mywebsite.com:6100/ws/test")
我的网页使用的端口 6100 包含这个我有一个 https错误和 socket = new WebSocket("ws://192.170.0.6:6100/ws/test")
我的网页容器的 IP 地址以及 new WebSocket("ws://mywebsite/webpage/ws/test")
这由 nginx 处理以将其路由到我的网页容器使用的 IP 和端口
如果您要连接到通过 HTTPS 引导的 WebSocket 地址,那么您需要使用 wss:
方案而不是 ws:
因此,如果您在端口 6100 上启用了 https,那么您需要使用 wss://mywebsite.com:6100/ws/test
(如果您使用 nginx 作为反向代理,是否有任何理由不分别为 http/https 使用默认端口 80 和 443?)
编辑:
如果您的代理分别为 http/https 提供默认端口 80/443,那么您应该使用如下内容:
function startConnect() {
document.getElementById('dt').click();
if (location.scheme === 'http:' ) {
socket = new WebSocket("ws://mywebsite.com/ws/test");
} else {
socket = new WebSocket("wss://mywebsite.com/ws/test");
}
socket.onmessage = function(e) {onMessageArrived(e.data)}
console.log("connected");
socket.onopen = function() {socket.send("1")};
}
这将根据页面的加载方式(http 与 https)选择 ws://
或 wss://
我有一个 docker compose,其中包含 3 个容器“node-red,influxdb,一个 html with JavaScript webpage with nginx:alpine image” 在 html 和 JavaScript 网页中,我有一个图像列表,我根据来自节点红色的数据通过 websockets
更改图像我用这个 JavaScript 函数接收数据
function startConnect() {
document.getElementById('dt').click();
socket = new WebSocket("ws://mywebsite.com:1880/ws/test");
socket.onmessage = function(e) {onMessageArrived(e.data)}
console.log("connected");
socket.onopen = function() {socket.send("1")};
}
// Called when a message arrives
function onMessageArrived(message) {
console.log("onMessageArrived: " + message);
var obj = JSON.parse(message);
document.getElementById("image1").src = "myimage/" + obj.L + "_DL.png";
document.getElementById("image2").src = "myimage/" + obj.M + obj.F + obj.S + "_" + obj.Z48_70 + "_M.png";
document.getElementById("image3").src = "myimage"+ obj.V + obj.V + "_X";
}
一切正常,直到我决定将 docker 用于“node-red 和 influx 以及 html 网页”并使用没有 docker 的 nginx 和 letsencrypt 证书来处理我的 3 个容器的反向代理。
我面临的问题是我无法使用 websockets 接收数据,即使我将 socket = new WebSocket("ws://mywebsite.com:1880/ws/test")
更改为 socket = new WebSocket("ws://mywebsite.com:6100/ws/test")
我的网页使用的端口 6100 包含这个我有一个 https错误和 socket = new WebSocket("ws://192.170.0.6:6100/ws/test")
我的网页容器的 IP 地址以及 new WebSocket("ws://mywebsite/webpage/ws/test")
这由 nginx 处理以将其路由到我的网页容器使用的 IP 和端口
如果您要连接到通过 HTTPS 引导的 WebSocket 地址,那么您需要使用 wss:
方案而不是 ws:
因此,如果您在端口 6100 上启用了 https,那么您需要使用 wss://mywebsite.com:6100/ws/test
(如果您使用 nginx 作为反向代理,是否有任何理由不分别为 http/https 使用默认端口 80 和 443?)
编辑: 如果您的代理分别为 http/https 提供默认端口 80/443,那么您应该使用如下内容:
function startConnect() {
document.getElementById('dt').click();
if (location.scheme === 'http:' ) {
socket = new WebSocket("ws://mywebsite.com/ws/test");
} else {
socket = new WebSocket("wss://mywebsite.com/ws/test");
}
socket.onmessage = function(e) {onMessageArrived(e.data)}
console.log("connected");
socket.onopen = function() {socket.send("1")};
}
这将根据页面的加载方式(http 与 https)选择 ws://
或 wss://