Function Mesh 开发工程师付睿:用户——开发者——Committer 之路

2024-02-14 22:50

本文主要是介绍Function Mesh 开发工程师付睿:用户——开发者——Committer 之路,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

关于 Apache Pulsar

Apache Pulsar 是 Apache 软件基金会顶级项目,是下一代云原生分布式消息流平台,集消息、存储、轻量化函数式计算为一体,采用计算与存储分离架构设计,支持多租户、持久化存储、多机房跨区域数据复制,具有强一致性、高吞吐、低延时及高可扩展性等流数据存储特性。
GitHub 地址:http://github.com/apache/pulsar/

Committer 新成员付睿

8 月,经过 Apache Pulsar PMC 的提名与审核,来自 StreamNative 的软件工程师付睿入选 Apache Pulsar Committer。祝贺 Apache Pulsar 社区 Committer 新成员付睿!

关注 Pulsar 社区的伙伴们或许对我们的新 Committer 早已有所耳闻。付睿曾任清华大学能源互联网研究院平台开发工程师,在 Pulsar Summit 2020 亚洲峰会上,曾分享 Apache Pulsar 在能源互联网领域的落地实践[1]。加入 StreamNative 后他也在 Pulsar Summit 2020 北美峰会介绍了 Function Mesh[2]

现在,付睿作为 Pulsar 开发工程师,主要的贡献有 Pulsar Function、Go Client,以及和 StreamNative 的同事共同研发 Function Mesh 和 Connector 来丰富对 Pulsar 用户的支持。

近日,我们和付睿进行了连线,聊聊他入行以及与 Apache Pulsar 的故事。以下内容根据采访整理而成。

用户到开发者的角色转换

付睿可以说是从 Pulsar 的用户一步步走到了 Committer 的位置。谈起他的 Pulsar 经历,就得从作为 Pulsar 用户谈起。

付睿在读书期间被导师寄予厚望,“被迫”去做架构方向,走进了架构师的行业。

从香港科技大学毕业后,付睿看到清华大学能源互联网研究院求职的机会,经过面试和交流很认可研究院的理念,就此开启了构建 IoT 平台的职业生涯。

在清华大学能源互联网研究院工作期间,由于旧的系统经过一年多的测试上线后并不符合需求,团队决定重新进行技术选型、修改架构,并且把新的系统需适应未来可能的业务场景纳入考虑范围内。于是通过搜索并研究 Pulsar 后,他的职业生涯就此被潜移默化地影响了。

Pulsar 支持消息队列,并且有丰富的计算功能 Pulsar Function,Pulsar Go Client 采用 Go 语言框架,都非常匹配清华大学能源互联网研究院物联网平台的技术需求。

那时 Pulsar 中文社区刚刚起步,付睿对接到了 Pulsar PMC 成员郭斯杰、翟佳以及 Committer 和 Go Client 作者冉小龙等人,将 Pulsar 带入了物联网平台。

机缘巧合下,付睿加入 StreamNative 成为 Pulsar 开发工程师。高频率与高质量的贡献让他很快获得 PMC 提名和投票通过,成为 Apache Pulsar Committer。

想当年,Committer 也是 Lv.1...

时隔两年,当问起在社区的第一个贡献,付睿仍印象深刻。他的第一个 PR 是关于 Go Function。当时 Pulsar 还处于早期的 2.4 版本,在 IoT 平台部署 Pulsar 后发现 Pulsar Function 与预期有所出入,付睿就在仓库里提了 issue。问题很快得到郭斯杰和冉小龙的回复,经过讨论后他基于自己理解提了 PR 来解决 Go Function Config 问题。

“虽然以前参与过开源社区,但是这是我第一次在 Apache 项目提 PR。” 面对全新的社区和项目,“当时很激动,我认真地写了描述,尽可能在 PR 描述清楚、重现问题。提完 PR 很紧张,每天都去刷新回复看 review。

打怪升级指南

从新人到用户,再到开发者和 Committer,付睿从自己的角度给出了与社区交流的建议:

“首先,要在提 issue 和 PR 前尽可能能理清问题、解释清楚、确保上下文详尽,方便大家理解问题来为你提供帮助。

另一方面,Pulsar 仓库 Wiki 提供了贡献代码的详细说明。每个想要参与的人都可以去阅读流程,README 文件也有对新手帮助的信息。

同时也要善于搜索。与其等待回复和交流,可以先去搜索相关问题和内容。很多仓库过往 issue、PR 和官方资料都可以解决你的疑问。”

寄语社区

Apache Pulsar 社区呈现的是开放友好、积极向上的气氛。希望我和越来越多新加入社区的人,可以像优秀的贡献者一样,共同将这份开放友好、积极的精神发扬光大。


想和付睿近距离沟通 Function Mesh 与 Go Client 吗?按照以下步骤加入 SIG 群吧!


加入 Apache Pulsar 社区

