登录
首页 >  Golang >  Go问答

WebSocket错误:关闭代码 1006(意外关闭):预料外的结束

来源:stackoverflow

时间:2024-03-15 22:27:29 394浏览 收藏

在使用 Gorilla Websocket 库创建服务器时,如果客户端在未发送关闭消息的情况下关闭连接,会出现“WebSocket 错误:关闭代码 1006(意外关闭):意外的 EOF”错误。这是由于对等方异常关闭导致的,是正常现象。为了处理这种情况,可以使用 IsUnexpectedCloseError 函数过滤掉预期的关闭错误。此外,确保在维护客户端映射时避免数据争用,如 Gorilla Chat 示例所示。

问题内容

我正在尝试使用 gorilla/websocket 编写一个简单的 go websocket 服务器

http.HandleFunc("/ws", func(w http.ResponseWriter, r *http.Request) {
    if os.Getenv("env") == "development" {
        upgrader.CheckOrigin = func(r *http.Request) bool { return true }
    }

    conn, err := upgrader.Upgrade(w, r, nil)
    if err != nil {
        log.Printf("Websocket error: %s", err)
        return
    }

    defer conn.Close()

    // Register client
    clients[conn] = true

    for {
        message := message.Message{}
        _, msg, err := conn.ReadMessage()
        if err != nil {
            log.Printf("Websocket error: %s", err)
            return
        }

        res, _ = json.Marshal(context.Game)

        // Send to every client that is currently connected
        for client := range clients {
            err := client.WriteMessage(websocket.TextMessage, res)
            if err != nil {
                // Remove connection
                client.Close()
                delete(clients, client)
            }
        }
    }
})

_, msg, err := conn.readmessage() 行抛出错误并关闭 websocket,但我不确定为什么。

错误为close 1006(异常关闭):意外的eof。我怎样才能防止这种情况发生?


解决方案


该错误表明对等方在未发送关闭消息的情况下关闭了连接。 RFC 称此为“异常关闭”,但接收该错误是正常的。

使用 IsUnexpectedCloseError 过滤掉预期的关闭错误。 Gorilla Chat Example 显示了如何使用该功能(view code here)。

正如 Adrian 指出的,问题中的应用程序在 clients 上存在数据争用。 Gorilla Chat 示例展示了如何在不发生数据争用的情况下维护客户端地图 (hub)。

好了,本文到此结束,带大家了解了《WebSocket错误:关闭代码 1006(意外关闭):预料外的结束》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多Golang知识!

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