golang
已收录文章:11989篇
-
构建高性能微服务架构需充分利用Go的并发特性,尤其是goroutine和channel。其优势体现在轻量级、高效性和易用性上。goroutine创建和切换开销小,channel提供安全通信方式。选择架构风格应根据业务场景和团队能力:1.APIGateway模式适合简化客户端调用;2.BFF模式优化用户体验但增加维护成本;3.ServiceMesh提供可观测性但配置复杂。小型项目建议从APIGateway入手逐步演进。Goroutine泄露会导致资源浪费,可通过pprof工具、监控指标和代码审查排查,使用c151 收藏
-
要使用logrus开发Go应用的日志系统,需先安装库并导入,然后配置日志级别、格式和输出位置,再利用结构化字段记录上下文信息,还可选地添加Hook实现多端输出。1.安装logrus:运行gogetgithub.com/sirupsen/logrus;2.导入库并设置别名为log;3.设置日志级别如log.SetLevel(log.DebugLevel);4.选择输出格式如JSON:log.SetFormatter(&log.JSONFormatter{});5.设置输出位置如文件或终端;6.使用W151 收藏
-
在Golang中实现并发安全的单例模式,sync.Once适合初始化短耗时和低并发场景,atomic适合高并发且需极致性能的场景。1.sync.Once方案简单易用,通过互斥锁保证初始化仅执行一次,但存在锁竞争和首次获取阻塞的问题;2.atomic方案利用CAS操作避免锁,理论上性能更优,但实现复杂且初始化耗时无法并行;3.选择方案应基于实际场景:初始化短且并发低时优先使用sync.Once,初始化长且并发高时考虑atomic,但需充分测试验证性能提升和安全性。151 收藏
-
提升JSON序列化反序列化速度的核心在于选择高效库如jsoniter并结合优化技巧。1.选择jsoniter替代标准库,其通过编译时代码生成减少运行时反射开销;2.复用对象和buffer以减少内存分配;3.使用流式API处理大型JSON数据降低内存占用;4.忽略不必要的字段及使用合适类型减少转换开销;5.通过基准测试验证性能差异;6.其他方法包括自定义逻辑、替换更高效数据格式、减小JSON体积和缓存结果;7.注意jsoniter存在API兼容性、配置复杂度、错误处理及学习曲线等缺点。151 收藏
-
简介 cookie 是用于在 Web 客户端(一般是浏览器)和服务器之间传输少量数据的一种机制。由服务器生成,发送到客户端保存,客户端后续的每次请求都会将 cookie 带上。cookie 现在已经被多多少150 收藏
-
我是谁 defer - 顾名思义翻译过来叫 延迟, 所以我们通常称呼 defer func() 这样 defer 后面紧跟的函数为 延迟函数. 作者注: 不过从实际应用来讲, 延迟函数通常用来做一些函150 收藏