首页 > 其他分享 > 夜莺监控突破一万 star,这是汗水,也是鞭策

夜莺监控突破一万 star,这是汗水,也是鞭策

时间:2024-12-31 15:09:14浏览次数:1  
标签:社区 star 项目 夜莺 开源 鞭策 监控 我们

夜莺监控项目在上周突破了一万 star,算是一个小小的里程碑。在开源领域,通常把 star 数量看作项目的繁荣指标,star 数量越多,说明愿意关注你的人越多。这个数字的背后,是一群人对你的鼓励、认可和支持,当然,还有鞭策。夜莺项目最早发起于 2020 年初,发展到现在接近四年时间,本文想借此机会聊聊我们做开源的初心,这四年的感悟,以及多方共赢的商业模式设计。

项目简介

 

夜莺项目最初是我们在滴滴的时候开源的,后来捐赠给中国计算机学会开源发展委员会进行托管,以基金会的方式运作。其 github 地址是 https://github.com/ccfos/nightingale,其中 ccfos 就是 CCF OpenSource,即中国计算机学会开源项目的统一地址。

项目至今,有 130 位 contributor 参与,共提交了 2600 多次 commit,发版了 170 多次,fork 数 1400,docker pull 228k,虽说我们还有很多不足,但这些数字让我们看到了持续进步的汗水。如果一个开源项目可以坚持投入 4 年,甚至 10 年,20 年,我们坚信它的社会价值会越来越大。

项目发起初心

如果聊到项目开源的初心,那得追溯到 10 年前我们开源 open-falcon 那会了,当时确实啥都不懂,就是凭一腔热血为爱发电,当时觉得吧,我们搞了一个自认为还不错的项目,独乐乐不如众乐乐,放出来大家一起完善,项目会越发牛逼。当时的我们,也没有想过什么商业模式,只是想把这个项目做好,让更多人用,让更多人参与。

实际遇到了如下一些问题,如果你也做过开源项目,估计会很有同感:

  • 维护者的心理压力大
    • 经常碰到不看文档的小白用户,问各种基础问题。就像一个二年级的小学生经常被问 1+1 等于多少,时间久了,会很厌倦
    • 偶尔会碰到颐指气使的人,用了你的项目,觉得你欠他的的一样,但凡遇到问题,不管是不是自己的问题就恶语相向

 

  • 维护者时间精力有限
    • 大部分开源项目都是维护者兼职在搞,时间精力有限,毕竟养家糊口才是第一位的,搞开源是上层精神层面的追求了
    • 这会导致有些问题处理不够及时,显然,这会导致用户不满。周末照顾家人时收到陌生人提问那也是家常便饭,我不开心,用户也不开心
    • 当维护者调岗跳槽之后,基本就不会继续参与了,这对项目而言是致命的
  • 项目功能发展设计其实还是靠你自己
    • 会有水平很高且愿意和你探讨项目设计发展的人,但确实数量不多,毕竟大部分开源项目影响力有限
    • 也会有参与者,通常是小修小改,偶尔还会碰到巨型 PR,是要改你的命名规范,因为他觉得现有的命名规范不符合他的审美

后来发起夜莺项目,我们就在思考如下这个关键问题:

如何才能让一些人才持续全情投入?只要有人持续投入,项目一定会越来越好,不管是功能层面、性能层面,还是文档、社区支持,只要有人持续参与,一切都会越来越好。但是人家得养家糊口啊,除非给人发工资。工资从哪里来?靠项目自身去赚不就行了。于是,,,我们创业了,做了一家公司叫快猫星云。

但是,事情远没有这么简单。

开源和商业的天然悖论

