背景
公司使用git作为代码的版本控制工具,快速迭代开发就会涉及到代码的分支创建,分支合并,标签管理和分支删除操作。
项目一开始是单体应用,使用idea提供的git管理工具就可以轻松完成上面的代码管理了。
但随着业务量的增加,单体应用变为前后端分离,再到后面改成微服务架构。要管理的项目数增长飞速,每半年就产出一个新的项目。还是使用idea提供的git管理工具进行项目管理,十分浪费时间。
其实git工具提供了丰富的命令,将这些命令组合起来成脚本。执行脚本,电脑在工作,自己在摸鱼,美滋滋!
下面分享下我在工作中用的到git脚本。
分支创建
新建文件branch.bat ,复制如下命令
@echo off
D:
cd D:\project\%~1
git fetch
git switch %~2
git pull origin %~2
git branch %~3
git push origin %~3
echo ::::::::::::
echo ::::::::::::branch project: %~1 base %~2 to %~3 ,push origin/%~3
echo ::::::::::::
echo.
echo.
eg:branch.bat doc master v1.1.0
-
参数含义:
-
doc:要操作的项目 -
master:基于master分支创建新分支 -
v1.1.0:新分支名称
分支合并
新建文件merge.bat ,复制如下命令
@echo off
D:
cd D:\project\%~1
git fetch
git switch %~3
git pull origin %~3
git merge origin/%~2
git push origin %~3:%~3
echo ::::::::::::
echo ::::::::::::merge project: %~1 merge from %~2 to %~3 ,push origin/%~3
echo ::::::::::::
echo.
echo.
eg:merge.bat doc v1.1.0 master
-
参数含义:
-
doc:要操作项目 -
v1.1.0:源分支(要合并代码的分支) -
master:目标分支(合并到哪个位置的分支)
标签管理
新建文件tag.bat ,复制如下命令
@echo off
D:
cd D:\project\%~1
git fetch
git switch %~3
git pull origin %~3
git merge origin/%~2
git push origin %~3:%~3
git tag %~4
git push origin %~4
echo ::::::::::::
echo ::::::::::::tag project: %~1 merge from %~2 to %~3 ,push origin/%~3 , tag origin/%~3 : %~4
echo ::::::::::::
echo.
echo.
eg:tag.bat doc v1.1.0 master tag_v1.1.0
-
参数含义:
-
doc:要操作项目 -
v1.1.0:源分支(要合并代码的分支) -
master:目标分支(合并到哪个位置的分支) -
tag_v1.1.0:对目标分支打标签
注意:tag.bat脚本会先把源分支代码合并到目标分支,再对目标分支打标签。
分支删除
新建文件delete.bat ,复制如下命令
@echo off
SetLocal EnableDelayEdexpansion
D:
cd D:\project\%~1
git fetch
git switch master
git pull origin master
echo project %~1(%~2) delete branch list:
git branch -r | find "%~2"
for /f %%a in ('git branch -r ^| find "%~2"') do (
set old=%%a
set bname=!old:origin/=!
git branch -D !bname!
git push --delete origin !bname!
echo ::::::::::::
echo :::::::::::: project: %~1 delete !bname! and origin/!bname!
echo ::::::::::::
echo.
echo.
)
eg:delete.bat doc v1
-
参数含义:
-
doc:要操作项目 -
v1:匹配分支名称开头是v1的分支
注意:delete.bat脚本是一个批量删除操作,会删除分支名称开头是指定字符串的远程分支和本地分支,谨慎操作。
关注公众号:java编程秀,获取更多Java最新资讯
|