-
Kafka、RabbitMQ、NSQ的选型取决于业务场景:高吞吐+日志留存优先Kafka,需注意sarama配置与消费者组参数;灵活路由/ACK选RabbitMQ,须规避连接非线程安全及ACK遗漏;轻量实时通知可选NSQ,但受限于消息大小、无原生消费者组及lookupd单点。
-
Worker启动时必须接收context.Context参数,否则上层无法取消;传context.Background()或内部新建独立ctx均导致ctx.Done()永不触发、select无法响应取消。
-
答案:Go语言中使用encoding/xml包解析XML,通过结构体标签映射元素和属性,支持嵌套、切片及属性处理,可用Unmarshal解析字符串或文件,动态结构可用Token流解析。
-
etcd服务注册不能只调用Put,必须结合Lease机制实现心跳与自动摘除:先Grant租约,再Put绑定key,最后KeepAlive续约;否则key残留或静默失效。
-
必须使用wechatpay-go处理微信支付v3,因其自动完成平台证书轮换、Authorization头注入及回调三元组校验;手写HTTP客户端易在时间格式、请求体哈希、证书解析等环节出错导致401。
-
Go集成测试数据库应通过Testcontainers动态启停容器实现环境隔离,结合事务回滚避免数据污染,并用接口抽象DB依赖便于mock单元测试,同时启用SQL日志和t.Log辅助快速定位问题。
-
PrintFields函数使用reflect包遍历并打印结构体导出字段名与值:先解引用指针,验证为结构体后,循环NumField()获取字段名和Interface()值。
-
Gonet/rpc默认无超时,需用context.WithTimeout封装Call实现超时控制,或改用gRPC;HTTP/JSON-RPC还需分层设置连接、响应头、读取超时。
-
gomoddownload下载失败时先看GO_PROXY和网络连通性它不走本地GOPATH,也不自动fallback到direct,失败几乎都卡在这两处。默认GO_PROXY是https://proxy.golang.org,direct,但国内访问前者常超时或被重置,direct又因模块服务器无认证/限流直接拒绝请求。临时解决:运行goenv-wGO_PROXY=https://goproxy.cn(或https://goproxy.io)验证是否生效:执行
-
最直接方式是用sort.Slice配合优先级映射map[string]int实现自定义排序,避免字符串字典序错误;推荐结构体用int型Priority字段配合常量,输入时校验转换,输出时查表转回字符串,兼顾安全、性能与可维护性。
-
Example函数必须以大写Example开头、无参数无返回值,定义在同包的_test.go文件中,末尾用顶格//Output:断言fmt.Println输出,且需显式初始化依赖。
-
counter++在多goroutine下必然不可靠,因其被拆为读取→加1→写回三步,中间可被抢占导致覆盖;必须用atomic.AddInt64等原子操作,且需满足类型、对齐、初始化三前提。
-
replace语句必须严格匹配模块路径且右侧为绝对路径,否则gobuild会静默使用远端版本;需同步更新go.sum、清理缓存、验证路径,并避免提交到主分支。
-
goget在Go1.18+中仅用于下载并构建含main函数的包,不再推荐安装工具或管理依赖;应改用goinstall(需带版本后缀)安装CLI工具,用gomodadd或goget-d添加依赖,并务必配置GOPROXY。
-
反射遍历map时panic是因传入nil或未初始化map,需用IsValid()和Kind()==reflect.Map双重校验;MapRange高效但限编译期已知类型,反射支持运行时任意map类型但慢10–100倍;修改仅允许更新已有key的value,不可新增键或扩容。