-
bufio.Scanner是流式读取大文件最轻量的选择,但默认缓冲区仅64KB,遇超长行会报错;需调用scanner.Buffer(make([]byte,64*1024),1<<30)扩容缓冲区。
-
Go中创建文件用os.Create(清空重写,不建父目录),创建单层目录用os.Mkdir(父目录须存在),嵌套目录用os.MkdirAll(自动递归创建);均需检查错误并合理设置权限。
-
Go中time.Time没有内置过期时间概念,业务定义的过期时间可通过Unix()(秒)、UnixMilli()(毫秒)或UnixNano()(纳秒)转为时间戳;JWT的exp字段在v5库中已自动转为time.Time;Redis的EXPIREAT需传Unix秒级时间戳,而Set方法传time.Duration;判断过期应先检查IsZero()再调用Before(time.Now())。
-
Go的json.Marshal默认忽略函数字段,但可通过实现json.Marshaler接口,将方法调用结果动态注入JSON输出,从而优雅地将计算型字段(如Value()、Size())作为JSON字段导出。
-
Go中收集goroutine错误的四种方式:1.带缓冲error通道;2.共享error变量+Mutex;3.errgroup.Group自动传播首个错误;4.锁保护切片汇总全部错误。
-
应构造完整HTTPhandler链(middleware(handler))进行基准测试,复用request/recorder、调用b.ResetTimer(),降级依赖(如ioutil.Discard日志)、重置req.Body,用-benchtime=10s-count=5和benchstat对比版本差异,并结合pprof火焰图与allocs/op分析真实瓶颈。
-
NSQ线上静默失效主因是连接与配置误用:Producer须全局复用并显式Connect(),ConnectToNSQLookupd()才用于生产服务发现,地址须为TCP端口(4160),PublishAsync错误回调不可为空且需异步处理,消息可靠性依赖幂等设计而非NSQ自身。
-
Go的http.Client默认无超时,需手动配置:用DialContext.Timeout控制连接建立(DNS+TCP+TLS),ResponseHeaderTimeout控制响应头接收,整体请求超时用context.WithTimeout包裹Do()调用。
-
应使用go-playground/validator库,它支持标签驱动、嵌套校验和自定义规则,且无运行时依赖;避免使用已归档的asaskevich/govalidator。
-
不可靠,因map遍历顺序随机且reflect.DeepEqual对nil/空slice、未导出字段、func、interface{}中类型不一致零值等场景处理失败;推荐用cmp.Equal配合cmpopts定制化比较。
-
time.Now().Unix()返回自Unix纪元起的整秒数(int64),无毫秒精度;需毫秒用UnixMilli()或UnixNano()/1e6;还原时间须显式传纳秒偏移(如0);解析字符串务必指定时区,避免跨时区误判。
-
告警规则应结构化为导出字段的Rule结构体,用JSON/YAML加载,operator存字符串以利扩展;通过fsnotify热加载并双变量+读写锁保障安全;构建device_id与metric两级索引优化匹配性能;增加duration_sec和suppress_window_sec支持时间窗口与去重抑制。
-
直接用chanint易卡死因无缓冲需同步收发:生产者发送时消费者未启动即阻塞,导致死锁;须用make(chanint,N)设缓冲、go启动双端、生产者close()后消费者用range安全退出。
-
Go结构体字段必须首字母大写(导出)才能被json.Marshal序列化;小写字母开头的字段会被忽略,导致输出空对象{}。本文详解结构体JSON转换原理、正确用法、标签控制及错误处理最佳实践。
-
CGO中C.CString分配的内存不释放会导致持续内存泄漏,RSS不断上升直至OOM;必须配对C.free,且需根据C函数文档判断返回指针是否需手动释放。