本文整理了 git常用的一些命令,主要参考了廖雪峰的Git教程,强烈建议有条件的小伙伴可以认真学习廖雪峰Git教程。
git init
git add 文件名 --添加对应的文件
git add . --添加所有的修改文件
git commit -m "提交的备注信息" --提交所有添加的文件
git status
git log --查看所有信息
git log --pretty=oneline --查看的信息汇总到一行
git log 可带参数很多,例如 --graph --pretty=oneline --abbrev-commit
git diff
git diff [commit id]
git diff HEAD -- [文件名]
git reset --hard HEAD^ --回退到上一个版本
git reset --hard HEAD~100 --回退到 100 个版本前
git reset --hard [指定的 commit id] --返回到指定的提交版本,可以是以前的,也可以是以后的
git reflog
可以以此确定当前所在的 commit id 和以前所处的 commit id
git restore --staged [文件名]
git restore [文件名]
git checkout -- [文件名]
命令中 – 很重要,没有加 – ,就变成了切换到同名的分支
git reset HEAD [文件名]
git restore <文件名>
git checkout -- <文件名> //删错了,但是版本库里还有,可以使用 checkout
git add/rm <文件名>
git commit -m "删除信息"
git push <远程库名称> <分支名>
git push -u origin <分支名>
第一次向远程仓库推送分支内容,加入-u 参数,不仅会推送本地分支内容,还会把本地分支和远程分支关联起来,在以后的推送中可以简化命令 git push origin <分知名> ,默认的远程库名称为 origin,也可以自定义,例如一个本地仓库同时关联 gitee 和 github:
git remote add github [email protected]:<github远程注册名>/<远程仓库名>.git
git remote add gitee [email protected]:<gitee远程注册名>/<远程仓库名>.git
git remote -v
gitee [email protected]:<gitee远程注册名>/<远程仓库名>.git (fetch)
gitee [email protected]:<gitee远程注册名>/<远程仓库名>.git (push)
github [email protected]:<github远程注册名>/<远程仓库名>.git (fetch)
github [email protected]:<github远程注册名>/<远程仓库名>.git (push)
git push github master //推送 GitHub master
git push gitee master // 推送 gitee master
git remote
git remote -v
git remote rm <名称>
git remote rm origin //删除本地和远程 origin 的关联
这里删除的是本地库和远程库的绑定联系,并非真正删除远程库的内容,如确实需要远程删除,需要手动登录 GitHub 或者 Gitee,找到仓库,手动删除。
git remote add origin git@server-name:path/repo-name.git
关联一个远程库时必须给远程库指定一个名字,origin是默认习惯命名
git clone <远程仓库地址>
git branch
git branch <分支名>
git checkout <分支名>
git switch <分支名>
git checkout -b <分支名>
git switch -c <分支名>
git merge <分支名>
git branch -d <分支名>
git branch -D <分支名> //强行删除
git merge --abort
合并过程中不能切换分支
不使用 fast forward 会产生一个新的提交,所以加参数-m 表明提交信息
git merge --no-ff -m "提交信息" <分支名>
git stash
git stash list
git stash pop //恢复工作区内容并删除列表
git stash apply //恢复工作区内容,但是列表记录还在
git stash drop //删除 stash list 列表内容
git stash apply stash@{0} //如果 stash 列表中不止一个暂存,stash@{}中可选择恢复哪一个stash
git cherry-pick <commit id>
git branch --set-upstream-to=origin/dev dev
git branch --set-upstream-to <branch-name> origin/<branch-name>
git pull
git checkout -b branch-name origin/branch-name
git rebase
rebase前
rebase 后
当 git进行 rebase 操作后,卡在正在变基阶段,切换分支提示需要先解决当前的索引冲突 you need to resolve your current index first,解决方法
git reset --merge
git 的标签其实对应的是某次提交的 commit id
git tag <标签名>
git tag v1.0
git默认标签打在最新 commit 的 id 上,如要指定某次 commit,可以指定 id
git tag <tag name> <commit id>
git tag v0.9 3165663
还可以有其他参数,创建带有说明的标签,用-a指定标签名,-m指定说明文字
git tag -a <tag name> -m "tag messsage" <commit id>
git tag -a v1.0 -m "version 1.0 released" 3165663
git tag
git show <tag name>
git show v1.0
git tag -d <tag name>
git push origin <tag name>
git push origin --tags
git push origin :refs/tags/<tag name>
–global 表示全局变量,如果不加,那只针对当前的仓库起作用。
repo 等级的配置一般在.git/config 下,global 等级的一般在~/.gitconfig 或者 ~/.config/git/config下
git config --global alias.st status //git st就表示git status
git config --global alias.co checkout //co表示checkout
git config --global alias.ci commit //ci表示commit
git config --global alias.br branch //br表示branch
git config --global alias.lg "log --color --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --abbrev-commit"