[go] 解决:concurrent write to websocket connection

出现这个问题是因为并发的调用了github.com/gorilla/websocket库的WriteMessage方法

在websocket连接上有多个groutinue同时调用写方法

 

go官方的解释:

websocket · pkg.go.dev

 

 

并发 
连接支持一个并发读取器和一个并发写入器。

应用程序负责确保不超过一个 goroutine 同时调用写入方法(NextWriter、SetWriteDeadline、WriteMessage、WriteJSON、EnableWriteCompression、SetCompressionLevel),并且不超过一个 goroutine 调用读取方法(NextReader、SetReadDeadline、ReadMessage、ReadJSON、SetPongHandler) , SetPingHandler) 并发。

Close 和 WriteControl 方法可以与所有其他方法可以并发调用。

 

每一个请求都是一个groutine,如果有多个groutine同时请求并且要写回数据,就会出现这个错误

 

一定要加上锁,并且在业务上避免多个同时调用

 

我遇到的问题是,我有两个结构体,但是conn是同一个,虽然每一个在调用时加了锁,只是锁定不同的结构体,所以User和Message同时调用还是有并发问题

复制代码
type User struct {
    Conn       *websocket.Conn
    Name       string
    Id         string
    Avator     string
    To_id      string
    Ent_id     string
    Role_id    string
    Mux        sync.Mutex
    UpdateTime time.Time
}
type Message struct {
    conn        *websocket.Conn
    context     *gin.Context
    content     []byte
    messageType int
    Mux         sync.Mutex
}
复制代码

 

posted @   唯一客服系统开发笔记  阅读(971)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
点击右上角即可分享
微信分享提示
1
chat with us