Go语言技术文章
-
本文回答 Go 普通 map 并发读写为什么会报错,解释常见误区,并通过互斥锁、sync.Map、race 检查和封装访问给出可落地的选择方法。418 收藏 -
Golang · Go教程 | 3天前 | defer · 单元测试 · testing · Go教程 · t.Cleanup · defer 单元测试 Testing 子测试 Go教程 T.Cleanup 测试资源清理
Go 测试代码里的临时文件、测试库、测试服务和环境变量,最好让清理动作跟随 testing.T 生命周期。本文对比 defer 和 t.Cleanup 的适用边界,给出可落地迁移清单。418 收藏 -
dockersystemprune不够用,因它无差别删除悬空资源,而实际需按前缀、时间、数量精准清理镜像并跳过被容器引用的;推荐用dockerimages--format'{{json.}}'解析结构化输出,结合容器镜像白名单与ID去重策略安全删除。417 收藏 -
Golang应用部署与运维自动化通过容器化、CI/CD、可观测性和IaC实现高效交付;容器化利用多阶段构建和精简镜像提升部署效率与稳定性,CI/CD通过自动化测试、构建、部署及回滚机制确保发布可靠,结合GitLabCI/CD、GitHubActions或ArgoCD等工具实现全流程自动化。417 收藏 -
init函数里调用sync.Once或启动goroutine容易死锁Go的包初始化是同步、单线程执行的,所有init函数按依赖顺序串行跑完才结束。一旦在init里触发了需要等待其他init完成的操作,就卡住。典型错误:在init中调用sync.Once.Do,而该Do的函数体又间接依赖另一个尚未执行的包的init;或者直接起goroutine并用sync.WaitGroup等待——WaitGroup.Wait永远不会返回,因为那个goroutine所依赖的417 收藏 -
这八个是日常开发中真正高频、不可绕开的核心标准库,因它们覆盖服务启动、数据进出、资源管理、并发协调、时间控制和格式输出等80%代码场景,其余为按需加载的场景专用库。417 收藏 -
net.Listen后程序立刻退出是因为未写Accept循环;必须用for循环持续调用listener.Accept(),否则只处理一个连接即终止,且需显式Close监听器。417 收藏 -
swag生成API文档时接口未显示,主因是扫描路径未覆盖handler文件或package不合法;@Param报错因type只支持基础类型或@Model定义的struct;中文乱码源于swagger.json编码异常或注释含非法字符。417 收藏 -
长连接网关中struct字段顺序关键,因Connection实例生命周期长、核心字段(如fd、state、readDeadline)被高频轮询或原子更新,若分散在多个64字节缓存行,将导致L1缓存miss率激增,实测吞吐下降7%;需按访问热度+大小双维度重排,使热字段紧凑落入前64字节,并隔离atomic字段防伪共享。417 收藏 -
网关结构体字段顺序不合理会导致单实例多占30%~50%内存,因高频创建、批量分配及缓存行失效加剧GC压力与延迟;需按对齐优先级(8字节>4字节>1/2字节)重排字段,并用unsafe.Sizeof和Offsetof验证padding。417 收藏 -
Go中构造函数必须返回error,因无类机制而用NewXXX函数初始化结构体,需校验参数、避免goroutine、用选项函数传参、立即清理失败资源并提供上下文错误信息。416 收藏 -
RabbitMQ消费者重复消费是因“至少一次投递”设计所致,需通过Redis+消息ID实现幂等,而非依赖DeliveryTag、MessageId或数据库唯一索引兜底。416 收藏 -
合理预分配slice容量、减少字符串键拷贝、用slice+索引map替代纯map存储可显著提升Go中map与slice混合使用性能,尤其在频繁插入和遍历场景下。416 收藏 -
连NATS需显式配置重连、凭证和TLS;JetStream需手动初始化上下文并创建流,设对RetentionPolicy、发布带唯一MsgID、订阅用DeliverAll,多goroutine并发publish会导致乱序。416 收藏 -
Go中同一文件多个init函数按源码出现顺序执行,不可互相调用;跨包按导入依赖拓扑序执行,main包init最后运行;init内panic导致程序立即终止,不可recover。416 收藏