golang专题下共有 1131 篇文章
-
- GolangTCP粘包处理方法详解
- TCP粘包问题的解决核心在于自定义应用层协议以标识消息边界,并在接收端正确拆包处理。1.TCP粘包是其正常行为,由发送方合并小包、接收方读取慢或数据过大被分片等原因引起。2.协议设计要点包括:消息头包含固定长度字段(如int32)标识消息体长度,结构清晰易编解码。3.Golang实现拆包流程为:持续读取数据至缓冲区,判断是否含完整消息头和消息体,满足条件则提取处理,否则等待后续数据。4.实际开发建议使用bufio.Reader、成熟框架如gRPC,注意字节序一致、缓冲区管理及拆包逻辑独立运行,同时处理连接
- Golang· Go教程 | 2星期 | golang TCP粘包 自定义协议 拆包 消息边界 350浏览 收藏
-
- Golang长连接心跳设置:deadline与keepalive详解
- 在Golang中设计长连接心跳机制应结合deadline与keepalive。一、心跳机制用于检测连接存活,客户端或服务端定期发送心跳包,连续未响应则断开重连;二、Go的deadline控制读写超时,如SetReadDeadline设置读操作截止时间,超时返回timeout错误;三、TCPKeepalive是系统级探针机制,启用需调用SetKeepAlive(true)与SetKeepAlivePeriod设置探针间隔;四、推荐组合使用:应用层心跳快速响应,传输层keepalive作为兜底保障,建议参数关
- Golang· Go教程 | 2星期 | golang 长连接 keepalive Deadline 心跳机制 145浏览 收藏
-
- Golang并发爬虫:worker池与任务分发技巧
- 用Golang构建并发爬虫系统的核心在于合理使用goroutine和channel实现worker池及任务分发。1.worker池通过预先创建goroutine并持续监听共享channel,减少频繁创建销毁的开销;2.任务分发策略包括单一队列、独立队列和优先级队列,按需选择以优化任务分配;3.并发控制通过限制worker数量、缓冲channel、加入sleep机制以及域名限速等方式防止过载并避免触发反爬;4.系统还需集成解析器、去重机制、持久化等模块,并完善错误处理与恢复逻辑以确保稳定性。
- Golang· Go教程 | 2星期 | golang 并发控制 任务分发 并发爬虫 worker池 183浏览 收藏
-
- Golang高效RPC客户端:连接池与超时设置详解
- 1.使用连接池提升RPC客户端性能的核心在于复用连接,减少每次调用建立新连接的开销,Golang中可通过sync.Pool实现简单连接池;2.超时控制通过context包实现,确保RPC调用在指定时间内完成,防止服务阻塞;3.错误处理需涵盖连接、超时及服务器返回错误,解析响应中的错误码进行相应处理;4.选择RPC框架应综合考虑性能、易用性、生态活跃度及语言支持,如gRPC适合多语言高性能场景;5.监控RPC客户端性能可追踪请求延迟、成功率、连接池状态和错误率,借助Prometheus等工具实现可视化;6.
- Golang· Go教程 | 2星期 | golang 错误处理 连接池 超时控制 RPC客户端 501浏览 收藏
查看更多
课程推荐
-
- Golang深入理解GPM模型
- Golang深入理解GPM调度器模型及全场景分析,希望您看完这套视频有所收获;包括调度器的由来和分析、GMP模型简介、以及11个场景总结。
- 474次学习
-
- Go语言课程Gin框架实战
- Gin是一个用Go(Golang)编写的HTTPweb框架。它是一个类似于 martini 但拥有更好性能的API框架,由于 httprouter,速度提高了近40倍。如果你需要极好的性能,使用Gin吧。
- 338次学习
-
- Golang云原生架构师课程
- Go是一门并发支持、垃圾回收的编译型系统编程语言;本课程转载自哔哩哔哩:https://www.bilibili.com/video/BV1Mh411M7A
- 204次学习
-
- Go编程基础视频教程
- Go是一门并发支持、垃圾回收的编译型系统编程语言,旨在创造一门具有在静态编译语言的高性能和动态语言的高效开发之间拥有良好平衡点的一门编程语言。我们收集了这套《Go编程基础视频教程》,希望能够帮助大家更好的学习go语言。
- 167次学习
-
- Golang进阶实战编程
- 本课程是在《Go语言基础视频》基础之上录制的,是Go语言基础的后半部分。包括包的管理,IO操作,Go语言最大的亮点:高并发,goroutine,channel,反射等。本视频主要为了帮助Go语言的初学者,从零到一的快速入门。学完本套课程,可以学会如果通过包管理Go项目,并发模型,以及并发实现,channel通道如何传递数据,反射等等。
- 128次学习