golang
已收录文章:102篇
-
HTTP/REST适用于简单同步通信,Go的net/http包支持开箱即用,适合管理类或低频交互;2.gRPC基于HTTP/2和Protobuf,性能高、类型安全,支持多种调用模式,是微服务间主流选择;3.消息队列如Kafka、RabbitMQ实现异步解耦,适用于削峰填谷和事件驱动场景;4.应根据一致性、延迟、团队熟悉度等权衡选择,并结合超时、重试、监控等实践提升系统稳定性。293 收藏
-
使用replace指令或GoWorkspaces可引用本地模块。首先在主应用go.mod中通过require声明本地模块路径,再用replace指令将其映射到本地文件系统路径(相对或绝对),随后运行gomodtidy使更改生效;另一种更优方案是使用Go1.18+的GoWorkspaces,在工作区根目录执行goworkinit创建go.work文件,并用goworkuse添加主应用和本地模块,无需修改go.mod即可实现多模块协同开发,避免污染主模块文件且更利于团队协作与CI/CD集成。290 收藏
-
gRPC-Web代理是前端与Go后端gRPC服务通信的关键桥梁,它将浏览器的HTTP/1.1请求转换为gRPC后端的HTTP/2协议,实现协议转换、CORS处理和双向兼容,确保前端可通过生成的客户端桩安全调用强类型的gRPC服务。284 收藏
-
Go语言函数调用开销主要来自栈管理、参数拷贝、寄存器保存和调用指令延迟,逃逸分析导致的堆分配会进一步增加成本。编译器通过内联优化减少调用开销,但受函数大小、闭包和递归限制。优化措施包括指针传递大结构体、合并小函数、避免过度抽象、使用pprof定位热点及缓存结果,结合逃逸分析和内联控制可有效提升高并发性能。280 收藏
-
答案:Go中实现线程安全单例应优先使用包初始化或sync.Once。包级变量初始化天然线程安全,适合无延迟需求场景;需延迟初始化时,sync.Once能确保实例仅创建一次,避免手动加锁带来的内存屏障等问题,是推荐做法。280 收藏
-
Golang的archive/zip库通过zip.Writer和zip.Reader实现ZIP文件的压缩与解压,压缩时需为每个文件创建zip.FileHeader并写入相对路径以保留目录结构,解压时需校验路径防止ZipSlip漏洞;处理大文件时依赖流式I/O避免内存溢出,但需注意磁盘I/O、CPU消耗及小文件数量带来的性能瓶颈,可通过调整压缩级别、并发处理和缓冲区优化提升效率;常见错误包括文件I/O失败、ZIP格式无效、路径安全风险等,应全面检查错误、包装错误信息、验证路径合法性并确保资源及时释放。273 收藏