-
Go标准库log包默认不带时间戳、无级别区分、输出固定到stderr且不可重定向,因此不适合生产环境;需显式创建自定义logger并设置flag和输出目标,或封装带级别的结构体。
-
Go1.13起默认启用GOPROXY,依赖下载加速依赖代理(如goproxy.cn)与本地模块缓存($GOPATH/pkg/mod),首次下载后复用本地缓存,配合CI/CD持久化或私有Proxy实现高效复用。
-
不能直接用net/http暴露服务到公网,因存在连接泛洪、Slowloris攻击、TLS卸载缺失、HTTP/2支持不全等安全与功能缺陷;必须通过Nginx作为反向代理承担网络边界职责,并正确配置超时、Header透传、WebSocket支持及真实IP解析。
-
robfig/cron/v3是Go中启动最简定时任务的常用方案,需显式调用Start()、注意秒级精度需WithSeconds()且表达式匹配段数,解析失败易静默忽略,不适用于高精度或大量任务。
-
本文介绍如何在Go中通过预过滤机制,避免将空嵌入结构体(如Problem{})序列化为JSON中的空对象{},从而实现任意组合非空结构体并生成紧凑、合规的JSON数组。
-
Go切片传参时传递的是包含ptr、len、cap的结构体副本,ptr值被复制但指向同一底层数组;修改元素生效,append等操作需返回新切片才能影响调用方。
-
不能直接将reflect.Value转为reflect.Type,只能通过v.Type()提取其绑定的类型;reflect.Type无法反向生成reflect.Value,需用reflect.New(t).Elem()创建新值。
-
json-iterator更快是因为绕过反射、预编译解析逻辑、支持零拷贝字符串读取,但仅在结构体稳定、字段固定且高频解析场景下优势显著;动态map或深层interface会削弱性能,甚至更慢。
-
Go标准库log不支持日志轮转,需用第三方库:lumberjack适合按大小轮转(如100MB/个,保留7个+28天),file-rotatelogs适合按日期轮转(如daily,带软链和精确时间控制)。
-
GoWorkspaces是专为本地多模块联动开发设计的机制,用于替代replace的临时方案;需在含go.mod的目录用goworkinit初始化,仅在Go1.18+且存在go.work文件时生效,不参与构建发布流程。
-
fstest.MapFS不能直接写入,因为它是只读的,仅实现fs.FS而非fs.ReadWriteFS,调用写操作会panic;适合只读测试场景,写入需换用memfs或afero等可写内存文件系统。
-
应使用context.Context透传traceID:入口从请求头提取ID并用自定义key注入ctx,下游调用显式传递该ctx;日志通过WithContext动态提取traceID,避免With频繁创建logger实例;gRPC/HTTP混合调用需手动处理metadata和header传递。
-
使用长连接替代短连接,通过Keep-Alive和gRPC的*grpc.ClientConn复用TCP连接;2.控制连接数量与并发度,设置最大空闲连接数并用信号量隔离不同服务;3.实现健康检查与自动重连,在Put前检测连接状态并重建失效连接;4.结合上下文超时控制,使用context.WithTimeout限制调用时间并释放资源。需持续压测调优以平衡性能与资源。
-
Go的json.Unmarshal不panic,所有错误均通过error返回;必须检查err!=nil,测试需覆盖非法JSON、字段标签对齐、json.RawMessage延迟解析及错误输入拦截。
-
Go并发超时控制核心是安全等待或及时放弃任务:首选context.WithTimeout精确管控生命周期;次选select+time.After轻量等待;批量任务用errgroup+context统一协调;务必调用cancel、记录日志、避免泄漏并测试验证。