QCon北京「鸿蒙专场」火热来袭!即刻报名,与创新同行~ 了解详情
写点什么

Tengine 开源 5 周年:不忘初心 继续前行

  • 2016-12-26
  • 本文字数:1963 字

    阅读完需:约 6 分钟

Tengine,轻量级 Web 服务器,基于

Nginx 进行开发,针对大访问量网站的需求,新增了很多高级功能和特性。比如,Tengine 兼容 Nginx 的所有配置,并且增加了动态模块加载、集成了 Lua 语言进行扩展等很多实用的功能,并在性能方面做了较大的提升。Tengine 在微博、土豆、小米等大型互联网公司均有使用,阿里集团内部几乎所有需要使用七层负载均衡软件或者 Web 服务器的场景中也都有使用。

2011 年 12 月,Tengine 宣布开源。时至今日,已是 Tengine 走过的第 5 个开源年头。值此开源 5 周年之际,InfoQ 特采访了项目发起人及主要负责人朱照远(叔度),希望能够向大家详细的介绍一下 Tengine 的日常维护及后续发展。

采访嘉宾:

朱照远,2009 年加入淘宝网,花名叔度,现在是阿里云 CDN 团队负责人,负责阿里巴巴 Web 服务器、CDN 等系统的研发。他是开源 Web 服务器项目 Tengine 的发起人。他的研究方向包括高性能服务器开发、大型网站的架构和性能优化、云计算技术等领域。

InfoQ:作为 Tengine 开源项目的发起人及主要负责人,请您谈谈您在项目中主要起什么作用?目前开发和维护 Tengine 的人员有哪些?

叔度:我在项目中主要负责制定项目的开发计划并参与到开发之中。同时也负责审核团队里其他工程师提交的代码、日常问题解答等。

目前,公司内部有 3-4 人参与开发和维护 Tengine 项目,比如,我的工作平常主要就是负责负载均衡软件 Tengine 的维护和开发。不过,外部也有部分爱好者提交 patch,目前社区中提交并收入 patch 的开发人数有超过 50 人。

InfoQ:关于 Tengine 的发展历程,也许您最有发言权,那么您和您的团队在 Tengine 维护过程中都遇到过哪些困难?平时是怎么收集 bug 信息及用户反馈的呢?

叔度: 许多核心改动官方不支持,导致分支差异较大,每次合并 Nginx 主干需要花费相当大的 review 和测试时间;还有就是当开源项目与内部业务的时间安排相冲突时,内部业务任务紧急所导致的开发资源紧缺,这是目前我们面对的主要困难。

关于 bug 信息和用户反馈等的收集,我们主要还是通过 GitHub issue,当然用户邮件私信反馈上来的问题也占一部分。

InfoQ:Tengine 是基于 Ngnix 进行的二次开发,那么相较于 Ngnix,都解决了哪些主要问题?

叔度:Tengine 主要解决了如下问题:

(1) upstream 功能加强: 一致性 Hash,会话保持,后端主动健康检查,动态 upstream 修改;

(2) 更精细监控手段: 基于域名粒度数据统计,upstream 状态监控;

(3) 页面优化: CSS/JS/HTML 内容组合,HTML 内容缩减,footer 模块;

(4) 请求 body 过滤功能,body 流式上传;

(5) 模块动态加载框架;

(6) proc 模块框架: 基于此开发独立进程;

(7) 流控: 基于 CPU/Mem 等的进程保护模块 sysguard,原生请求限流模块加强;

(8) 其他许多核心改动如 reuseport、syslog 日志支持等。

InfoQ:Tengine 开源 5 周年之际,Tengine 2.2.0 新版本发布,这是继上次 Tengine 2.1.1 版本发布已经过去了一年多的时间,有人说阿里对 Tengine 已经不再重点维护,对此您怎么看?

叔度: Tengine 项目始终是阿里重点维护的开源项目,我们内部一直在对 Tengine 做维护和不断的改进。但是由于最近 1 年内部工作较多,精力有限所以没有做版本的发布。实际上最近一年 Tengine 在 GitHub 上的 commit 记录从未间断过,这也是最近发布 Tengine 2.2.0 的一个基础。还有就是我们最近又有很多新同学加入,后续版本迭代会恢复正常,希望能给大家带来更多的惊喜。

InfoQ:新发布的版本,都给大家带来了哪些新的功能及特性?如何有效利用 Tengine 源码进行深入学习?

叔度: 新特性主要包括:

debug_pool 模块,可以查看 Tengine/Nginx 内部内存分布 (基于 Nginx 的内存池轻量改造),可以帮助开发同学做内存优化和快速定位内存泄露。

