登录
首页 >  Golang >  Go问答

Gorilla WebSocket 一分钟后断开连接

来源:Golang技术栈

时间:2023-03-27 15:22:58 324浏览 收藏

哈喽!今天心血来潮给大家带来了《Gorilla WebSocket 一分钟后断开连接》,想必大家应该对Golang都不陌生吧,那么阅读本文就都不会很困难,以下内容主要涉及到golang,若是你正在学习Golang,千万别错过这篇文章~希望能帮助到你!

问题内容

我在 nginx 1.4.6 反向代理后面使用 Go (Golang) 1.4.2 和 Gorilla WebSockets。打开页面大约一分钟后,我的 WebSocket 断开连接。在 Chrome 和 Firefox 上也会发生相同的行为。

起初,我在使用 WebSocket 连接服务器和客户端时遇到了问题。然后,我读到我需要调整我的 nginx 配置。这就是我所拥有的。

server {
    listen 80;
    server_name example.com;

    proxy_pass_header Server;

    location / {
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forward-Proto $scheme;

        proxy_http_version 1.1;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection "upgrade";

        proxy_pass http://127.0.0.1:1234;
    }
}

我的 Go 代码基本上是在回显客户的信息。(为简洁起见,省略了错误)。这是我的HandleFunc

var up = websocket.Upgrader{
    ReadBufferSize:  1024,
    WriteBufferSize: 1024,
}

ws, _ := up.Upgrade(resp, req, nil)
defer ws.Close()

var s struct {
    Foo string
    Bar string
}

for {
    ws.ReadJSON(&s)
    ws.WriteJSON(s)
}

JavaScript 也很简单。

var ws = new WebSocket("ws://example.com/ws/");
ws.addEventListener("message", function(evnt) {
    console.log(JSON.parse(evnt.data));
});

var s = {
    Foo: "hello",
    Bar: "world"
};
ws.send(JSON.stringify(s));

Go 正在报告websocket: close 1006 unexpected EOF。我知道当我离开或刷新页面ReadJSON时返回EOF,但这似乎是一个不同的错误。此外,在打开页面大约一分钟后,意外的 EOF 会自行发生。

onerror在 JavaScript 中有一个函数。该事件不会触发,而是onclose触发。

正确答案

我有同样的问题,问题是nginx配置。它默认为 1 分钟的读取超时proxy_pass

语法:proxy_read_timeout 时间;

默认值:proxy_read_timeout 60s;

上下文:http、服务器、位置

请参阅http://nginx.org/en/docs/http/ngx_http_proxy_module.html#proxy_read_timeout

就我而言,我已将超时时间增加到 10 小时:

proxy_read_timeout 36000s;

文中关于golang的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《Gorilla WebSocket 一分钟后断开连接》文章吧,也可关注golang学习网公众号了解相关技术文章。

声明:本文转载于:Golang技术栈 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>
评论列表