golang
已收录文章:1318篇
-
蓝绿部署适合稳定性优先的低频重大发布,金丝雀发布适合高频迭代与精准验证,两者可结合使用,关键在于根据业务需求选择合适策略并配合版本标识、健康检查、优雅关闭和配置外置化等实践提升Golang服务部署可靠性。242 收藏
-
令牌桶允许突发流量,漏桶保证恒定输出;Go中用rate.Limiter实现令牌桶,漏桶需手动实现并注意并发安全。358 收藏
-
策略模式通过接口封装不同算法,使算法可互换且与客户端解耦;Go语言利用接口和组合实现该模式,如定义SortStrategy接口及冒泡、快速排序等实现,通过Sorter上下文动态切换算法,实现解耦与扩展。437 收藏
-
用Golang构建DevOps工具链可实现从代码提交到部署运维的全自动化闭环。1.利用gobuild和交叉编译特性,结合Git事件触发自动化构建,生成带版本标签的静态二进制并上传制品库;2.使用Go编写部署控制器,通过SSH、KubernetesAPI或云SDK实现滚动更新、蓝绿发布,并集成Consul做服务发现,部署前自动执行数据库迁移;3.开发高性能日志采集Agent,结构化日志输出至ELK/Loki,暴露Prometheus指标,集成OpenTelemetry实现链路追踪,异常时通过钉钉或企业微信告474 收藏
-
Golang处理时间的关键在于掌握time.Now()获取当前时间、格式化与解析的方法以及时间计算和比较。1.使用time.Now()获取当前时间对象或时间戳;2.格式化时间需基于参考时间“2006-01-0215:04”进行定义;3.解析字符串为时间需严格匹配格式并注意时区;4.时间加减通过Add方法结合time.Duration实现;5.比较时间使用After、Before或Equal方法,计算间隔可用Sub方法获取时间差。116 收藏
-
Go语言中通过channel和goroutine实现发布订阅模式,核心角色为发布者、订阅者和消息中心。使用chan传递消息,消息中心管理订阅关系并广播消息,支持多主题、动态增删订阅者,利用缓冲channel避免阻塞,确保高效并发。示例中定义Topic、Event、Subscriber及PubSub结构,通过Start启动事件循环,Subscribe注册订阅,Publish发送消息,Unsubscribe移除订阅者,Stop停止服务。每个订阅者独立接收消息,发布者将事件推送到对应主题的channel,所有订165 收藏