如果想有效学习 Tengine 源码,建议查阅

官方文档了解大体功能,然后再结合代码阅读,或者查看当时的 pull request 提交记录。

InfoQ:请您谈一下这五年来维护开源项目的心得以及您对开源的一些想法。请您阐述下 Tengine 的下一步计划及未来的发展方向?

叔度:维护开源是一件有意义的事情,当基于真实需求开发出新的功能,开放出去不但能提高项目自身的完善度,同时也会帮助到其他有使用需求的人,也能够更好地促进大家对于开源的支持及参与。不仅如此,能够编写一份完善的文档,能够及时解答使用者的困惑,能够对反馈的信息及时收纳和处理,对开源项目的进一步发展都起着非常重要的作用。

下一步,我们希望能够将内部的一些通用的功能和模块整理并合入 Tengine 中。比如最近会先将 HTTP 请求流量拷贝模块和 HTTP 正向代理模块先整合进主干。另外还有各种丰富的调试优化改进以及集群监控管理功能,这些都将会逐步引入。不仅如此,我们还将积极跟进 Nginx 官方版本,尽快将 Tengine 版本与 Nginx 最新版本对齐,促进 Tengine 更好地发展,进一步扩大用户的使用范围。

2016-12-26 19:244267

评论

发布
暂无评论
发现更多内容

RayLink测评 | 完全免费,功能超越同类付费远程控制软件!!

RayLink远程工具

远程控制软件 远程办公软件 远控软件

【冲破信息孤岛】华为云大数据BI,助力金融行业进行数字化转型

秃头也爱科技

海量、安全、高可靠的华为云对象存储服务OBS,助力企业数据存储降本提效

清欢科技

打碎软件应用,在产业互联场景中串联—钉钉7.0关注企业间高效协同

B Impact

华为云对象储存OBS,为企业提供优秀且安全的数据储存环境

清欢科技

华为云对象存储,助力企业驶入“数据快车道”

清欢科技

企业内部使用的即时通讯软件有哪些?

BeeWorks

不止于大,华为云对象存储服务OBS的全能一面

清欢科技

推动企业稳定发现,华为云大数据助力能源企业纾困

秃头也爱科技

华为云对象存储OBS,助力企业降本增效

清欢科技

解决“双十一”电商行业数据存储难题,华为云OBS值得期待

清欢科技

还在为数据存储而烦恼?不妨进来看看华为云对象存储服务OBS

清欢科技

大数据一站式服务,华为云大数据BI驱动企业业务线增长

秃头也爱科技

云渲染和自己的电脑渲染哪个好?

Renderbus瑞云渲染农场

云渲染

FL STUDIO2023最新版本号21新变化

茶色酒

FL STUDIO20.9 FL Studio FL Studio 21

华为云OBS对象存储:企业“上云”的好帮手

清欢科技

阿根廷夺冠梅西加冕,球场外视频平台角逐世界杯

易观分析

视频 足球 卡塔尔世界杯

Android程序签名打包

芯动大师

Android Studio 打包签名 签名的含义

什么是云仿真,云仿真平台有哪些好处

3DCAT实时渲染

虚拟仿真 实时云渲染 云仿真 三维仿真

中国电信发布《天翼云安全白皮书》 打造高质量云网安全保障体系

极客天地

BI-数据可视化 | 年度干货合集

搞大屏的小北

数据可视化工具 BI 分析工具 BI分析 市场分析

跨浏览器测试策略

FunTester

2022“易观之星”奖项公布,聚焦数字经济,助力数智创新

易观分析

金融 易观 颁奖

存储数据如何更省钱?华为云告诉你!

清欢科技

即时通讯软件WorkPlus助力政企应用快速移动化

BeeWorks

软硬协同造就极致性能 天翼云紫金DPU打造为云而生的全新一代云计算体系结构

极客天地

HTTP的四种认证方式

穿过生命散发芬芳

HTTP 12月月更

提升企业决策能力,华为云用大数据BI助力企业腾飞

秃头也爱科技

2022-12-30:某天小美进入了一个迷宫探险,根据地图所示,这个迷宫里有无数个房间 序号分别为1、2、3、...入口房间的序号为1 任意序号为正整数x的房间,都与序号 2*x 和 2*x + 1

福大大架构师每日一题

算法 rust 福大大

架构中实时引擎与离线渲染的主要优势

3DCAT实时渲染

Unity 渲染 实时渲染 AEC

敏捷技术实践之重构

华为云PaaS服务小智

Tengine 开源5周年:不忘初心 继续前行_语言 & 开发_大冰_InfoQ精选文章