我与 Apache 软件基金会的故事

2022-06-10 08:21:12 +08:00
 shaoyaoju

原文发布在 公众号:琚致远,也欢迎阅读 创业 2 年值得分享的事情 😊

2015 年我在读大一,在部署 Web 项目时用到了 Apache Web Server ,Apache 软件的羽毛标志只需看一眼就能牢牢记住。

Apache 软件基金会成立于 1999 年(我出生于 1997 年),作为全球最大的开源软件基金会,我从未想过会现在与它有更深入地联系。

项目

2019 年大学毕业后不久,APISIX 项目发起人联系到我,希望我能为 APISIX 贡献一个 Dashboard 项目。首先,什么是 APISIX ?那时我对 APISIX 项目的理解仅仅是一个开源的 API 网关,那什么是 API 网关呢?我没有使用过这类产品,更谈不上如何做一个与 APISIX 配套的 Dashboard 了。

在大学期间自己接了许多项目(来自学校、朋友介绍、政府部门),尽管我对“如何构建 API 网关控制台”没有思路,但我清楚一个 Web 项目包含了“需求确认、产品设计、代码开发、功能测试、服务上线”这几项基本流程。

在多次与 温铭、院生 沟通产品需求后,我为 APISIX 项目制作了 APISIX Dashboard V1:它没有精致的 UI (如下图所示),但能够满足对 APISIX 核心概念地操作,此时自己对 API 网关以及 APISIX 相关概念更加清晰了。

值得一提的是:APISIX 内置了数十种插件对 API 请求、响应进行处理,这些插件通过 JSONSchema 进行插件配置参数地合法性检查。以 limit-req 插件为例,它的 JSONSchema 规则如下:

local schema = {
    type = "object",
    properties = {
        rate = {type = "number", exclusiveMinimum = 0},
        burst = {type = "number",  minimum = 0},
        key = {type = "string"},
        key_type = {type = "string",
            enum = {"var", "var_combination"},
            default = "var",
        },
        rejected_code = {
            type = "integer", minimum = 200, maximum = 599, default = 503
        },
        rejected_msg = {
            type = "string", minLength = 1
        },
        nodelay = {
            type = "boolean", default = false
        },
        allow_degradation = {type = "boolean", default = false}
    },
    required = {"rate", "burst", "key"}
}

当用户为某一条 Route 配置插件时,为了降低用户理解 JSONSchema 规则的难度,我们尝试在界面中根据规则直接渲染表单字段,如何在界面中动态地生成插件配置表单是我遇到的最大的挑战。通过一系列调研与测试,我自定义了一个 UI 组件,它可以通过接收 JSONSchema 规则渲染指定表单,这个组件得到了许多用户好评。

在 2020 年中,我们计划开发 Dashboard V2 ,主要原因有:

  1. 随着插件越来越多,自己维护的表单组件不足以覆盖所有插件场景,无意中发现了 react-jsonschema-form 这个流行的 JSONSchema 表单生成器组件,希望使用它来解决表单生成的问题;
  2. Dashboard V1 是自己独立使用 Vue.js 与 ElementUI 开发的,在适配基金会发版要求时我们修改了大量的源码文件,由于种种原因代码变得不易那么维护;
  3. Dashboard V1 是直接对接了 Admin API ( DP ),我们希望采用 DP 与 CP 分离的架构,因此需要为 Dashboard 单独开发一个 API Server 。

直到今天,Apache APISIX Dashboard 依然在缓缓维护着 V2 版本。

具体开发过程不再赘述,但值得分享的事情是自 2019 年到 2020 年末,Apache APISIX Dashboard 与 Website 两个项目的 Web 贡献者非常少,这是由于 Apache APISIX 这个 API 网关属于中间件分类,用户以服务端开发者居多。为了解决事情多、贡献者少的问题,我选择使用 Ant Design 作为 UI 组件库、使用 Ant Design Pro 作为项目脚手架,直接原因是那段时间社区以中国开发者居多,采用文档清晰、产品质量高的 Ant Design 作为项目基础组件,会降低中国开发者的贡献门槛,唯一缺点是 Ant Design 在中国太流行了,许多项目的 Dashboard 长得非常像。

从下图可见,自 2020 年中到年末,Dashboard 贡献者数量在明显地上升。来自中国、印度的贡献者们,从一些国际化内容修改到大块模块地开发,为 Dashboard 项目添砖加瓦。其中,有几位贡献者的故事令人瞩目,我会在另一篇文章进行记述。

