[go] 解决:concurrent write to websocket connection
出现这个问题是因为并发的调用了github.com/gorilla/websocket库的WriteMessage方法
在websocket连接上有多个groutinue同时调用写方法
go官方的解释:
并发
连接支持一个并发读取器和一个并发写入器。
应用程序负责确保不超过一个 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 }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· 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工具