-
ReceiverQueueSize设为0会被自动修正为1000,因客户端消费依赖非空缓冲区触发消息分发,强行设0将导致Receive()阻塞在waiting状态;其本质是控制Broker推送批量大小,而非拉取粒度。147 收藏 -
Golang · Go教程 | 3天前 | 并发编程 · 数据竞争 · Go教程 · 生产实践 · race detector · golang Go 数据竞争 并发 sync atomic race detector go test -race
从共享计数器和订单状态缓存出发,讲清 Go race detector 的运行方式、报告解读、修复策略、CI 阻断和上线检查。147 收藏 -
围绕 Go 1.24 新增的 os.Root、OpenInRoot 和 Root.Open,讲清路径遍历防护、符号链接边界、文件上传、安全解压、测试用例和老项目迁移方式。144 收藏 -
逃逸分析本身不直接导致内存碎片,而是因小对象逃逸至堆、高频分配释放及GC延迟,造成mheap中大量不连续小span堆积形成外部碎片。143 收藏 -
从生产排障角度讲 Go log/slog 的结构化字段、context logger、错误日志、脱敏、日志级别和 trace/metrics 关联。143 收藏 -
Go原生错误不带堆栈,需用github.com/pkg/errors.Wrap或runtime/debug.Stack()手动添加;Go1.20+支持错误链但不自动记录堆栈;日志加Lshortfile标志更轻量实用。142 收藏 -
Go的map默认非并发安全,多goroutine读写会触发panic;sync.Map适用于高读低写场景,但不支持遍历且无泛型;推荐用泛型SyncMap+RWMutex封装以兼顾类型安全与并发控制。141 收藏 -
govet是Go工具链自带的语义分析检查工具,专查语法合法但逻辑可疑的代码,如printf参数不匹配、range复制结构体、struct标签拼写错误、未用变量、WaitGroup调用顺序错误等。140 收藏 -
直接用gohandle()会压垮长连接服务,因每连接并发子任务导致goroutine泛滥;ants.Pool必须配置WithDynamicAdjustment、WithExpiryDuration、WithNonblocking和WithPanicHandler,并按IO/CPU类型拆池或差异化调参,Resize需由独立监控goroutine基于可观测指标触发。137 收藏 -
Go语言中通过接口和结构体嵌入实现装饰器模式,如定义Logger接口并嵌入原对象实现功能扩展,结合TimestampLogger与LevelLogger形成链式调用,最终输出带时间戳和级别的日志,适用于HTTP中间件、数据库访问等场景。135 收藏 -
Golang · Go教程 | 2天前 | 优雅关闭 · Go教程 · 后端工程 · Golang实战 · net/http · 服务治理 · golang shutdown Go net/http HTTP服务 优雅关闭 SIGTERM 生产实践
从一次滚动发布中的半截请求出发,讲清 Go HTTP 服务优雅关闭、signal.NotifyContext、http.Server.Shutdown、超时、连接排空、后台任务收尾和上线检查。135 收藏 -
答案:Go通过reflect.TypeOf获取接口和具体类型的Type,利用Implements方法判断实现关系,需注意指针与值接收者的区别。134 收藏 -
从 Go 1.24 的 weak.Pointer 和 runtime.AddCleanup 出发,讲清弱引用缓存、Value 判空、GC 回收、清理回调和生产场景的使用边界。134 收藏 -
首先定义Protobuf接口并生成Go代码,然后实现gRPC服务端和客户端,最后启动服务并调用SayHello方法,输出“Response:Hello,Alice”,完成Unary调用流程。131 收藏 -
M会被休眠回收当且仅当:未绑定LockOSThread、无运行G且队列为空、未处于系统调用、已解绑P并完成handoffp、空闲超约10ms;cgo派生的M由C侧管理,runtime不回收。130 收藏