-
Kafka、RabbitMQ、NSQ的选型取决于业务场景:高吞吐+日志留存优先Kafka,需注意sarama配置与消费者组参数;灵活路由/ACK选RabbitMQ,须规避连接非线程安全及ACK遗漏;轻量实时通知可选NSQ,但受限于消息大小、无原生消费者组及lookupd单点。
-
Go的语法糖如短变量声明、多返回值赋值、结构体初始化简化等,均在编译期处理,底层对应var声明、跳过返回值、字段顺序填充等机制,不增加运行时开销。
-
访问者模式允许在不修改元素类的情况下定义新操作,适用于数据结构稳定但需执行多种操作的场景。通过Element接口定义Accept方法,Visitor接口声明Visit方法,具体元素如Text和Image实现Accept以接收访问者,具体访问者如HTMLExporter和WordCounter实现不同业务逻辑,利用Go接口多态实现动态分发,新增功能只需添加访问者而不改动原有代码,符合开闭原则,适用于操作多、元素类型少的场景。
-
Go进程报“toomanyopenfiles”本质是未及时关闭文件、未限制并发及系统fd配置不当;需在启动前固定系统限制,用unix.Getrlimit读取/proc/pid/limits中真实Soft值校验。
-
Go中处理软中断的唯一标准路径是os/signal包,它将信号转为channel消息供goroutine消费;必须用带缓冲channel监听,常用SIGINT/SIGTERM,Windows仅SIGINT可靠,需用select阻塞接收而非range,且应分离信号处理与业务逻辑。
-
本文介绍如何在Go中将任意嵌套结构的JSON数据(解析为interface{})的所有键名统一转为小写,避免MongoDB查询时因大小写不一致导致的问题,并提供可复用的递归转换函数及注意事项。
-
Go禁止goto跳过变量声明,因编译期要求作用域清晰;解决方法是将声明移至所有标签前、用块包裹或改用defer;仅允许多层循环退出等少数场景使用。
-
静态资源路径切换CDN需统一规则并保持路径一致:模板或构建脚本中通过配置驱动URL前缀,避免硬编码;Go仅生成正确URL,不参与路径重写;HTML中静态资源直连CDN,动态接口走Go后端;构建时替换路径最稳妥,确保HTML、构建产物、CDN配置及回源规则四者对齐。
-
io.Copy更可靠因自动处理缓冲、边界条件和部分写入;必须用io.CopyBuffer时是需复用缓冲区或降低GC压力,建议缓冲区大小为64KB或128KB。
-
能,多个.go文件可放在同一包中,只需同目录下所有文件声明相同package名,无需import即可互相调用,首字母大写标识导出。
-
State接口应设计为无状态、事件驱动:定义CanHandle(event)bool和Handle(ctx,event,data)error方法,配合统一Event类型与迁移校验表,避免方法爆炸与非法跳转。
-
用net/http手动校验表单最可控:先显式调用r.ParseForm()并检查错误,再逐字段校验;邮箱用net/mail.ParseAddress或正则;多字段推荐validator库配合指针类型与omitempty;错误须结构化返回字段级信息,前后端name严格对齐。
-
应先用os.ReadFile读取原始字节,再通过golang.org/x/text/encoding/simplifiedchinese.GBK.NewDecoder().Bytes()转为UTF-8;大文件需用transform.NewReader流式处理避免OOM,并务必检查转码error。
-
闭包能捕获并持续访问外层函数变量,如counter函数中count被递增且生命周期延长至堆;闭包引用变量而非值拷贝,循环中易因共享i导致所有闭包输出相同值。
-
必须显式指定Buckets,否则所有观测值落入+Inf桶导致分布图失真;需按真实延时范围配置,避免默认值;业务耗时应排除中间件开销;推荐用HistogramVec按method/path/status等维度统计,禁用动态path防基数爆炸。