我们想到的第一个模式是靠技术 Support,因为 RedHat 就是这么干的。普通用户提供社区支持,商业用户提供商业支持,如果客户在生产环境部署了你的软件,为了防止紧急生产故障,买个 Support 以防万一,这理所当然,看起来是个好模式。但也仅仅是看起来,实操中会发现如下问题:

  • 监控、可观测性系统,我们觉得是 P0 级服务,但是很多客户觉得不影响核心系统所以没关系,重视程度不高,如果是核心 DB 或 OS,那就不一样了
  • 开源做的越好,比如功能越稳定、丰富,文档越完备,用户遇到的问题越少,越不需要 Support,如果开源做的不好,用户量起不来,也不会有商业用户
  • 边界不好界定。如果只是夜莺软件本身出问题我们来提供支持理所当然,那客户问这个 promql 怎么写?达梦数据库怎么监控?这些问题就很难界定了

所以,技术 Support 根本没有大规模商业化的底层逻辑支撑。如果你只是个人项目,养活自己就行,或者只是想赚点外快,这个模式或许还行,如果只是想养活几个人,这个模式我都觉得很难。

另外,开源监控、可观测性项目,可选择的项目还比较多,你如果收费,别家免费,即便你做的更好,也很难有人买单。你有养家糊口的压力,但是其他有些项目的研发人员人家已经财务自由了,人家就是可以全职不拿钱做开源,你怎么办?

多方共赢的商业模式设计

其他领域不敢讲,监控、可观测性这个领域,如何设计一个多方共赢的商业模式?我的个人观点(注意,只是个人观点)如下:

  • 开源的部分,需要是功能闭环的,即,不依赖商业功能也能用的起来。而且这部分功能要足够好,让用户觉得用的很爽,这样才能吸引用户。这部分承接了我们的精神层面的诉求以及商业营销层面的诉求。这部分功能,我们可以把它叫做社区版。我们要在社区版这块投入全职人力,给他们发工资做开源。
  • 没有预算的开源用户,可以免费使用社区版,有社区提供的技术支持,虽然响应速度没有商业版快,总还会有人响应,比那些动不动就撂挑子的开源项目会强很多。
  • 有预算的用户,可以购买商业版,商业版的功能要比社区版更强大,技术支持也更及时。比如开源版会重点做告警引擎功能,而商业版会做大一统的可观测性平台。其定位不能相同,定位相同了就没法取舍,比如一个功能是放社区版还是商业版,就很难界定了。

其他一些 ToB 商业公司同行可能会觉得我们这种做法就是毒瘤。因为我们开源的部分抢了他们的生意,但实际上,我们开源的是基础监控告警能力,即便没有我们,还是会有 Prometheus,会有 Zabbix 这些前辈在,如果 ToB 公司的生意能够被开源项目抢走,说明你的产品能力可能还需要加强。而社区版也承载了我们的精神层面的诉求,我们希望为社会提供一个好用的监控系统,让更多人受益,这是初心,我们不可能放弃。

活下去是责任,留下点什么才是关键价值

有些创业导师说,如果你只是为了钱,那不应该创业。实际上,创业的原因哪能是单一的。肯定是既要又要还要啊。

  • 既要赚到钱,养家糊口,发得起工资,这是责任
  • 又要部分员工可以全职做开源,满足一下精神层面的需求
  • 还要让飞轮转起来,越做越好越做越大,让各方受益

如果,我是说如果,我们站在生命的尽头,回首往事,什么会相对更有价值?我想,可能是过程中一起经历的风雨,以及我们生命留下的痕迹,我们在开源项目上的付出,可能会是我这碌碌无为的一生中最深的那个痕迹了吧。

标签:社区,star,项目,夜莺,开源,鞭策,监控,我们
From: https://www.cnblogs.com/ulricqin/p/18644069

