Go教程技术文章
-
是的,Gonet包在Windows上自Go1.9起真走IOCP,但仅限net.Conn相关操作(Listen、Accept、Read、Write);os.Open、filepath.WalkDir等仍为同步Win32调用,不进完成端口。166 收藏 -
Golang · Go教程 | 1星期前 | goroutine · Context · 超时控制 · Go教程 · 后端开发 · Go Goroutine context 超时控制 WithTimeout Done QueryContext
本文用完整工作流讲解 Go context 超时控制:从 HTTP 入口创建超时预算,把 ctx 传给 DB 查询和远程请求,到 goroutine 监听 Done、及时退出并释放资源,最后给出验证和上线清单。166 收藏 -
Golang · Go教程 | 1星期前 | WaitGroup · channel · 并发编程 · 优雅关闭 · Go教程 · WaitGroup Channel关闭 Go channel 并发收尾 done信号
本文把 Go channel 关闭拆成一套可复用工作流:先确定谁负责关闭,再用 done 信号通知停止,用 WaitGroup 等待协程收尾,最后关闭结果通道并验证没有 panic 和泄漏。165 收藏 -
Go不内置Git,需配置系统Git与gomod协同:确保gitURL映射、SSH/HTTPS认证有效;gomodinit的module名须严格匹配仓库地址;私有仓库必须设置GOPRIVATE跳过代理校验。162 收藏 -
Go1.18+切片扩容阈值为256,非1024;仅当len==cap时append才触发growslice;空slice首次append分配1元素空间;内存按sizeclass对齐导致碎片;预估容量比依赖自动扩容更高效可控。157 收藏 -
Context是Go中管理并发任务的核心工具,通过context.WithCancel可实现任务取消,调用cancel函数通知所有子任务退出;使用context.WithTimeout或WithDeadline可设置超时控制,超时后Done()通道关闭,任务需监听并及时终止。156 收藏 -
使用互斥锁、读写锁、通道和原子操作可有效处理Golang中共享资源的并发访问,避免数据竞争。1.互斥锁(sync.Mutex)确保同一时间仅一个goroutine访问资源,适用于一般场景;2.读写锁(sync.RWMutex)提升读多写少性能,允许多个读操作并发;3.通道(channel)通过通信共享内存,将状态管理集中于单一goroutine,适合复杂状态同步;4.sync/atomic提供原子操作,高效处理计数器等简单类型。选择依据场景:atomic用于轻量数值操作,RWMutex优化读密集,chan155 收藏 -
从线上排障角度讲 errors.Is/As、fmt.Errorf %w、错误分层、日志上下文和用户可见错误的边界。151 收藏 -
使用令牌桶限流、复用HTTP连接、控制并发与超时、启用压缩等手段提升Go服务稳定性。具体:1.用golang.org/x/time/rate实现请求限流,防止突发流量过载;2.共享http.Client并配置Transport参数以复用连接;3.利用channel和context控制最大并发数与请求超时;4.客户端声明Accept-Encoding:gzip,服务端中间件自动压缩响应;5.优化API减少冗余数据传输。组合这些策略可显著提高高并发场景下的系统性能与可靠性。150 收藏 -
goroutine泄漏已发生,pprof/debug/pprof/goroutine?debug=2可确认:若见432000s(5天)等超长阻塞时长,且chanreceive/select状态数持续单增,即为泄漏;重点排查ssh、httpreadLoop/writeLoop及自定义channel退出路径。148 收藏 -
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 收藏