-
不能直接用Pod名当锁key,因为Pod名不稳定且不支持原子操作;应使用Lease对象通过resourceVersion实现带超时的分布式锁,锁key需为稳定业务标识。
-
reflect.New返回指针类型反射值但需调用.Elem()获取可寻址值才能设字段;字段必须导出且可设置,嵌套结构需递归处理,指针字段要先.Elem()或新建实例。
-
Golang的encoding/csv包在处理带BOM头、结构体映射和复杂字段时需技巧。1.读取带BOM头文件时,应先读取判断是否存在BOM头(0xEFBBBF),若存在则跳过,否则回退指针再解析;2.读写结构体需手动映射字段,写入时构造表头并遍历结构体转字符串数组,读取时将字符串数组转结构体;3.处理含逗号、换行、引号字段时,应使用Write方法传原始字符串,库会自动加引号并转义内部引号,避免手动拼接出错。掌握这些技巧后可应对大多数CSV处理需求。
-
CreateInBatches比循环Create快得多,因其将多条记录合并为单条批量INSERT语句执行,跳过逐条事务开销、减少网络往返与SQL解析,并仅触发一次BeforeCreate/AfterCreate钩子;默认每批100条,需注意参数顺序、返回值检查方式及空切片安全行为。
-
必须用_=iota跳过值,因iota按声明行计数,空行和注释无效;_=iota显式消耗计数,确保后续值准确递增,并需在String()/MarshalJSON()/switch中覆盖所有值域。
-
ServiceMesh跨集群通信需统一控制平面,共用istiod并配置clusterName/network标签;Go服务调用需用.global域名,依赖CoreDNS+istio-coredns-plugin解析;mTLS需MeshPolicy级PeerAuthentication和DestinationRule配置;排查应优先分析istio-proxy日志与stats而非Go应用日志。
-
hmac.New第二个参数必须是[]byte而非string;密钥类型错误、签名原文拼接不一致、body重复读取、timestamp与nonce校验不严是验签失败四大主因。
-
直接用gof()启动协程会导致协程数失控、内存暴涨和调度开销大;WorkerPool通过固定数量协程轮询消费带缓冲通道实现可控并发,worker需用task,ok:=<-ch判断通道关闭。
-
Go反射无法访问私有字段,必须用unsafe.Offsetof计算偏移量配合unsafe.Pointer读取,但存在跨平台不稳定、内存安全风险及维护成本高等问题。
-
用fmt.Printf配合格式动词(如%s、%d、%v)是最常用也最可控的方式,别依赖fmt.Println自动换行加空格的“省事”逻辑——它在调试和日志里反而容易掩盖结构问题。
-
ApolloClient.GetConfig()拿不到更新值是因为默认不监听变更,需显式启用长轮询(WithLongPolling(true))并注册AddChangeListener回调,在回调中反序列化新配置且用原子指针切换实例。
-
Go中函数可通过返回匿名函数创建闭包,捕获外层变量实现状态保持;示例中counter返回的闭包共享count变量,每次调用递增并返回新值。
-
main.go应放在cmd/子目录下(如cmd/myapp/main.go),根目录仅保留go.mod等元信息;internal/是Go强制的访问边界,用于封装不对外承诺的实现;API层负责错误映射为HTTP状态码,domain层只定义业务语义错误;go.mod的module名应为最终导入路径(如github.com/user/repo)。
-
typeRes=http.ResponseWriter是别名,零成本兼容;typeResresponse.Response是新类型,字段相同也不兼容,因Go严格区分类型身份。
-
使用errgroup可自动传播首个错误并取消其他任务;2.自定义通道能收集全部错误,适用于需运行所有任务的场景。