git init
初始化一个Git仓库
git add <file>
添加文件到Git仓库
git commit -m <message>
把文件提交到Git仓库
git status
查看工作区的状态
git diff
查看修改内容
git reset --hard commit_id
版本回退
git log
可以查看提交历史,以便确定要回退到哪个版本
git reflog
查看命令历史,以便确定要回到未来的哪个版本
git checkout -- file
可以丢弃工作区的修改,命令中的--很重要,没有--,就变成了“切换到另一个分支”的命令
git reset HEAD <file>
可以把暂存区的修改撤销掉,重新放回工作区
git rm
用于删除一个文件
git remote add origin git@server-name:path/repo-name.git
关联远程库
git push -u origin master
第一次推送master分支的所有内容
git push origin master
推送最新修改
git clone
克隆仓库
git branch
查看分支
git branch <name>
创建分支
git checkout <name>或者git switch <name>
切换分支
git checkout -b <name>或者git switch -c <name>
创建+切换分支
git merge <name>
合并某分支到当前分支
git branch -d <name>
删除分支
git remote -v
查看远程库信息
git push origin branch-name
从本地推送分支
git checkout -b branch-name origin/branch-name
在本地创建和远程分支对应的分支
git branch --set-upstream branch-name origin/branch-name
建立本地分支和远程分支的关联
git pull
从远程抓取分支
git log --graph
可以看到分支合并图
git merge --no-ff -m "merge with no-ff" dev
--no-ff参数,表示禁用Fast forward
合并分支时,加上--no-ff参数就可以用普通模式合并,合并后的历史有分支,能看出来曾经做过合并,而fast forward合并就看不出来曾经做过合并。
git stash
把当前工作现场“储藏”起来,等以后恢复现场后继续工作
git stash list
查看工作现场
git stash pop
恢复工作现场
git branch -D <name>
强行删除分支
git rebase
可以把本地未push的分叉提交历史整理成直线
git tag <name>
打新标签
git tag -a <tagname> -m "blablabla..."
可以指定标签信息
git tag
查看所有标签
git branch
查看所有分支
git show <tagname>
查看标签信息
git push origin <tagname>
推送某个标签到远程
git push origin --tags
一次性推送全部尚未推送到远程的本地标签
git tag -d <tagname>
删除一个本地标签
git push origin :refs/tags/<tagname>
git push origin :refs/tags/v0.9
远程删除标签,注意要先从本地删除