-
Notifications
You must be signed in to change notification settings - Fork 2.5k
Open Source Promotion Plan Summer 2022 (Chinese)
开源之夏(全称:开源软件供应链点亮计划——暑期 2022)是由中国科学院软件研究所与 OpenEuler 社区共同主办的一项面向高校学生的暑期在线活动,旨在鼓励在校学生积极参与开源软件的开发维护,促进优秀开源软件社区的蓬勃发展。主办方联合各大开源社区,针对重要开源软件的开发与维护提供项目,并向全球高校学生开放报名。
学生可以自由选择项目,与社区导师沟通实现方案并撰写项目计划书。被选中的学生将在社区导师指导下按计划完成开发工作,并将成果贡献给社区。项目的完成度由社区评估,主办方会根据评估结果给学生发放丰厚的奖金,学生还有机会成为社区 Committer。
Apache APISIX 是一个动态、实时、高性能的开源 API 网关,提供了负载均衡、动态上游、灰度发布、服务熔断、身份认证、可观测性等丰富的流量管理功能。
作为云原生 API 网关,Apache APISIX 可以帮助企业快速、安全地处理 API 和微服务流量,可应用于网关、Kubernetes Ingress 和服务网格等场景。目前已被普华永道数据安全团队、腾讯蓝军、平安银河实验室、爱奇艺 SRC 和源堡科技安全团队等专业网络安全机构测试,并得到了高度认可。
今年,Apache APISIX 社区向开源之夏 2022 组委会推荐了多项精选项目课题,现已上线第一批项目课题,欢迎同学们积极报名申请!
-
仔细阅读学生指南
-
多与导师沟通:每个项目都附有导师的联系方式,建议报名后通过邮件先与导师取得联系。
-
充分了解活动: 认真阅读各类指南、活动日程等内容。
-
仔细查看社区的文档:认真熟悉社区的参与方式、沟通渠道、社区软件设计文档和社区开源仓库代码等。
-
项目申请书的质量是被选中的主要因素:仔细阅读申请要求,提交申请材料。
-
项目描述:基于 Apache APISIX 的 xRPC 框架实现 dubbo 2 协议的代理功能,需要能根据配置动态路由,并增强其可观测性。
-
难度:进阶
-
导师:罗泽轩
-
联系方式:[email protected]
-
项目产出要求:
-
支持根据配置(service_name \ version 等)进行动态路由
-
可以在日志中记录当前请求的相关参数,如 service_name 等等
-
为上述功能提供详尽的文档。
-
-
项目技术要求:
-
能够跑通多个 Dubbo 官方的示例
-
能够有充分的测试覆盖
-
项目描述:OpenFunction 是一个云原生的开源 FaaS 平台,旨在让开发者聚焦于业务逻辑而无需关心运行时的环境和设施。Apache APISIX 是一个开源的云原生 API 网关。本项目将结合二者,进而能够让用户通过 Apache APISIX 代理托管在 OpenFunction 之上的函数,从而触发函数的运行。
难度:进阶
导师:张超
联系方式:[email protected]
-
项目产出要求:
-
向 Apache APISIX 提交实现 OpenFunction 插件的 PR,并在经过代码评审后合并进入主干分支
-
向 Apache APISIX 提交 OpenFunction 插件文档和,并在评审和合并进入主干分支
-
输出一篇博客介绍 Apache APISIX 是如何集成 OpenFunction 的
-
-
项目技术要求:
-
建议实现时采用小步快跑的模式,拆分若干个 PR 进行提交(小 PR 更易于评审,且效率更高)
-
向 Apache APISIX 提交 PR 时,需要附上完整的测试用例覆盖
-
项目描述:在当前 APISIX Dashboard v2 中提供基础的用户名密码认证方式,没有权限管理方案。因此需要实现一个认证及权限框架,用于对这些模块进行非侵入式扩展。
难度:基础
导师:白泽平
联系方式:[email protected]
-
项目产出要求:
-
实现认证、权限框架
-
实现一种认证、权限示例
-
完善开发文档
-
-
项目技术要求:
-
任务需要进行拆分,使用 GitHub PR 逐步进行
-
开发内容需要配合测试用例及文档
-
项目描述:Apache APISIX Ingress controller 是一个使用 Apache APISIX 作为数据面的 Kubernetes Ingress controller 实现。Gateway API 旨在通过许多供应商实现并具有广泛行业支持的富有表现力、可扩展和面向角色的接口来发展 Kubernetes 服务网络。
难度:进阶
导师:张晋涛
联系方式:[email protected]
-
项目产出要求:
-
使 APISIX Ingress controller 可以使用 Gateway API 中的 TCPRoute 配置 4 层流量代理
-
完整的 e2e test case
-
-
项目技术要求:
-
需要熟悉基于 Kubernetes 的 controller 开发
-
有一定的 Go 开发经验
-
项目描述:近一年来,Apache APISIX 新增了多个插件,目前已支持 70+ 插件。在 apisix.apache.org 增加了文档站的支持后,由于文档整体数量较多,在内容质量的呈现方面却有些滞后。之前中文文档的内容编写者众多且风格不统一,部分内容也会出现细节性的错误等,所以目前 APISIX 中文技术文档的内容上依然有很大的优化空间,我们希望在文档可读性和内容准确性上呈现出更好的一面。
该项目主要是对目前 Apache APISIX 官网文档最新版本的中文内容进行调整,涉及 Plugins 插件内容下 Security 和 Traffic 两个模块中的内容(共计 19 篇;如有项目优先级调整,则更换为同插件目录下 Obeservability 模块内容,共计 21 篇)。
文字量上翻译成中文篇幅短的预计不到 1000 字/篇,篇幅长的大概在 2000-3000 字/篇左右。算上预热期在内,4 个月完成 20 篇文档,大概每周可进行一篇文档的调整与输出,在时间上对于学生来说还算比较宽裕。
难度:基础
导师:Sylvia Su
联系方式:[email protected]
- 项目产出要求:
阅读并熟悉 APISIX 英文技术文档后,对中文技术文档的内容产出有一定思路。完成目前中文技术文档的内容重构与优化,保证内容符合社区写作标准且格式统一,内容通俗易懂同时对 APISIX 项目初学者友好,最重要是保证内容的准确性。最终发布至 Apache APISIX 官方文档站供开源爱好者参考使用。
-
项目技术要求:
-
熟练使用 Markdown、Git 与各类编辑器和 GitHub 网站
-
需要了解 APISIX 项目是什么、有用什么用、使用这些插件可以完成哪些场景等
-
项目描述:Apache APISIX 即将迎来 V3 版本,而 Apache APISIX Dashboard 也需要对 V3 版本进行适配,借此机会,我们需要将 Dashboard 的前端部分进行重构,以解决历史问题,并带来更好的体验。
难度:进阶
导师:杨陶
联系方式:[email protected]
-
项目产出要求:
-
使用 TypeScript 作为主要的编程语言
-
梳理项目结构,制定合理的重构计划
-
完成重构方案中路由与页面的重构工作
-
协助解决项目中现存的 issue
-
-
项目技术要求:
-
熟悉 TypeScript、React、NodeJS,以及相关生态
-
能使用 Git 和 GitHub 进行协作开发
-
了解 React 和 NodeJS 相关生态者优先
-
了解 Apache APISIX 者优先
-
项目描述:OpenID-Connect 是一套基于 OAuth2.0 协议的轻量级规范,OpenID-Connect 允许客户端基于授权服务器或身份提供商(IdP)进行的身份验证来验证最终用户的身份,并获得用户的相关信息。Apache APISIX Dashboard 支持以 OpenID-Connect 协议对接其他身份提供商,例如 Okta,Auth0 等平台,从而实现无需在控制面保存账号密码即可轻松登陆。
难度:进阶
导师:朱欣欣
联系方式:[email protected]
-
项目产出要求:
-
向 Apache APISIX Dashboard 提交支持 OpenID-Connect 协议功能的 PR,并在经过代码评审后合并进入主分支
-
向 Apache APISIX Dashboard 提交 OpenID-Connect 协议测试的 PR,完成对接其他平台的测试,并在经过代码评审后合并进入主分支
-
向 Apache APISIX Dashboard 提交功能使用文档,并在评审和合并进入主干分支
-
-
项目技术要求:
-
建议实现时采用小步快跑的模式,拆分若干个 PR 进行提交(小 PR 更易于评审,且效率更高)
-
向 Apache APISIX Dashboard 提交 PR 时,需要附上完整的测试用例覆盖
-
项目描述:目前,Apache APISIX 没有一个非常有用的配置文件工具来分析 CPU 或内存,开发人员只能使用基准测试或打印日志来分析 Apache APISIX。使用 eBPF 为 Apache APISIX 创建配置文件工具,使用 eBPF 捕获 Apache APISIX 中的 Lua 调用堆栈信息,并将其绘制成 CPU 火焰图。
难度:进阶
导师:厉辉
联系方式:[email protected]
-
项目产出要求:
-
使用 eBPF 捕获和解析 Apache APISIX 中的 lua 调用堆栈信息,对其进行汇总并生成 cpu 火焰图
-
利用 eBPF 同时捕获和解析 C 和 Lua 混合调用堆栈信息,对其进行总结,生成 cpu 火焰图
-
支持获取在 Docker 中运行的 Apache APISIX 进程
-
支持获取 Apache APISIX Openresty luajit 32/luajit 64 模式
-
-
项目技术要求:
-
熟悉 Lua/C
-
对 eBPF 和 Openresty 有一些了解
-
对 profiling 有一定了解
-