docs/contribute_guide/贡献指南.md
欢迎 👏🏻 👏🏻 👏🏻 来到 KnowStreaming。本文档是关于如何为 KnowStreaming 做出贡献的指南。如果您发现不正确或遗漏的内容, 请留下您的意见/建议。
请务必阅读并遵守我们的:行为准则。
按要求,在 创建Issue 中创建ISSUE即可。
需要重点说明的是:
Commit-Log 包含三部分 Header、Body、Footer。其中 Header 是必须的,格式固定,Body 在变更有必要详细解释时使用。
1、Header 规范
Header 格式为 [Type]Message, 主要有三部分组成,分别是Type、Message,
Type:说明这个提交是哪一个类型的,比如有 Bugfix、Feature、Optimize等;Message:说明提交的信息,比如修复xx问题;实际例子:[Bugfix]修复新接入的集群,Controller-Host不显示的问题
2、Body 规范
一般不需要,如果解决了较复杂问题,或者代码较多,需要 Body 说清楚解决的问题,解决的思路等信息。
3、实际例子
[Optimize]优化 MySQL & ES 测试容器的初始化
主要的变更
1、knowstreaming/knowstreaming-manager 容器;
2、knowstreaming/knowstreaming-mysql 容器调整为使用 mysql:5.7 容器;
3、初始化 mysql:5.7 容器后,增加初始化 MySQL 表及数据的动作;
被影响的变更:
1、移动 km-dist/init/sql 下的MySQL初始化脚本至 km-persistence/src/main/resource/sql 下,以便项目测试时加载到所需的初始化 SQL;
2、删除无用的 km-dist/init/template 目录;
3、因为 km-dist/init/sql 和 km-dist/init/template 目录的调整,因此也调整 ReleaseKnowStreaming.xml 内的文件内容;
TODO : 后续有兴趣的同学,可以考虑引入 Git 的 Hook 进行更好的 Commit-Log 的管理。
详细见:PULL-REQUEST 模版
需要重点说明的是:
本节主要介绍对 KnowStreaming 进行代码贡献时,相关的操作方式及操作命令。
名词说明:
Fork KnowStreaming 主仓库至自己账号下,见 https://github.com/didi/KnowStreaming 地址右上角的 Fork 按钮;git clone [email protected]:xxxxxxx/KnowStreaming.git,该仓库的简写名通常是origin;git remote add upstream https://github.com/didi/KnowStreaming,upstream是主仓库在本地的简写名,可以随意命名,前后保持一致即可;git fetch upstream;git fetch origin;master分支,拉取到本地并命名为github_master:git checkout -b upstream/master;最后,我们来看一下初始化完成之后的大致效果,具体如下图所示:
至此,我们的环境就初始化好了。后续,github_master 分支就是主仓库的master分支,我们可以使用git pull拉取该分支的最新代码,还可以使用git checkout -b xxx拉取我们想要的分支。
在文末评论说明自己要处理该问题即可,具体如下图所示:
本节主要介绍一下处理问题 & 提交解决过程中的分支管理,具体如下图所示:
git checkout github_master;git pull;git checkout -b fix_928;git commit -m "[Optimize]优化xxx问题";git push --set-upstream origin fix_928;GitHub 页面发起 Pull Request 请求,管理员合入主仓库。这部分详细见下一节;代码在提交到 GitHub 分仓库之后,就可以在 GitHub 的网站创建 Pull Request,申请将代码合入主仓库了。 Pull Request 具体见下图所示:
可以不需要将多个commit合并为一个,如果要合并,可以使用 git rebase -i 命令进行解决。