参与开源,可以获得公司及社区内外的认可,结交来自各个领域、志同道合的小伙伴;同时也可以提高个人影响力,促进个人发展。参与开源不是码农的专属,社区、文档等各个方面都可以让大家发挥一技之长。

作为全球性开源项目,截至目前,Apache Pulsar 已拥有 440+ 名贡献者、9.5K+ Star 、2.3K+ Fork 。我们为大家提供了参与指南,欢迎越来越多的小伙伴助力 Apache Pulsar 项目的不断发展与前进。

相关阅读

Apache Pulsar 官方贡献指南[3]
社区活动|Apache Pulsar 社区志愿者招募

引用链接

[1] Apache Pulsar 在能源互联网领域的落地实践: https://pulsar-summit.org/zh/event/asia-2020/sessions/when-the-energy-internet-meets-apache-pulsar
[2] Function Mesh: https://www.na2021.pulsar-summit.org/function-mesh-complex-streaming-jobs-made-simple
[3] Apache Pulsar 官方贡献指南: http://pulsar.apache.org/en/contributing/


点击「阅读原文」,为 Pulsar 点赞

这篇关于Function Mesh 开发工程师付睿:用户——开发者——Committer 之路的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/709791

相关文章

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

SpringBoot 多环境开发实战(从配置、管理与控制)

《SpringBoot多环境开发实战(从配置、管理与控制)》本文详解SpringBoot多环境配置,涵盖单文件YAML、多文件模式、MavenProfile分组及激活策略,通过优先级控制灵活切换环境... 目录一、多环境开发基础(单文件 YAML 版)(一)配置原理与优势(二)实操示例二、多环境开发多文件版

使用docker搭建嵌入式Linux开发环境

《使用docker搭建嵌入式Linux开发环境》本文主要介绍了使用docker搭建嵌入式Linux开发环境,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1、前言2、安装docker3、编写容器管理脚本4、创建容器1、前言在日常开发全志、rk等不同

Python实战之SEO优化自动化工具开发指南

《Python实战之SEO优化自动化工具开发指南》在数字化营销时代,搜索引擎优化(SEO)已成为网站获取流量的重要手段,本文将带您使用Python开发一套完整的SEO自动化工具,需要的可以了解下... 目录前言项目概述技术栈选择核心模块实现1. 关键词研究模块2. 网站技术seo检测模块3. 内容优化分析模

基于Java开发一个极简版敏感词检测工具

《基于Java开发一个极简版敏感词检测工具》这篇文章主要为大家详细介绍了如何基于Java开发一个极简版敏感词检测工具,文中的示例代码简洁易懂,感兴趣的小伙伴可以跟随小编一起学习一下... 目录你是否还在为敏感词检测头疼一、极简版Java敏感词检测工具的3大核心优势1.1 优势1:DFA算法驱动,效率提升10

Python开发简易网络服务器的示例详解(新手入门)

《Python开发简易网络服务器的示例详解(新手入门)》网络服务器是互联网基础设施的核心组件,它本质上是一个持续运行的程序,负责监听特定端口,本文将使用Python开发一个简单的网络服务器,感兴趣的小... 目录网络服务器基础概念python内置服务器模块1. HTTP服务器模块2. Socket服务器模块

Java 与 LibreOffice 集成开发指南(环境搭建及代码示例)

《Java与LibreOffice集成开发指南(环境搭建及代码示例)》本文介绍Java与LibreOffice的集成方法,涵盖环境配置、API调用、文档转换、UNO桥接及REST接口等技术,提供... 目录1. 引言2. 环境搭建2.1 安装 LibreOffice2.2 配置 Java 开发环境2.3 配

Python38个游戏开发库整理汇总

《Python38个游戏开发库整理汇总》文章介绍了多种Python游戏开发库,涵盖2D/3D游戏开发、多人游戏框架及视觉小说引擎,适合不同需求的开发者入门,强调跨平台支持与易用性,并鼓励读者交流反馈以... 目录PyGameCocos2dPySoyPyOgrepygletPanda3DBlenderFife

使用Python开发一个Ditto剪贴板数据导出工具

《使用Python开发一个Ditto剪贴板数据导出工具》在日常工作中,我们经常需要处理大量的剪贴板数据,下面将介绍如何使用Python的wxPython库开发一个图形化工具,实现从Ditto数据库中读... 目录前言运行结果项目需求分析技术选型核心功能实现1. Ditto数据库结构分析2. 数据库自动定位3

Django开发时如何避免频繁发送短信验证码(python图文代码)

《Django开发时如何避免频繁发送短信验证码(python图文代码)》Django开发时,为防止频繁发送验证码,后端需用Redis限制请求频率,结合管道技术提升效率,通过生产者消费者模式解耦业务逻辑... 目录避免频繁发送 验证码1. www.chinasem.cn避免频繁发送 验证码逻辑分析2. 避免频繁