写点什么

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:244510

评论

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

第一届POLARDB数据库性能大赛-亚军0xCC☣☢比赛攻略

阿里云天池

Windows 11 version 23H2 中文版、英文版 (x64、ARM64) 下载 (updated Sep 2024)

sysin

windows 11

链藏“万亿金矿”的新能源,汽车企业如何抓住客户体验数字化新机遇?

八爪鱼采集器︱RPA机器人

爬虫 采集

爬虫如何帮助构建比价系统|涨姿势

八爪鱼采集器︱RPA机器人

爬虫 采集

AI加速数字员工智能化落地——中国数字员工市场发展及企业数字员工落地建议

易观分析

ChatGPT 向更多用户推出高级语音模式:支持 50 种语言;字节发布两款新视频生成大模型丨 RTE 开发者日报

声网

面试官:谈谈你对 IoC 和 AOP 的理解!

JavaGuide

Java spring aop ioc

手工测试用例转Web自动化测试生成

霍格沃兹测试开发学社

Windows 10 version 22H2 (updated Sep 2024) 中文版、英文版下载

sysin

windows 10

Windows Server 2022 中文版、英文版下载 (updated Sep 2024)

sysin

windows Server 2022

客户成功案例(1):新闻媒体/招投标/行业资讯数据聚合

八爪鱼采集器︱RPA机器人

爬虫 采集 爬虫软件

CVPR2021 安全AI挑战者计划第六期赛道一第二名方案分享 (UM-SIAT队)

阿里云天池

如何根据拍立淘API返回值进行商品数据分析

技术冰糖葫芦

API Gateway api 货币化 API 接口 API 测试 pinduoduo API

天池云上智能降雨量预测总决赛-优胜奖RIOFGROUP队攻略分享

阿里云天池

性能测试 | JMeter的运行

测试人

软件测试

面试官:项目中如何实现布隆过滤器?

王磊

Databend 为什么能帮用户降低 90% 成本?

Databend

客户成功案例3:企业数据模型搭建、灾害预警解决方案

八爪鱼采集器︱RPA机器人

爬虫 采集

JMeter的运行

霍格沃兹测试开发学社

豆包MarsCode初体验,用 React 创建一个最经典的贪吃蛇游戏

TRAE

人工智能 编程 程序员 AI 代码

2024-09-25:用go语言,给定一个长度为 n 的整数数组 nums 和一个正整数 k, 定义数组的“能量“为所有和为 k 的子序列的数量之和。 请计算 nums 数组中所有子序列的能量和,并对

福大大架构师每日一题

福大大架构师每日一题

Windows 10 on ARM, version 22H2 (updated Sep 2024) ARM64 AArch64 中文版、英文版下载

sysin

windows arm 10

洞察药监局数据,挖掘万亿价值

八爪鱼采集器︱RPA机器人

爬虫 采集

TEDxDUTH 使用 NocoBase 实现革新

NocoBase

低代码 TED 管理工具 无代码 创新管理

火山引擎数据飞轮面向企业大模型业场景务提供数智服务

字节跳动数据平台

大模型 数智化 数智化转型

Spark“数字人体”AI挑战赛_脊柱疾病智能诊断大赛_GPU赛道亚军比赛攻略_triple-Z团队

阿里云天池

华为四大创新助力运营商打造万兆智能接入网,加快50G PON商用部署,加速智能应用创新

极客天地

体验3A云游戏,无需购买高端显卡

Ogcloud

云游戏 3A云游戏 云游戏发行 游戏云化

如何借助SD-WAN实现简单且经济的组网?

Ogcloud

SD-WAN 企业组网 SD-WAN组网 SD-WAN服务商 SDWAN

Lightroom Classic 2022(lrc2022)支持(Win&Mac)版

你的猪会飞吗

LRC2022 mac破解软件下载 lrc2022下载

鸿蒙智行首款轿跑SUV智界R7上市,小艺化身贴心随行的用车顾问

极客天地

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