如何发起并运营一个开源项目

1. 前言

今天分享一下如何发起并运营一个开源项目。平时咱们开发用到的轮子大多都是开源的,能够说开源项目推进了IT行业的的发展,而这两年是开源项目的爆发期。对于我的来讲,开源项目也是开发者成长提高的途径之一。今天就来分享一下如何孵化并运营一个开源项目。git

2. 立项

凡是项目都须要创意,或者咱们称之为“点子”,来源有多个方面。github

不少开源项目包括编程语言都诞生于解决特定问题的过程当中,好比Java诞生于智能硬件平台的研发过程当中。因此你平常遇到的一些问题和你对这些问题的解决方案能够成为你建立开源项目的一个思路。这种状况下须要更多的创造性,同时还要规避一些法律风险。spring

你也能够对其它一些开源项目进行扩展和优化,有时候咱们能够站在巨人的肩膀上。就像开源Git托管平台Gitea诞生于Gogs。编程

更简单的方式是你甚至能够整合脚手架,目前在Github上的整合脚手架很是多,甚至有些项目知名度还很是高。编程语言

当你有这个契机你就有孵化开源项目的先决条件了。

3. 开发

接下来就是开发了,最开始只有你本身贡献所有的代码,并且你可能须要作得更多。开发尽可能遵循Git工做流,ISSUE功能要充分利用起来,用户的咨询建议和BUG反馈尽可能经过ISSUE来处理。spring-boot

ISSUE处理问题

经过吸取Pull Request也能够集思广益,提高你项目的质量。Gitee和Github还提供了一些漏洞检测和质量检测功能。也能提升你的开发质量。单元测试

3.1 测试

做为开源项目,必定要把好质量关。起码的单元测试要作,这样其它开发者会更加信任你的项目。学习

3.2 开源协议

开源协议是开源项目的重要标识,这个是必须的步骤。目前开源协议有不少,选择一款适合你的,通常状况下我选择Apache 2.0测试

协议除了放一个LICENSE文件在项目的目录中外,最好在每个源代码文件的copyright头中也声明一下,好比胖哥的开源项目Payment Spring Boot中是这样的:优化

3.3 其它配套设施

做为一个开源项目,项目说明README.md要有,用来对项目进行简单的介绍。由于是源码开放,代码注释也很是重要,也有利于向别人讲解你的思路和意图。若是有精力构建一个项目主页就可让你的项目更加高大上了,把文档、图文教程、CHANGELOG、Q&A、RoadMap分门别类放进去,也有利于用户更加深刻的了解学习你的开源项目。你能够看胖哥以往的相关文章有介绍的哦。

4. 发布

若是以为你的项目已经达到可用的程度就能够公开发布了。源代码国外确定是放在Github上,国内选择Gitee(码云)。根据你的喜爱选择一个主库,二者按期同步。另外要明确开发分支和正式分支,最好默认显示最近的正式版本分支。

大体的发版步骤

版本一经发布不能进行更改,版本号建议语义化,参考下图中Gitee的语义化说明。

Github和Gitee都提供了建立发行版的功能,以Gitee为例(Github一样有相似的功能):

Gitee建立发行版

建立完毕后,你的项目就会生成一个发行版,用户能够经过对应版本的发行版获取对应版本的源代码,查看描述。

Gitee获取对应版本的发行版

在进行源代码发行的同时,也建议部署对应的编译版本到公用依赖库,好比Java项目会发布的Maven中央仓库,JavaScript项目会发布到NPM,Python项目PyPi。若是你有能力使用CI/CD的话(例如Github Action),可让整个发版流水线化。

记得发版的同时,要发布对应版本的更新信息、文档等配套设施。

5. 推广

只要是产品就须要推广。推广是一个技术活,而这每每不是技术人员的强项。你能够在目标人群的汇集地友好地宣讲你的开源项目,例如一些开发者社区(开源中国),交流群等等,甚至是这几年比较火的短视频。每次发版可经过一些公共渠道进行公告。让你的开源项目尽量为人所知。可是请不要做弊,不要学某些人走捷径,花钱去购买Star。

在推广的过程当中,要学会收集和分析用户的意见。

6. 社区驱动

推广的同时要进行社区建设,有利于拉升你开源项目的活跃度,同时也能够从中提炼项目的需求。甚至能够将社区活跃者提高为项目贡献者,组建一个开源小团队。

社区驱动是开源项目发展的重要动力。

7. 总结

若是你想作好开源,就要把开源项目当作产品来作,坚持、创新、协做、运营、服务一个都不能少。我的也会在项目的打磨中成长提高。对于开源更重要的是一种态度。不管项目涉及的技术是否高深,开源者都应该获得鼓励和尊重。

关注公众号:Felordcn 获取更多资讯

我的博客:https://felord.cn

相关文章
相关标签/搜索