Git 常用技能总结

分享于2021年05月10日
使用 Git 偶尔碰到一些生僻的技能,总是需要去 Google,第二次用时又忘了。所以这是一篇我自认为比较重要的 Git 技能表,主要供自己查阅使用,反复查阅能够加深印象,提升技能熟练度。如果你是还不知道 Git 是什么,建议先阅读 廖雪峰的Git教程。- 工作流 -Git 最核心的一个概念就是工作流。工作区(Workspace)是电脑中实际的目录;暂存区(Index)像个缓存区域,临时保存你的改动;最后是版本库(Repository),分为本地仓库和远程仓库。下图真是一图胜千言啊,就无耻盗图了。- 远程仓库 - 添加远程仓库git remote add origin git@server-name:path/repo-name.git #添加一个远程库查看远程仓库git remote #要查看远程库的信息git remote -v #显示更详细的信息推送分支git push origin master #推送到远程master分支抓取分支git clone git@server-name:path/repo-name.git #克隆远程仓库到本地(能看到master分支)git checkout -b dev origin/dev #创建远程origin的dev分支到本地,并命名为devgit checkout origin/dev --track #与上面效果一样git pull origin master #从远程分支进行更新 git fetch origin master #获取远程分支上的数据抓取GitHub上某个pull request到本地git fetch origin pull/ID/head:BRANCHNAMEgit checkout BRANCHNAME$ git branch --set-upstream branch-name origin/branch-name,可以建立起本地分支和远程分支的关联,之后可以直接git pull从远程抓取分支。另外,git pull = git fetch + merge to local删除远程分支$ git push origin --delete bugfixTo https://github.com/wuchong/jacman - [deleted] bugfix# 或者直接push一个空分支$ git push origin :bugfixTo https://github.com/wuchong/jacman - [deleted] bugfix更新远程分支信息项目往前推进的过程中,远程仓库上经常会增加一些分支、删除一些分支。所以有时需要与远程同步下分支信息。git fetch -p-p就是修剪的意思。它在fetch之后删除掉没有与远程分支对应的本地分支,并且同步一些远程新创建的分支和tag。- 历史管理 -查看历史git log --pretty=oneline filename #一行显示git log -p -2 #显示最近2次提交内容的差异git show cb926e7 #查看某次修改版本回退git reset --hard HEAD^ #回退到上一个版本git reset --hard cb926e7 #回退到具体某个版git reflog #查看命令历史,常用于帮助找回丢失掉的commit用HEAD表示当前版本,上一个版本就是HEAD^,上上一个版本就是HEAD^^,HEAD~100就是上100个版本。管理修改git status #查看工作区、暂存区的状态git checkout -- #丢弃工作区上某个文件的修改git reset HEAD #丢弃暂存区上某个文件的修改,重新放回工作区查看差异git diff #查看未暂存的文件更新 git diff --cached #查看已暂存文件的更新 git diff HEAD -- readme.txt #查看工作区和版本库里面最新版本的区别git diff #在合并改动之前,预览两个分支的差异使用内建的图形化git:gitk,可以更方便清晰地查看差异。当然 Github 客户端也不错。删除文件git rm #直接删除文件git rm --cached #删除文件暂存状态储藏和恢复git stash #储藏当前工作git stash list #查看储藏的工作现场git stash apply #恢复工作现场,stash内容并不删除git stash pop #恢复工作现场,并删除stash内容- 分支管理 -创建分支git branch develop #只创建分支git checkout -b master develop #创建并切换到 develop 分支合并分支git checkout master #切换到主分支git merge --no-ff develop #把 develop 合并到 master 分支,no-ff 选项的作用是保留原分支记录git branch -d develop #删除 develop 分支- 标签 -显示标签git tag #列出现有标签 git show #显示标签信息###创建标签git tag v0.1 #新建标签,默认位 HEADgit tag v0.1 cb926e7 #对指定的 commit id 打标签git tag -a v0.1 -m 'version 0.1 released' #新建带注释标签操作标签git checkout #切换到标签git push origin #推送分支到源上git push origin --tags #一次性推送全部尚未推送到远程的本地标签git tag -d #删除标签git push origin :refs/tags/ #删除远程标签- Git 设置 -设置 commit 的用户和邮箱git config user.name \"xx\" #设置 commit 的用户git config user.email \"xx@xx.com\" #设置 commit 的邮箱git commit --amend --author \"Jark Wu \" #修改上次提交的用户信息git config format.pretty oneline #显示历史记录时,每个提交的信息只显示一行- END -往期回顾◆如何优雅扩缩容,一致性哈希算法◆华为云物联网四年配置中心实践◆Apache Pulsar 对现代数据堆栈至关重要的几个原因