社区

中学时我对 Web 渗透技术非常感兴趣,会在各种技术论坛中学习、交流,那时我便经常听到“社区”这个词。2016 年,我参与到了 freeCodeCamp 中文社区中,并与 Miya 等人参与到中国多个城市站建设当中,以成都、上海、杭州之活跃,并结交了众多志同道合的朋友们。

2019 年参与到开源项目 APISIX 后,我在不断为项目贡献代码之外,也在关注、回复 GitHub 、邮件列表的用户问题,并与开源用户进行讨论。随着用户地逐渐增多、讨论越来越频繁,忽然我觉得有“社区”的味道了。

APISIX 项目被捐献给 Apache 软件基金会、2020 年从基金会毕业、拥有众多国内大 B 用户地生产使用案例等,每一个事件都吸引了众多行业用户关注、为社区带来了更多用户与贡献者、为项目带来了更多生产用户的内部反馈与实践。

社区是由人构建的,Apache APISIX 社区是由来自全球各地、有着不同语言与文化的贡献者、用户以及社区共同参与维护的。在过去 3 年时间里,我们一直在做这样的事情:

  1. 认可、宣传、普及 Apache 文化;
  2. 举办线上或线下社区会议,持续关注用户反馈;
  3. 帮助不同经验的贡献者参与社区之中;
  4. 持续优化项目、丰富文档资料,帮助用户更好地使用产品。

经过不懈的努力与坚持,Apache APISIX 社区贡献者已超过 400 位!🎉

成为 Apache APISIX 贡献者,我们会尝试联系大家并邮寄一份周边以表心意。每当收到来自不同国家的贡献者动态,作为社区建设的一份子,因 TA 们付出的卓越贡献而激动不已、也会为自己感到骄傲与自豪!

用户

Apache APISIX 属于基础软件设施的中间件分类,其用户指全球使用 API 的企业。

2019 年末,贝壳找房是已知的首家超大流量生产用户,那时起便每天处理过亿生产流量,Apache APISIX 表现的非常稳定。

想象一下:每乘地铁、出差乘飞机、购买咖啡 /奶茶、看哔哩哔哩、使用 WPS 时,这些数字服务的背后都有 Apache APISIX 的存在,这种感觉是多么的棒!

我们还有许多生产用户,请访问https://apisix.apache.org/showcase 了解更多。

认可

2019 年刚参与 Apache APISIX 时,仅仅是因为它是一个开源项目、自己一直希望深度参与到一个开源项目当中,在 2019 年 10 月份,温铭 告诉我项目成功捐赠到了 Apache Software Foundation ,在毕业之前叫做 apache/incubator-apisix,我被邀请进入 initial committer。我记得很清楚:那天在办公室,内心充满欣喜地打印 Apache CLA 文件,并签名、拍照、上传,然后拥有了自己的 Apache ID juzhiyuan!!!🎉

2020 年,项目从 Apache 软件基金会毕业后,自己成为了正式的 Apache APISIX PMC 成员,除了贡献代码外也在积极维护社区建设,帮助、观察新的贡献者并选举优秀的贡献者加入 Committer 。到目前为止,我已成功推选 8 位优秀的 Committer ,其中 2 现在是 Apache APISIX PMC 成员。

2022 年 3 月某一天早上,自己收到了 Apache Member 邀请邮件,这是多么惊喜的事情呀!意味着自己除了关注 Apache APISIX 社区之外,也有了更多的责任与义务,与各位共同维护、发展 Apache 软件基金会。为此,社区专门采访了我,请阅读琚致远:95 后 Apache Member 的成长之路

时间线

8704 次点击
所在节点    程序员
75 条回复
lakehylia
2022-06-10 14:02:13 +08:00
有课代表总结一下吗?
pastor
2022-06-10 14:21:14 +08:00
@lakehylia
我想尝试课代表:
1. 标题就是傍大腿装逼的风格。其实 apache 项目要分三六九等,进入 apache 未必就是真的牛逼的东西
2. 文章内容拖沓,找不到重点干货,更适合去做 PPT 忽悠老板然后给自己升职加薪,详情参考《沙漠骆驼》新东方年会版。踏实做技术的本分人,没几个不烦这种 PPT 技术达人的
3. 一个使用 antd 开发的 dashboard ,功能通常不会比很多公司的管理后台复杂,这玩意本身确实不牛逼
4. 年纪不大,语气是成功人事高高在上,少年非要装老成却又并没见到真正牛逼的点,肯定不讨喜
5. 而且说白了,这就是个间接的推广软文,我不反对推广干货,但是实在没看到干货,所以就烦了

