TranslateProject/translated/talk/20220928 Build an open source project using this essential advice.md
2023-07-12 18:51:31 +08:00

133 lines
9.1 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

[#]: subject: "Build an open source project using this essential advice"
[#]: via: "https://opensource.com/article/22/9/build-open-source-project"
[#]: author: "Bolaji Ayodeji https://opensource.com/users/bolajiayodeji"
[#]: collector: "lkxed"
[#]: translator: "wcjjdlhws"
[#]: reviewer: " "
[#]: publisher: " "
[#]: url: " "
使用这些必要的建议来构建开源项目
======
使用这些步骤来为你的第一个或接下来的项目打下坚实的基础。
[开源][2]是一个蓬勃发展且有益的生态系统,它通过分散模式和社区贡献开发的软件公开解决社区和行业问题。
随着这个生态系统的爆炸式发展,许多开发者想要参与并且构建新的开源项目。问题是:你如何成功地完成它?
这篇文章将会揭秘开源项目的生命周期与结构。基于我的个人经历,我想要向您概述一下开源项目的内部情况,向您展示一下怎样构建一个成功稳定的项目。
### 对开源的快速介绍
[开放源代码促进会][3]OSI提供了开源的正式、详细的定义但是维基百科提供了一个很好的总结
> 开源软件是根据许可证发布的计算机软件,在许可证中,版权所有者授予使用者使用、研究、更改和向任何人、为了任何目的分发软件和它的源代码的权利。
开源软件通常在网络上有公开的代码,它由多人合作或一人开发。这就需要与来自不同地区、不同文化和不同技术背景的人合作,而且往往是远程合作。
### 开源项目的剖析
就像人类的身体,一个开源项目由多个结构组成,这些结构构成了整个系统。我认为它们是两个分支:人(微观)和文件(宏观)。
#### 分支一:人
通常,一个开源项目包括以下人群:
* 创始人: 创建项目的人
* 维护者: 积极管理整个项目的人
* 贡献者: 为项目做贡献的人(像你一样的人!)
* 用户: 使用这个项目的人,包括开发者和非技术客户
* 工作组: 将贡献者分成特定领域的小组专注于围绕特定主题领域如文档、入职、测试、DevOps、代码审查、性能、研究等的集合。
* 赞助人: 为项目提供资金支持的人
当你准备构建一个新项目时,你需要考虑以上列表中的每一个群组。你对他们每个人有什么计划?
* 对于维护者,请确定任用维护者的标准。通常,积极的贡献者就是最爱好的维护者。
* 对于用户和贡献者,你需要准备可靠的文档、入职流程和他们使用你的项目取得成功所需的一切。
* 对于工作组,请确定你是否需要它们,以及你的项目将来如何有逻辑地拆分。
* 最后,对于赞助人,你必须提供足够的数据和有关你项目的信息使他们会选择赞助你。
你不必在你项目的起始阶段解决上面所有问题。然而,在早期阶段思考它们是很明智的,这样你就能打下正确的基础,确保未来的扩建项目能够站稳脚跟并取得成功。
#### 分支二:文件
开源项目通常包括下列文件,通常为纯文本或 markdown 格式:
* License 本法律文件解释了如何以及在何种程度上可以自由使用、修改和共享本项目。OSI网站上有OSI认可的许可证列表。如果没有明确的许可证您的项目在法律上就不是开源的
* Code of conduct 本文件概述了规则、规范、可接受的做法以及决定以任何方式参与项目的任何人的责任(包括当某人违反任何规则时会发生什么)。[贡献者公约][4] 是一个很好的示例,它是开源的(采用知识共享许可协议)。
* README 这个文件向新用户介绍你的项目。在很多 Git 托管网站上,比如 GitLabGitHub 和 CodebergREADME文件会显示在仓库的初始文件列表下。这里通常会提供文档以及其他必要文档的链接。
* Documentation 这是一个包含所有本项目文件资源的文件或目录包括指南、API 参考、教程等。
* Contributing 包含一份说明如何为项目做出贡献的文件,包括安装指南、配置等。
* Security 包括一个解释如何提交漏洞报告或安全问题的文件。
此外,一个项目通常有用于问题、支持和协作的网页。
大致包括:
* 问题或错误报告: 用户可以报告错误的地方。该页面还为开发人员提供了一个地方,让他们可以分配自己的任务来修复一个或多个错误。
* 拉取或合并请求: 提供功能增强建议和错误解决方案的地方。这些补丁可以由任何人创建,由维护者审核,然后合并到项目代码中。
* 讨论: 维护者、贡献者和用户讨论开源项目的地方。它可以是一个专门的网站,也可以是协作编码网站中的一个论坛。
大多数项目还通过在线聊天的形式为社区成员之间的对话和互动提供交流渠道。
### 许可证
[许可证][5] 也许是创建开源项前需要考虑的最简单但也是最重要的标准。许可证定义了允许使用、修改和共享项目源代码和其他组件的条款和条件。
许可证包含大量的法律术语,很多人并不完全理解。我使用 [choosealicense.com][6],它可以帮助你根据你的目标社区、你从使用你的代码的人那里获得补丁的愿望,或者你允许别人使用你的代码而不分享他们对你的代码所做的改进来选择许可证。
![这为何时使用 MIT 许可或 GNU GPLv3 许可提供了指导。它还建议为社区做出贡献的人们使用该社区所偏好的许可证。该图表还指出还有更多许可证可供选择。网站choosealicense.com有一个基于文本的版本可以链接到更详细的信息。][7]
图片由: (Bolaji Ayodeji, CC BY-SA 4.0)
### 创建一个开源项目的13个阶段
现在是关键问题: 如何开始开源软件项目?
以下是我所认为的开源项目的各个阶段。
1. 集思广益,撰写提纲,妥善记录。
2. 开始发展您的想法。这通常包括确定要使用的正确工具和堆栈、编写一些代码、对代码进行版本控制、调试、喝咖啡、在StackOverflow上闲逛、使用其他开源项目、睡觉、构建一些东西来解决确定的问题--或者只是为了好玩!
3. 在本地测试项目,根据需要编写一些单元测试和集成测试,根据需要设置 [CI/CD管道][8],创建一个暂存分支(在合并到主分支之前测试代码的测试分支),并完成部署项目所需的其他工作。
4. 编写 [良好有效的文档][9]。这应该包括您的项目是做什么的,为什么它是有用的,如何开始使用它(使用,安装,配置,贡献),以及人们在哪里可以得到支持。
5. 确保记录所有您希望使用的代码约定。使用诸如 linters、code formatters、Git hooks 和 commizen 命令行工具等工具来执行这些约定。
6. 选择合适的许可证并创建 README。
7. 在互联网上发布项目(您可能最初有一个私有的资源库,在这一步将其公开)。
8. 建立发布和记录更新日志的流程(您可以使用 Choesets 等工具)。
9. 向全世界推广项目!您可以在社交媒体上发帖、创办时事通讯、私下与朋友分享、进行产品发布、现场直播或其他任何您知道的传统营销策略。
10. 使用任何可用的融资平台寻求资金支持,如 Open Collective、GitHub Sponsors、Patreon、Buy me a Coffee、LiberaPay 等。当您在这些平台上创建账户时,请在项目文档和网站中添加相关链接。
11. 围绕你的项目建立一个社区。
12. 在必要时,考虑引入工作组,将项目管理分成合理的部分。
13. 不断实施新理念,维持项目背后的资源和人员。
随着项目的进展,对项目的不同部分进行评估非常重要。这将为您提供可用于评估和未来发展战略的数据。
### 现在开始一个项目吧!
我希望这篇文章能帮助您推进您一直在考虑的项目。
请随意将其用作指南,并在构建您的一流开源软件项目时填补我遗漏的任何空白。
--------------------------------------------------------------------------------
via: https://opensource.com/article/22/9/build-open-source-project
作者:[Bolaji Ayodeji][a]
选题:[lkxed][b]
译者:[wcjjdlhws](https://github.com/wcjjdlhws)
校对:[校对者ID](https://github.com/校对者ID)
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
[a]: https://opensource.com/users/bolajiayodeji
[b]: https://github.com/lkxed
[1]: https://opensource.com/sites/default/files/lead-images/BUSINESS_buildtogether.png
[2]: https://opensource.com/resources/what-open-source
[3]: https://opensource.org
[4]: https://www.contributor-covenant.org/version/2/1/code_of_conduct
[5]: https://opensource.com/tags/licensing
[6]: https://choosealicense.com
[7]: https://opensource.com/sites/default/files/2022-09/choosealicense.png
[8]: https://opensource.com/article/19/9/intro-building-cicd-pipelines-jenkins
[9]: https://slides.com/bolajiayodeji/effective-oss-docs