背景
目前公司的项目分支管理:
- 每次新的需求,都从master分支来拉取新的分支,
命名规则:
feature/年月日-项目简称-开发者。
例如:
feature/20220401-goods-sku-dushan
- 紧急bug的修复,从master分支,拉取新的分支,进行bug的定位和修复
命名规则:
hotfix/年月日-项目简称-开发者
例如:
hotfix/20220405-goods-import-dushan
- 合并代码规则
每次将自己的分支合并到dev或者test分支,进行开发和测试,测试通过后, 准备发布预发环境或者正式环境。 将master分支回合自己的分支,然后启动无误后,将自己的分支合并master分支,打上标签后,准备进行发布。
分支和tag数目过多
按照如上规则进行项目开发后,随着时间的发展,项目中的分支和标签数目急剧增长。并且之前管理者,认为项目的分支和tag应该保持半年以上,这个就没有道理,每次有问题也是拉取新的分支,那么之前的分支留着毫无用处。
批量删除标签
- 查看已有tag列表
git tag -l
2. 根据正则表达式筛选dev的标签
git tag -l | awk '/dev_20220[1-5]/{print}'
3. 根据正则表达式筛选正式环境的标签
git tag -l | awk '/master_20220[1-5]/{print}'
- 批量删除标签
按照上面的正则表达式,删除标签
git push origin --delete tag $(git tag -l |awk '/dev_20220[1-5]/{print}')
网上还有另一个命令,通过xargx,但是我没有测试成功
没能成功
git tag -l | awk '/dev_2022[1-5]/{print}' | xargs git push origin --delete tag
下图,可以看出远程仓库的dev标签已经删除,本地还存在。
- 删除本地分支
远程仓库的分支已删除,按照同样的语法,删除本地分支
git tag -l |xargs git tag -d
批量删除分支
同样的原理
- 按照正则表达式,搜索符合命名规则的分支
如下,是hotfix的分支
git branch --all | awk '/\/hotfix\/20220[1-5]/{print}'
总的分支如下: 查询的hotfix分支如下:
- 批量删除分支—失败
原计划使用以下语句,但是始终提示:remote ref does not exist
git branch --all | awk '/\/hotfix\/20220[1-5]/{print}'| xargs git push origin --delete
---报错信息
error: unable to delete 'remotes/origin/hotfix/20220319_qqwe_dushan': remote ref does not exist
error: unable to delete 'remotes/origin/hotfix/20220401_qqq_dushan': remote ref does not exist
但是使用命令却可以查找到分支,问题其实在与,下面的命令查找分支的时候是没有remotes/origin/的。所以每次删除都提示找不到这个分支
git branch --all| awk '/\/hotfix\/20220[1-5]/{print}'
- 批量删除分支—成功
使用如下命令进行分支的拆分,效果如图
git branch -r | awk -F/ '/\/hotfix\/20220[1-5]/{print $2"/"$3}'
使用命令,进行分支的批量删除
git branch -r | awk -F/ '/\/hotfix\/20220[1-5]/{print $2"/"$3}'| xargs -I % git push origin --delete %
同理,批量删除feature分支
git branch -r | awk -F/ '/\/feature\/20220[1-5]/{print $2"/"$3}'| xargs -I % git push origin --delete %
最终结果如下,实现批量删除功能
强迫症表示,真的清爽了很多。
|