Go语言技术文章
-
控制日志字段、Trace 采样和指标标签基数,降低观测系统对热路径的开销。509 收藏 -
讲解 Go 服务如何用 slog 记录 request_id、trace_id、错误类型和业务字段,让日志可以直接支撑线上排查。503 收藏 -
Go无内置图结构,需按需组合基础类型实现邻接表、邻接矩阵或结构体封装;DFS/BFS须手动管理visited状态;Dijkstra需防溢出与负权;并发优化应重workerpool而非盲目goroutine。501 收藏 -
Go的Benchmark函数须以Benchmark开头、接收*testing.B参数,并在b.N循环中执行逻辑;框架自动调优b.N使总耗时≥1秒,需用b.ResetTimer()分离初始化开销。501 收藏 -
结构体指针赋值后字段没变,是因为误将指针变量重新赋值(如p=&User{...}),未解引用修改原内存;正确做法是用p.Name="new"或(*p).Name="new"。501 收藏 -
本文用 Go 泛型实现切片保序去重,并进一步扩展到结构体按字段去重,讲清 comparable 约束、seen map、首条保留和常见边界处理。501 收藏 -
必须显式调用e.Start()或e.StartServer()启动服务,否则仅监听端口却无响应;路径匹配严格区分大小写和斜杠;结构体字段须大写并加jsontag才能序列化;必须启用middleware.Recover()捕获panic。500 收藏 -
Consul高负载导致Go网关连接重置,根本原因是Server连接处理能力不足与客户端短连接、无超时、无复用等默认行为不匹配;需强制复用连接、设超时与降频检查,并优化Server配置及规避Go代码陷阱。499 收藏 -
Go不推荐手写双重检查锁单例,因sync.Once已是内存安全、零分配且经优化的成熟实现;手写易出错、难维护,且无法获得编译器特殊优化。498 收藏 -
不是必须,但绝大多数跨模块本地开发场景下replace是唯一可靠方式;go.work是Go1.18+推荐的多模块协同方案;子模块go.mod中不可require主模块;CI/CD需禁用go.work并独立发布各模块。498 收藏 -
使用time.AfterFunc或手动延迟首次触发:先创建ticker,再用time.AfterFunc延迟首次操作,或用time.Timer替代,避免NewTicker启动即触发。497 收藏 -
Vault的database/creds/路径属databasesecretsengine,不可用KVv2读取,必须调client.Logical().Read();该路径动态生成临时凭据,含lease_id、username、password及lease_duration,需手动续租防过期失效。497 收藏 -
根本原因是Go进程重启导致TCP连接被内核强制回收,真正的平滑升级需旧进程继续服务存量WebSocket连接直至自然关闭或优雅终止,并配合Nginx透传Upgrade头、客户端心跳+指数退避重连及全链路超时协同。497 收藏 -
LT模式下epoll_wait会反复通知未处理完的就绪事件:只要文件描述符处于就绪状态(如接收缓冲区非空或发送缓冲区未满),epoll_wait就会持续返回该事件,直到对应状态解除。497 收藏 -
全局队列(sched.runq)不参与work-stealing负载均衡,仅作为防饿死的被动兜底通道;它加锁、单次取1个G、每61次调度tick才检查一次,设计上排除在窃取路径外。496 收藏