Git作为开发者入门第一的工具大家在日常肯定经常使用,但是这里我要分享一些Git的高级用法用来节省你的时间跟头痛。
1. 在Git中搜索
如果你想在存储库中寻找可能早已经被删除的代码,使用以下命令可以在任何提交或分支中搜索代码。
git rev-list --all | xargs git grep -F ''
例如,要搜索字符串"jwt_black_list"在你的git仓库:
$git rev-list --all | xargs git grep -F 'jwt_black_list'
6b8b51184e5ec0efaf145a05241358bf1ac77be7:config/config.go: JwtBlackList int64 `mapstructure:"jwt_black_list" json:"jwt_black_list" yaml:"jwt_black_list"`
6b8b51184e5ec0efaf145a05241358bf1ac77be7:utils/jwt.go: return "jwt_black_list:" + MD5([]byte(tokenStr))
2. 清理本地分支
删除已经从远程存储库中删除的本地分支
git config --global fetch.prune true
删除已合并到 master 分支的所有本地分支
git branch --merged master | grep -v '^\*\| master' | xargs -n 1 git branch -d
3. 计算commit
git rev-list --count branch_name
计算main分支提交的次数
$ git rev-list --count main 128 ? 10:28:12
30
4. 查看另一个分支的文件
通常我们会想要查看存在于另一个分支上的文件的内容。实际上,我们可以在不切换分支或通过 查看git 存储库管理器的情况下做到这一点。
例如,如果您在我们的master分支中有一个文件“newfeature.py”,但我们正在处理我们的dev分支,它已经落后了。我们可以使用以下命令查看这个新文件
$ git show master:newfeature.py
5. 空白提交
如果正在使用 DevOps 管道和 CI/CD,那么很可能在 git 提交上有自动集成。实际上我们可以只使用空白提交,而不用对文档进行小的行更改。
git commit --allow empty -m 'new empty commit'
6. 自动更正拼写错误
我们在使用git命令都会打错命令或者看到这条信息出现在终端上。
git: ‘stats’ is not a git command. See ‘git --help’.
The most similar command is
status
Git 实际上提供了自动更正命令的配置。
git config --global help.autocorrect 1
7. 自动修剪
Git Prune 是一个实用命令,用于清理任何引用都无法访问的孤立 git 对象。任何无法通过标签或分支访问的提交都被定义为不可访问。Git prune 是一个 git 命令,它将清除所有这些对象。当然,很难知道何时需要修剪已删除的对象,因为我们的存储库不会警告我们。通过启用这个 git 配置,我们可以要求 git 对每个 git fetch 和 git pull 执行修剪
$ git config --global fetch.prune true
8. 备份未跟踪的文件
当要删除一些未跟踪的文件时但是怕以后需要这些文件,可以创建这些文件的备份以防万一。
git ls-files --others --exclude-standard -z | xargs -0 tar rvf ~/backup-untracked.zip