-
健康检查接口必须暴露/health且返回200,需同步探测数据库、Redis、下游HTTP等关键依赖并设超时,/health与/ready必须分离,同时通过Prometheus暴露多维健康指标。
-
实现Golang文件断点续传需利用HTTP的Range请求头与本地文件偏移写入。首先通过net/http发送带Range头的GET请求获取部分数据,服务端返回206状态码表示支持。使用os.OpenFile结合Seek从指定偏移写入文件,避免覆盖。为恢复任务,需持久化记录下载进度(如JSON文件),包含URL、总大小、已下载字节等信息,重启时读取并续传。完成后再删除元数据文件。可选优化:通过HEAD请求获总大小,分块并发下载多个Range至临时文件,最后按序合并提升速度。
-
Go调度器通过Work-Stealing实现负载均衡:当P本地队列为空且全局队列、netpoll均无任务时,按伪随机顺序最多尝试4轮窃取,每次从目标P队列尾部偷取一半(≤256个)G,依赖原子操作保障无锁安全。
-
最稳妥方式是直接用s3.PutObject,v2SDK已封装认证与重试;大文件用s3manager.Uploader,小文件用PutObject;注意region、bucket、key严格匹配及权限配置。
-
math包函数高并发变慢主因是未向量化且goroutine调度放大调用开销;累加浮点数需防精度丢失,推荐Kahan求和或math.FMA;避免float64等值判断。
-
http.FileServer不支持上传,因其仅处理GET请求,无法解析POST表单或multipart数据;需自定义handler实现分片、路由与元数据管理。
-
Go微服务中不能直接用net/http实现负载均衡,因其无客户端LB能力;应通过服务发现(如Consul)+客户端LB(如kitex)或ServiceMesh(如Istio)分层解决。
-
container/list不适合高频增删或按索引访问,它是无随机访问能力的双向链表;应优先使用切片或第三方数组列表。
-
真正通用的Go泛型Filter函数应使用func[S~[]E,Eany](sS,ffunc(E)bool)S签名,解耦切片与元素类型,支持指针/接口切片、避免传值拷贝、复用底层数组提升性能。
-
应使用gorilla/websocket而非net/http,因后者仅支持HTTP握手,缺乏帧解析、Ping/Pong心跳、连接状态管理等能力,硬实现易出错;前者封装RFC6455全流程,自动响应控制帧、支持读写超时与安全广播。
-
必须用unsafe.Pointer的场景包括:与C交互(如C.malloc)、底层原子操作、自定义序列化时直接读写结构体字段偏移;需配合Offsetof确认字段位置,禁止对interface{}/map/slice/func转换,uintptr不能长期持有以防悬空指针。
-
Go集成ClickHouse核心难点是写稳、读准、跑久:需显式配置Auth与Protocol防401/dialtimeout;批量写控1万–10万行并复用batch防OOM;时区统一设Asia/Shanghai,Nullable字段用sql.NullString;查询必设context超时与max_execution_time。
-
Go语言net/url库提供安全高效的URL解析,核心是url.Parse()返回*url.URL对象,支持各字段访问与修改;需检查错误、区分RawQuery与Query()解码差异,并用ResolveReference处理相对路径。
-
正确做法是用Query/Exec参数化传参防注入,禁用字符串拼接;占位符因驱动而异(mysql用?,postgres用$1);动态表名等须白名单校验;预处理提升性能但非必需,ORM亦需规范用法。
-
errgroup.Run()在context已取消时直接panic,非bug而是设计使然;须在调用前检查ctx.Err()!=nil,避免复用已取消context,IO类任务优先用GoContext(),CPU任务可用Go(),Wait()不保证逻辑执行完且仅返回首个错误。