Go语言技术文章
-
用client-go连不上集群时,本地调试需用clientcmd.BuildConfigFromFlags()替代rest.InClusterConfig(),后者仅适用于Pod内且有RBAC的场景;批量PatchDeployment需手动循环并控制并发,不可直接goroutine泛滥。395 收藏 -
time.Ticker适用于固定间隔的周期性任务,但不保证绝对准时;需手动Stop防止goroutine泄漏;任务耗时超间隔会堆积触发,严格串行应改用time.Sleep。282 收藏 -
Go反射无法获取包级常量的类型信息,因为常量在编译期被内联为字面量,无运行时身份;reflect.TypeOf(const)实际推导其底层类型,而非反射常量本身。240 收藏 -
Context是Go中管理并发任务的核心工具,通过context.WithCancel可实现任务取消,调用cancel函数通知所有子任务退出;使用context.WithTimeout或WithDeadline可设置超时控制,超时后Done()通道关闭,任务需监听并及时终止。156 收藏 -
本文介绍使用OpenSSH的ControlMaster多路复用机制,在不阻塞主进程的前提下,安全、可检测地建立并验证SSH连接是否真正就绪,适用于需后续复用连接的Go子进程场景。342 收藏 -
Go连接Elasticsearch需处理TLS验证、v7/v8API差异、mapping结构错位及HTTP状态码检查,否则生产环境易现401、x509、timeout或查无结果。343 收藏 -
这是典型的闭包变量捕获问题:for循环中复用变量i,所有goroutine共享同一地址,导致打印的都是最终值;应显式传参或在循环内创建新变量绑定当前值。375 收藏 -
Go语言配置管理推荐使用结构体绑定、环境区分和环境变量覆盖,结合viper库实现多格式解析与性能优化,提升项目可维护性。383 收藏 -
Go类型断言失败会panic,因直接用value.(Type)时类型不匹配将触发不可恢复中断;必须使用value,ok:=interface{}.(Type)的comma-ok模式确保安全。297 收藏 -
Go用户注册登录需验证输入、bcrypt加密密码、参数化存储、JWT或Redis会话;校验邮箱、密码强度、用户名;禁用明文存储和SQL拼接;设HttpOnly/SecureCookie。480 收藏 -
go.mod的require不自动更新,仅显式操作或构建触发时写入;gomodtidy才真正对齐依赖,删除未引用项并补全实际import的所有依赖。327 收藏 -
Go项目目录结构无强制规范,但cmd/下须按可执行名建子目录(如cmd/api),main.go仅做配置加载、依赖初始化和app.Run()调用;internal/是编译器级私有边界,外部导入即报错;测试文件必须与源码同目录同包且以_test.go结尾。109 收藏 -
nats.Connect连不上JetStream是因服务端未启用,需加-js参数或配置jetstream块;js.Publish失败、消息丢失、重复消费等问题均源于JetStream未正确配置和使用。112 收藏 -
Go用net包监听TCP并回显原始字节需:启动goroutine处理每个conn,循环Read()直至io.EOF;用固定缓冲区并截取有效数据;手动处理粘包/拆包;encoding/binary解析固定长度二进制头;time.AfterFunc实现可重置超时与心跳;自定义io.Writer带时间戳记录收发流量。402 收藏 -
ZRangeByScore+ZREM会重复消费,因两worker并发查询后各自删除,需用Lua脚本原子性地查、删、推;score必须统一为秒级整数并NTP校时;ZPOPMIN是Redis5.0+真解法,asynq需手动配置RetryDelayFunc和ProcessIn保障严格一次语义。398 收藏