要是像隔壁 3 年的同学一样谦虚 /t/858318 ,没人会在这里喷 OP ,而且隔壁 3 年的同学已经很牛逼了,对比之下,OP 这个标题、自己的实力和行文的口气,真忍不住想喷
zhw2590582
2022-06-10 14:21:40 +08:00
只看了第一段,后面忽略了,楼主之前是不是做过什么牛逼的事,让别人主动联系你?
shaoyaoju
2022-06-10 14:43:38 +08:00
@fregie 我加入公司较早,招聘有几个阶段:

1. 2020 年我们招聘十分严格(非社招),希望能邀请到一起创业的伙伴,到年末时不到 10 人;
2. 2021 年我个人认为简历筛选宽松了一点点,且开始招聘实习生,但社会招聘通过率不理想,因此又收紧了简历筛选标准;
3. 2022 年我们主要在海外招聘,并加入 2 位 Web 工程师和设计师。

这些年我们一直在寻找可以长久合作、一起创业的伙伴。😊
shaoyaoju
2022-06-10 14:49:06 +08:00
@zhw2590582 嗨,我在这里补充了联系原因: https://v2ex.com/t/858593#r_11753806
mlhadoop
2022-06-10 14:50:13 +08:00
@pastor #42 感谢总结,帮我节约 5 分钟
shaoyaoju
2022-06-10 15:02:41 +08:00
@pastor @qaweqa @manami 👋 将内容同步到 V2EX 不是为了讨谁的喜,背景我回复在了: https://v2ex.com/t/858593#r_11754182
pocketz
2022-06-10 15:15:33 +08:00
建议把时间线折叠一下,这样观感会好一些

看起来 Apache Member 好像很厉害的样子,有人能介绍一下吗
maplelin
2022-06-10 15:25:39 +08:00
希望 OP 多分享一下刚开始参与开源的经历(受邀请加入 APISIX 之前的经历),因为大部分有意成为开源贡献者的开发者可能都没有机会参与到知名项目的贡献中去,我觉得这部分内容 v 友会更有兴趣一点。
Ciallo
2022-06-10 15:33:05 +08:00
@manami #18 我朋友圈要是刷到一堆这些直接就删除了,都没必要屏蔽 😨
smalllam
2022-06-10 15:40:02 +08:00
不管楼上说啥,对于真正做事出成绩的,我个人一律表示支持肯定,就这样。
min
2022-06-10 16:02:21 +08:00
课代表帮忙总结一下,这软件是干嘛的?稳定么? 使用广泛么? 有替代竞品么?
lasuar
2022-06-10 16:08:35 +08:00
更多是在宣传自己
pastor
2022-06-10 16:15:33 +08:00
@shaoyaoju 同学,我总结的几条里,也没说是因为觉得 “你是为了讨谁的喜” 呀
yogogo
2022-06-10 16:25:28 +08:00
牛逼~~找不到其他词了,抱歉
liangch
2022-06-10 16:48:26 +08:00
宣传就好好宣传。思路有点乱。
jin5354
2022-06-10 16:51:27 +08:00
看了半天做的只是 dashboard 吗?如果没有技术深度,当然得不到 V 友的认可。。码农 PK ,技术至上。
lz 讲了太多的运营,合作,搞人脉,这些其实没那么多人想看,感觉 lz 适合当 CEO 而不是 CTO 。
有趣的是可以引用 @isb 的一句话 talk is cheap show me the code ,lz 的文章其实是 talk 太多 code 太少的例子。
jin5354
2022-06-10 16:58:17 +08:00
不是指 code 量少,其实还是如此浩瀚的篇幅的宏达的叙事,没能撑起大伙儿对技术的期望吧。
webfrogs
2022-06-10 17:12:25 +08:00
目前在用 apisix , 也贡献了几个小 pr 。好用,支持,加油~~
yuu95
2022-06-10 17:19:16 +08:00
牛逼。我看的总结

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/858593

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX