git常用用法小结

配置

配置全局用户:

1
2
3
4
5
$ git config --global user.name "Your Name"
$ git config --global user.email "email@example.com"
$ git config --global color.ui true # 开启彩色高亮
$ git config --global core.editor vim # 设置编辑器为vim
$ git config -l # 列举所有配置
git 配置文件路径 ~/.gitconfig
1
2
项目的 git 配置文件路径 project/.git/config
项目配置会覆盖全局配置

配置本地(当前repository)用户:

1
2
$ git config --local user.name "Your Name"
$ git config --local user.email "email@example.com"

删除全局用户配置:

1
2
$ git config --global --unset user.name
$ git config --global --unset user.email

删除本地用户配置:

1
2
$ git config --local --unset user.name
$ git config --local --unset user.email

创建版本库

1
2
3
4
$ mkdir learngit #新建文件夹
$ cd learngit #进入文件夹
$ pwd #显示路径
/Users/admin/learngit

初始化版本库与提交

1
2
3
4
5
6
7
8
$ git init #初始化空版本库
Initialized empty Git repository in /Users/admin/learngit/.git/
$ git add <file> # 将工作文件修改提交到本地暂存区
$ git add . # 将所有修改过的工作文件提交暂存区
$ git commit -m "wrote a readme file" #将暂存区文件提交到当前分支
[master (root-commit) cb926e7] wrote a readme file
1 file changed, 2 insertions(+)
create mode 100644 readme.txt

常用操作

查看、添加、提交、删除、找回,重置修改文件

查看文件

1
2
3
4
5
6
7
8
9
10
$ git show # 显示某次提交的内容
$ git show $id # 显示指定id的内容
$ git diff <file> # 比较当前文件和暂存区文件差异
$ git diff
$ git diff <$id1> <$id2> # 比较两次提交之间的差异
$ git diff <branch1>..<branch2> # 在两个分支之间比较
$ git diff --staged # 比较暂存区和版本库差异
$ git diff --cached # 比较暂存区和版本库差异
$ git diff --stat # 仅仅比较统计信息

查看提交记录

1
2
3
4
5
$ git log
$ git log <file> # 查看该文件每次提交记录
$ git log -p <file> # 查看每次详细修改内容的 diff
$ git log -p -2 # 查看最近两次详细修改内容的 diff
$ git 本地分支管理

查看、切换、创建和删除分支

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
$ git branch # 查看分支
$ git branch -r # 查看远程分支
$ git branch <new_branch> # 创建新的分支
$ git branch -v # 查看各个分支最后提交信息
$ git branch --merged # 查看已经被合并到当前分支的分支
$ git branch --no-merged # 查看尚未被合并到当前分支的分支
$ git branch -d <branch> # 删除某个分支
$ git branch -D <branch> # 强制删除某个分支 (未被合并的分支被删除的时候需要强制)
$ git checkout <branch> # 切换到某个分支
$ git checkout -b <new_branch> # 创建新的分支,并且切换过去
$ git checkout -b <new_branch> <branch> # 基于 branch 创建新的new_branch
$ git checkout $id # 把某次历史提交记录 checkout 出来,但无分支信息,切换到其他分支会自动删除
$ git checkout $id -b <new_branch> # 把某次历史提交记录 checkout 出来,创建成一个分支
$ git checkout -- <file> # 抛弃工作区修改
$ git checkout . # 抛弃工作区修改

分支合并和rebase

1
2
3
$ git merge <branch> # 将 branch 分支合并到当前分支
$ git merge origin/master --no-ff # 不要 Fast-Foward 合并,这样可以生成 merge 提交
$ git rebase master <branch> # 将 master rebase 到 branch,相当于:git checkout <branch> && git rebase master && git checkout master && git merge <branch>

git暂存管理

1
2
3
4
$ git stash # 暂存
$ git stash list # 列所有stash
$ git stash apply # 恢复暂存的内容
$ git stash drop # 删除暂存区

