-
Notifications
You must be signed in to change notification settings - Fork 8.3k
如何贡献代码
Spring Cloud Alibaba 从开源建设以来,受到了很多社区同学的关注。社区的每一个 issue ,每一个 PR,都是对整个项目的帮助,都在为建设更好用的 Spring Cloud 添砖加瓦。
我们真心地感谢为这个项目提出过 Issue 和 PR 的同学,特别是这些 contributor: HaojunRen、xiejiashuai、mengxiangrui007 、liaozan
我们希望有更多社区的同学加入进来,一起把项目做好。
在贡献代码之前,请您稍微花一些时间了解为 Spring Cloud Alibaba 贡献代码的流程。
我们随时都欢迎任何贡献,无论是简单的错别字修正,BUG 修复还是增加新功能。请踊跃提出问题或发起 PR。我们同样重视文档以及与其它开源项目的整合,欢迎在这方面做出贡献。
如果是一个比较复杂的修改,建议先在 Issue 中添加一个 Feature 标识,并简单描述一下设计和修改点。
如果您是初次贡献,可以先从 good first issue 和 help wanted 中认领一个比较简单的任务。
- 点击 本项目 右上角的
Fork
图标 将 alibaba/spring-cloud-alibaba fork 到自己的空间。 - 将自己账号下的 spring-cloud-alibaba 仓库 clone 到本地,例如我的账号的
flystar32
,那就是执行git clone https://github.com/flystar32/spring-cloud-alibaba.git
进行 clone 操作。
- 在自己的机器执行
git config --list
,查看 git 的全局用户名和邮箱。 - 检查显示的 user.name 和 user.email 是不是与自己 github 的用户名和邮箱相匹配。
- 如果公司内部有自己的 gitlab 或者使用了其他商业化的 gitlab,则可能会出现不匹配的情况。这时候,你需要为 spring-cloud-alibaba 项目单独设置用户名和邮箱。
- 设置用户名和邮箱的方式请参考 github 官方文档,设置用户名,设置邮箱。
fork 出来的代码后,原仓库 Master 分支可能出现了新的提交,这时候为了避免提交的 PR 和 Master 中的提交出现冲突,需要及时 merge master 分支(master 分支对应当前仓库的 2.2.x 和 2021.x 两个主干分支,同时维护)。
- 在你本机的 spring-cloud-alibaba 目录下,执行
git remote add upstream https://github.com/alibaba/spring-cloud-alibaba
将原始仓库地址添加到 remote stream 中。 - 在你本机的 spring-cloud-alibaba 目录下,执行
git fetch upstream
将 remote stream fetch 到本地。 - 在你本机的 spring-cloud-alibaba 目录下,执行
git checkout master
切换到 master 分支。 - 在你本机的 spring-cloud-alibaba 目录下,执行
git rebase upstream/master
rebase 最新代码。
Spring cloud Alibaba 作为 Spring Cloud 的实现之一,在代码规范方面直接沿用了 Spring Cloud 项目规范,在正式开始之前请参考相关 代码格式规范说明,提交代码前需要先配置好代码格式规范。
开发自己的功能,开发完毕后建议使用 mvn clean install
命令确保能修改后的代码能在本地编译通过。执行该命令的同时还能以 spring 的方式自动格式化代码。然后再提交代码,提交代码之前请注意创建一个新的有关本特性的分支,用该分支进行代码提交。
- 同样,提交 PR 前,需要 rebase master 分支的代码,具体操作步骤请参考之前的章节。
- 如果出现冲突,需要先解决冲突。
提交 PR,根据 Pull request template
写明修改点和实现的功能,等待 code review 和 合并,成为 Spring Cloud Alibaba Contributor,为更好用的 Spring Cloud 做出贡献。
- 文档
- Documents
- Open Source components
- Commercial components
- Example
- awesome spring cloud alibaba