git init 初始化
git add 文件名
git clone 克隆分支
cat ~/.gitconfig 查看git配置
git config --global user.name "123" 设置用户名
git config --global user.email "123@qq.com" 设置email
git config --global core.editor vim 设置写注释时候的编辑器,用vim可以实现输入多行注释
git config --global alias.ci "commit -a -v" 设置命令别名
git config --system alias.st status
git config --system alias.ci commit
git config --system alias.co checkout
git config --system alias.br branch
git br new_branch 新建新分支
git co new_branch 切换到分支
git co -b new_branch 新建分支并切换到新分支
git push origin new_branch 把本地分支提交到远程
git br -a 查看远程分支
git br 查看本地分支
git br -d new_branch 删除本地分支
git push origin :new_branch 冒号前面的空格不能少,原理是把一个空分支push到server上,相当于删除该分支。
git checkout (master分支名称) -- base.txt 还原文件内容(未添加到stage),类似SVN还原,即 svn revert base.txt
git reset HEAD base.txt 还原文件内容(已添加到stage)
git reset --hard e81aff0 版本回退到e81aff0
$ git reset --hard dc2735bffdea2f04df0dd25185df011867c13a23HEAD is now at dc2735b emoji
git reflog 查看git操作历史命令和commit id,如下是个例子
11b5054 (HEAD -> master) HEAD@{0}: reset: moving to 11b5054cede37314ca7cf6bd696b550b07736814dc2735b (origin/master) HEAD@{1}: reset: moving to dc2735bffdea2f04df0dd25185df011867c13a2311b5054 (HEAD -> master) HEAD@{2}: commit: v2e81aff0 HEAD@{3}: commit: svnv1dc2735b (origin/master) HEAD@{4}: commit: emoji
git log 查看git提交历史版本
git log --pretty=online 显示内容位于一行内