高频使用的 Git 命令
前端桃园
共 3625字,需浏览 8分钟
·
2020-03-13 23:26
作者:CRPER
juejin.im/post/5de8d849e51d455808332166
前言
汇总下我在项目中高频使用的git命令及姿势。
不是入门文档,官方文档肯定比我全面,这里是结合实际业务场景输出。
使用的 Git版本:git version 2.24.0
命令
# 输出概要日志,这条命令等同于
# git log --pretty=oneline --abbrev-commit
git log --oneline
# 指定最近几个提交可以带上 - + 数字
git log --oneline -5
# 提供类似 GUI 工具的 log 展示
git log --graph --date=relative --pretty=tformat:'%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%an %ad)%Creset'
查看日志,常规操作,必备
git status
查看工作区状态的东东,不如GUI直观,但是命令行也有一些用的
git status
git status -s
git status --show-stash
git checkout
用来切换到对应记录的,可以基于分支,提交,标签。
切提交和标签一般用来热修复或者老版本需要加新特性。
git checkout dev
git checkout origin/test
git checkout --track origin/feature-test
git checkout -b testbranch
git checkout -- file
git checkout .
git checkout -
git commit
天天打交道的命令,这里说一些很常见的姿势
git commit --amend --no-edit
git commit --no-verify -m "xxx"
git commit -m "xxx"
git commit -t templateFile
git commit -F
git reset
不得不说,代码回滚中这个命令也是用的很多,而且是 --hard
git reset --hard commit_sha1
git reset --soft commit_sha1
git reset --soft HEAD~1
git reset --mixed commit_sha1
git reset --merge commit_sha1
git reset --keep commit_sha1
git revert
一般用于master 的代码回滚,因为多人在上面协作,
revert
可以平稳的回滚代码,但却保留提交记录,不会让协作的人各种冲突
git revert commit-sha1
git rebase
变基在项目中算是很频繁的,为什么这么说。
比如你开发一个新的 feature, 遵循最小化代码提交的理念。
在整个功能开发完毕的时侯,会有非常多的 commit,用 rebase
可以让我们的commit记录很干净
git rebase -i git-sha1|branch(HEAD)
git rebase --continue
git rebase --skip
git rebase --abort
- pick: 是保留该 commit(采用)
- edit: 一般你提交的东西多了,可以用这个把东东拿回工作区拆分更细的 commit
- reword: 这个可以重新修改你的 commit msg
- squash: 内容保留,把提交信息往上一个 commit 合并进去
- fixup: 保留变动内容,但是抛弃 commit msg
- drop: 用的比较少,无用的改动你会提交么!!!
- 本地提交之前,最好把基准点变为需要合并的分支,这样提交 PR/MR 的时侯就不会冲突(本地来解决冲突)
- 不要在公共分支上变基!!!一变其他协作者基本都一堆冲突!除非你们有很清晰的分支管理机制
git merge
git merge --no-ff branchName
git pull
git pull
中用的最多是带--rebase(-r)
的方式(变基形式拉取合并代码),保持分支一条线。默认的pull
会走ff
模式,多数情况会产生新的commit,部分参数与 merge
提供一致。git push
git push origin localbranch
git push -d origin branchName
git push --tags
git push --follow-tags
git push -f origin branchName
git push --force-with-lease
git remote
git remote add origin url
git remote add github url
git remote set-url origin(或者其他上游域) url
git branch该命令用的最多的就是删除本地分支,重命名分支,删除远程分支了git branch -d branchName
git branch -M oldBranch newNameBranch
git branch --set-upstream-to=origin/xxx
git branch --set-upstream-to origin xxx
git stash
stash
添加描述信息!!!git stash save stashName
git stash -u save stashName
git stash push -m "更改了 xx"
git stash apply stash@{0}
git stash pop stash@{0}
git stash list
git stash clear
git stash drop stash@{0}
git stash show stash@{0}
git reflog
rebase,merge, reset
这些当我们不小心硬回滚的时侯,或变基错了都可以在这里找到行为之前的commit,然后回滚。当然这个时间回溯也只在本地有用,你推送到远程分支的破坏性改动,该凉还是得凉。git reflog -5
git cherry-pick
--continue
git cherry-pick commit-sha1
git cherry-pick master~4 master~2
git cherry-pick startGitSha1..endGitSha1
git rm
git rm --cache -- file
git rm -r --cached .
git add .
git commit -m "xxx"
git rev-parse
git rev-parse --short HEAD --verify
git rev-parse --show-toplevel
git rev-parse --git-dir
git rev-parse --all
git diff
总结
推荐阅读
我的公众号能带来什么价值?(文末有送书规则,一定要看)
每个前端工程师都应该了解的图片知识(长文建议收藏)
为什么现在面试总是面试造火箭?
你点的每个在看,我都认真当成了喜欢。
评论