相关文章

  • 用StartAI Flux文生图,轻松打造新年元旦海报背景图
    随着新年元旦的脚步日益临近,各个行业的竞争也愈发激烈。在这个关键的时刻,一张独具匠心、充满新年氛围的海报背景图,无疑将成为吸引顾客眼球、提升销量的重要法宝。现在,StartAI的Flux文生图功能为你提供了一个全新的创意平台,助你轻松打造独特的新年元旦海报设计。一、功能优势......
  • [CF2053C] Bewitching Stargazer 题解
    我们不妨直接递归模拟算答案。定义\(f(l,r)\)表示左右端点为\(l,r\)的答案。记\(mid\gets\lfloor\frac{l+r}{2}\rfloor\),于是:\[f(l,r)=\begin{cases}f(l,mid)+f(mid+1,r)&(r-l+1)\equiv0\pmod2\\f(l,mid-1)+f(mid+1,r)+mid&{\text{otherwi......
  • 3. Quick Start Guide 快速入门指南
    ForgettingstartedwithLALRPOP,it'sprobablybestifyoureadthetutorial,whichwillintroduceyoutothesyntaxofLALRPOPfilesandsoforth.GPT:要开始使用LALRPOP,最好的方法是阅读教程,它会介绍LALRPOP文件的语法以及其他相关内容。MS:要开始使用LAL......
  • Plate:Star12.4k,太逆天啦,几乎任何场景能都用到,轻量化、简单、易用的Ai富文本编辑框开源
    嗨,大家好,我是小华同学,关注我们获得“最新、最全、最优质”开源项目和高效工作学习方法Plate是一个强大的工具包,它让开发者能够更容易地使用Slate框架开发文本编辑器。Plate专注于四个主要领域:**核心(Core)、插件(Plugins)、原语(Primitives)和组件(Components)**。架......
  • 2053C - Bewitching Stargazer
    简化题意一个$1至n\(的区间,如果其长度是奇数,\)ans\(+=\)mid\(,再分为两个区间\)l\(~\)mid-1\(和\)mid+1\(~\)r\(,否则分为\)l\(~\)mid\(和\)mid+1\(~\)r\(,再次进行操作。直到长度小于\)k$。Solution我们可以先举个例子,例如\(n=22,k=4\)第一轮,\(1\)~\(11\),\(12\)~\(......
  • Camstar Portal 弹出层的使用:父子页面值传递
    效果如下在Onload方法注册事件protectedoverridevoidOnLoad(EventArgse){try{base.OnLoad(e);SearchBtn.Click+=newEventHandler(SearchBtn_Click);TranslateDetails.RowSelected+=newJQGridEventHandler(TranslateDetails_S......
  • 【gopher的java学习笔记】Spring Boot Starter初探
    转到java这边后,这天需要搭一个java的webservice出来,如果是以前golang的话,那我就可以非常熟练的用gin搭建一个webservice出来,核心逻辑就是写好一些rest接口实现后再加上最为灵魂的一句://启动Gin服务器在8080端口router.Run(":8080")那来到java这边,我第一反应......
  • Android Studio使用Flutter拉取依赖出现Waiting for another flutter command to rele
    Waitingforanotherfluttercommandtoreleasethestartuplock...意思就是等待释放锁,通过Waitingforanotherfluttercommandtoreleasethestartuplock这些方法依旧不行。还是会出现,无论是kill掉dart进程、删除localfile文件还是重启电脑,都没有解决这个问题。最后我......
  • StarRocks元数据无法合并
    一、先说结论如果您的StarRocks版本在3.1.4及以下,并且使用了metadata_journal_skip_bad_journal_ids来跳过某个异常的journal,结果之后就出现了FE的元数据无法进行Checkpoint的现象,那么选择升级版本到3.1.4以上,就可以解决。二、背景已经平稳运行了几个月的StarRocks集群突然奔溃......
  • spring boot 增加dynamic-datasource-spring-boot-starter多数据源依赖,项目打包后运行
    在本地idea运行正常,打包部署后运行会报错,经过github查询是dynamic-datasource-spring-boot-starter3.3.0版本存在问题,需要升级到3.3.1以上版本就可以正常运行<dependency><groupId>com.baomidou</groupId><artifactId>dynamic-datasource-spring-boot-st......