百度BFE的Go语言应用与挑战
需积分: 19 73 浏览量
更新于2024-07-19
收藏 670KB PDF 举报
"李炳毅在Gopher China 2016大会上的演讲分享了Go语言在百度BFE(Baidu FrontEnd)项目中的应用,讲述了BFE作为百度统一前端平台的功能、发展背景以及为何选择Go语言进行重写。此外,还探讨了Go语言在BFE项目中遇到的挑战,如垃圾回收(GC)问题及其优化策略。"
李炳毅,作为百度运维部BFE团队的一员,自2010年加入百度,专注于流量接入、安全和防攻击工作,并参与了多个使用Go语言开发的项目,如7层流量代理Go-BFE和应用层防火墙WAF。BFE是一个七层流量接入平台,主要负责百度各重要产品的流量调度、防攻击和数据分析,日处理请求量达到千亿级别。
随着BFE从Transmit、Utr、C-BFE的演变到Go-BFE,主要原因是原有系统存在高修改成本、事件驱动编程模型的调试难度、C语言的开发效率低下、配置管理落后以及不支持平台化等问题。因此,技术选型转向Go语言,考虑到其较低的学习成本、同步并发编程模型、内存管理和强大的语言描述能力,尽管在BFE的场景下性能并非首要考虑因素,但可以通过算法设计和架构优化来满足性能需求。
然而,Go语言的垃圾回收机制带来了延迟问题,这对实时性要求极高的BFE来说是个挑战。李炳毅提到,GC的延迟可能达到几十到几百毫秒,这在高并发环境下可能导致明显的性能影响。为了优化,他们采取了一系列措施,包括减少对象数量、合并小对象、利用C代码和cgo、对象复用(对象池)以及深度优化系统结构和算法。例如,通过将小对象合并成大对象,利用Array减少引用,以及在必要时将数据移至C代码,以降低GC扫描的影响。
演讲中还讨论了其他技术问题,如http协议栈的处理和分布式架构的设计,以及开发过程中对好用工具链的需求。这些内容展示了Go语言在大规模、高性能网络服务中的实际应用和面临的挑战,以及如何通过技术创新和优化来解决这些问题。
2021-07-24 上传
点击了解资源详情
点击了解资源详情
2019-08-13 上传
2021-02-18 上传
2021-07-12 上传
2022-03-03 上传
liuhui0001
- 粉丝: 0
- 资源: 3
最新资源
- Angular实现MarcHayek简历展示应用教程
- Crossbow Spot最新更新 - 获取Chrome扩展新闻
- 量子管道网络优化与Python实现
- Debian系统中APT缓存维护工具的使用方法与实践
- Python模块AccessControl的Windows64位安装文件介绍
- 掌握最新*** Fisher资讯,使用Google Chrome扩展
- Ember应用程序开发流程与环境配置指南
- EZPCOpenSDK_v5.1.2_build***版本更新详情
- Postcode-Finder:利用JavaScript和Google Geocode API实现
- AWS商业交易监控器:航线行为分析与营销策略制定
- AccessControl-4.0b6压缩包详细使用教程
- Python编程实践与技巧汇总
- 使用Sikuli和Python打造颜色求解器项目
- .Net基础视频教程:掌握GDI绘图技术
- 深入理解数据结构与JavaScript实践项目
- 双子座在线裁判系统:提高编程竞赛效率