git远程分支管理

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
$ git pull # 抓取远程仓库所有分支更新并合并到本地
$ git pull --no-ff # 抓取远程仓库所有分支更新并合并到本地,不要快进合并
$ git fetch origin # 抓取远程仓库更新
$ git merge origin/master # 将远程主分支合并到本地当前分支
$ git checkout --track origin/branch # 跟踪某个远程分支创建相应的本地分支
$ git checkout -b <local_branch> origin/<remote_branch> # 基于远程分支创建本地分支,功能同上
$ git push # push所有分支
$ git push origin master # 将本地主分支推到远程主分支
$ git push -u origin master # 将本地主分支推到远程(如无远程主分支则创建,用于初始化远程仓库)
$ git push origin <local_branch> # 创建远程分支, origin是远程仓库名
$ git push origin <local_branch>:<remote_branch> # 创建远程分支
$ git push origin :<remote_branch> # 先删除本地分支(git branch -d <branch>),然后再push删除远程分支
$ git rm <file> # 从版本库中删除文件
$ git rm -rf <file> # 强制删除远程仓库中的文件目录
$ git rm <file> --cached # 从版本库中删除文件,但不删除文件
$ git reset <file> # 从暂存区恢复到工作文件
$ git reset -- . # 从暂存区恢复到工作文件
$ git reset --hard # 恢复最近一次提交过的状态,即放弃上次提交后的所有本次修改
$ git reset --hard HEAD^ #回退到上个版本(上一个版本就是HEAD^,上上一个版本就是HEAD^^,当然往上100个版本写100个^比较容易数不过来,所以写成HEAD~100。)

git远程仓库管理

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
$ git remote -v # 查看远程服务器地址和仓库名称
$ git remote show origin # 查看远程服务器仓库状态
$ git remote add origin git@github.com:whuhacker/Unblock-Youku-Firefox.git # 添加远程仓库地址
$ git remote set-url origin git@github.com:whuhacker/Unblock-Youku-Firefox.git # 设置远程仓库地址(用于修改远程仓库地址)
$ git remote rm <repository> # 删除远程仓库
$ git commit <file>
$ git commit .
$ git commit -a # 将 git add, git rm 和 git ci 等操作都合并在一起做
$ git commit -am "some comments"
$ git commit --amend # 修改最后一次提交记录
$ git revert <$id> # 恢复某次提交的状态,恢复动作本身也创建了一次提交对象
$ git revert HEAD # 恢复最后一次提交的状态
$ git status # 查看还问提交但是已经被修改的文件
$ git log # 查看历史版本提交记录
$ git log --pretty=oneline # 查看历史版本提交记录(显示在一行)
$ git reflog # 用来记录每一次执行的命令
$ git merge dev # 合并dev到当前分支
$ git merge --no-ff -m "merge with no-ff" dev # 加上--no-ff参数就可以用普通模式合并,合并后的历史有分支,能看出来曾经做过合并远程仓库
$ ssh-keygen -t rsa -C "youremail@example.com" # 获取管理github仓库的密钥私钥
$ git remote add origin git@github.com:opstrip/opstrip.github.io.git # 关联远程仓库
$ git remote set-url origin git@github.com:opstrip/opstrip.github.io.git # 修改远程仓库
$ git push -u origin master # 推送到远程仓库的master分支
$ git clone git@github.com:opstrip/opstrip.github.io.git # 从远程克隆仓库到本地
$ git push origin branch-name # 把本地提交推送到远程仓库的<branch-name>分支
$ git pull # 获取最新的远程仓库

设置跟踪远程库和本地库

1
2
$ git branch --set-upstream master origin/master
$ git branch --set-upstream develop origin/develop

  • 如果git pull提示“no tracking information”,则说明本地分支和远程分支的链接关系没有创建,用命令git branch –set-upstream branch-name origin/branch-name。
文章目录
  1. 1. 配置
    1. 1.1. 配置全局用户:
    2. 1.2. 配置本地(当前repository)用户:
    3. 1.3. 删除全局用户配置:
    4. 1.4. 删除本地用户配置:
  2. 2. 创建版本库
  3. 3. 初始化版本库与提交
  4. 4. 常用操作
    1. 4.1. 查看文件
    2. 4.2. 查看提交记录
    3. 4.3. 查看、切换、创建和删除分支
    4. 4.4. 分支合并和rebase
    5. 4.5. git暂存管理
    6. 4.6. git远程分支管理
    7. 4.7. git远程仓库管理
    8. 4.8. 设置跟踪远程库和本地库