Git常用个人备份笔记

一、新建代码库

1、在当前目录下创建一个Git代码库

1
git init

创建的.git默认是隐藏的,使用命令ls -ah显示出来。

2、新建一个目录,并初始化为Git的代码库

1
git init [dir-name]

3、克隆一个项目包括其提交历史

1
git clone [url] [local-dir-name]

二、配置

1、显示当前Git配置

1
git config --list

2、设置提交的时候的用户信息

1
2
git config [--global] user.name "username"
git config [--global] user.email "email address"

三、增加删除文件

1、添加指定文件到暂存区

1
git add [file1] [file2] ···

2、添加指定目录到暂存区,包括子目录

1
git add [dir name]

3、将当前目录下的所有文件到暂存区(包括当前目录下的已经修改的文件夹)

1
git add .

4、删除工作区文件,并且将这次删除放入到暂存区

1
git rm [file1] [file2]

从版本库中找回rm的文件

1
git checkout --[file]

5、停止追踪指定文件,但该文件会保留到工作区,文件内容不变。

1
git rm --cached [file]

四、代码提交

1、提交暂存区到版本库

1
git commit -m [message]

2、提交暂存区的指定文件到仓库

1
git commit [file1][file2]··· -m [message]

3、提交工作区自上次commit之后的变化,直接到仓库区

1
git commit -a

4、提交时显示所有的diff信息

1
git commit -v

5、使用一次新的commit,代替上一次提交;如果代码没有变化,就用来改写上一次的commit提交信息。commit的SHA1会发生改变,上一次的提交的内容不会发生改变。

1
git commit --amend -m [meesage]

6、重做上一次的commit,并包括指定文件的新变化(此时不需要讲file1和file2添加到暂存区)

1
git commit --amend [file1] [file2]

五、分支

1、列出所有的分支

1
git branch

2、列出所有的远程分支

1
git branch -r

3、新建一个新的分支,但还是停留在当前的分支。工作区会复用,即在master上面修改的内容还没有提交,那么如果新建了一个分支,并切换过去,master的未提交的内容也会跟着带到新的分支。

1
git branch [branch-name]

4、新建一个分支,并切换到该分支

1
git checkout -b [branch-name]

5、新建一个分支,并指定指向的commit,此时如果工作区不干净,切换可能会出现失败,需要使用git stash 将当前工作区的修改给隐藏掉。

1
git branch [branch-name] [commit id]

6、切换到上一个分支

1
git branch -

7、在当前的分支和指定的远程分支之间建立追踪关系

1
git branch --set-upstream [branch] [remote-branch]

8、合并指定分支到当前分支

1
git merge [branch]

9、删除分支

1
git branch -d [branch-name]

10、删除一个没有被合并过的分支需要使用-D参数:

1
git branch -D [branch-name]

11、删除远程分支

1
git push [origin-name] --d [branch-name]

12、新建一个分支,指向某个tag

1
git checkout -b [branch] [tag]

13、显示分支图

1
git log --graph

14、修改分支名称

1
git banch -m [old-name] [new-name]

15、合并多次commit

1
git rebase -i [commit]

上面的命令表示的是head分支到commit上一个commit的合并,注意不包括该commit。

在弹出的Vim编辑页面输入命令:

Commands:

1
2
3
4
5
6
7
8
9
10
# p, pick <commit> = use commit
# r, reword <commit> = use commit, but edit the commit message
# e, edit <commit> = use commit, but stop for amending
# s, squash <commit> = use commit, but meld into previous commit
# f, fixup <commit> = like "squash", but discard this commit's log message
# x, exec <command> = run command (the rest of the line) using shell
# d, drop <commit> = remove commit
# l, label <label> = label current HEAD with a name
# t, reset <label> = reset HEAD to a label
# m, merge [-C <commit> | -c <commit>] <label> [# <oneline>]

然后wq保存,再弹出一个Vim编辑框,修改commit信息。

16、恢复删除的分支

1
2
git reflog 查看之前的这个已经删除的分支的提交历史
git branch <之前提交的那个分支的名字> <上一步操作查询到sha1>

六、标签

1、列出所有标签

1
git tag

2、新建一个指向当前commit的tag

1
git tag [tag-name]

3、新建一个tag在指定的commit

1
git tag [tag-nam] [commit]

4、删除本地tag

1
git tag -d [tag-name]

5、删除远程tag

1
git push [origin-name]:refs/tags/[tag-name]

6、查看tag信息

1
git show tag

7、提交本地所有tag

1
git push [origin-name] --tags

8、提交指定tag

1
git push [origin-name] [tag]

七、查看信息

1、查看有变更的文件

1
git status

2、显示当前分支的版本历史

1
git log

3、显示commit历史,以及每次commit发生变更的文件

1
git log --stat

4、显示代码差异

1
git diff

暂存区没有文件:比较的是当前工作区和上一次的commit的差别。

暂存区有文件:比较的是当前工作区和暂存区的差别。

5、显示暂存区和上一次commit的差异

1
git diff --cached [file]

6、显示工作区和当前分支的最新commit的差异

1
git diff head

7、显示两次提交之间的差异(commit1 和 commit的顺序需要注意,不一样会导致新增和删除错位)

1
git diff [commit1] [commit2]

8、显示某次提交的元数据的和内容变化

1
git show [commit]

八、远程同步

配置远程仓库:

1
git remote add test http://xxxx@git.XXXX.com/scm/wbqa/xxxx.git

test为远程仓库的别名,后面的htpp为远程仓库地址。
删除远程仓库:

1
git remote rm test

test为别名

1、下载远程仓库的所有变动

1
git fetch [remote]

2、显示所有的远程仓库

1
git remote -v

和git remote的差别

1
2
3
4
5
$ git remote
origin
$ git remote -v
origin https://github.com/DimpleFeng/GitTest.git (fetch)
origin https://github.com/DimpleFeng/GitTest.git (push)

3、取回远程仓库的变化,并和本地分支合并

1
git pull [remote] [branch]

4、上传本地指定分支到远程仓库

1
git push [remote] [branch]

5、强行推送当前分支到远程仓库即使有冲突

1
git push [remote] --force

6、git remote 通常用于查看别人的进行,因为取回的代码对本地没有影响。

1
2
3
git remote add <主机名> <网址> 添加远程主机
git remote rm <主机名> 删除远程主机
git remote rename <原主机名><新主机名>

7、git pull 取回远程主机某个分支的更新,再和本地的分支进行合并。

1
git pull <远程主机名> <远程分支名>:<本地分支名>

取回origin主机的next分支,与本地的master合并

1
git pulll origin next:master

如果远程分支是和当前的分支进行合并,则冒号后面可以省略。

在某些场合,Git会自动在远程分支和本地分支之间创建一个追踪关系,如果当前分支和远程分支存在着追踪关系,就可以省略远程分支名称。

如果当前分支只有一个追踪分支,远程主机名也可以省略。

8、git push 将本地分支的更新,推送到远程主机

1
git push <远程主机名><本地分支名>:<远程分支名>

如果省略远程分支名,表示将本地分支推送给与之存在追踪关系的远程分支,如果该分支不存在会被新建。

如果省略本地分支名,则表示删除指定的远程分支:git push origin :master
如果当前分支和远程分支存在追踪关系,则本地分支和远程分支都可以省略。
如果只存在一个追踪分支,那么主机名可以省略.

如果远程主机的版本比本地的新,那么推送到Git的时候会报错,这个时候可以采用git push –force origin强制覆盖远程主机的版本。

九、撤销

1、恢复暂存区的指定文件到工作区。会丢失提交到暂存区后对该文件的所有操作。

1
git checkout [file]

2、恢复某次commit的指定文件到暂存区和工作区(git处于等待commit状态,同时会丢失在这之前对工作区的修改的内容)

1
git checkout [commit] [file]

3、恢复暂存区所有文件到工作区。会丢失在提交到暂存区之后的对文件的所有修改。

1
git checkout .

4、重置暂存区和工作区,与上一次commit一致

1
git reset --hard

5、重置当前分支的head为指定的commit,同时重置暂存区和工作区,与指定commit一致。

1
git reset --hard [commit]

git reset [file] 将file从暂存区回退到工作区(修改内容不会丢失)

6、将未保存的变化隐藏

1
git stash

弹出

1
git stash pop

7、查看历史命令

1
git reflog
-------------The End-------------

本文标题:Git常用个人备份笔记

文章作者:Dimple

发布时间:2018年08月24日 - 10:08

最后更新:2018年09月28日 - 17:09

原始链接:http://www.bianxiaofeng.com/2018/08/24/2018-8-24-10-00-54/

许可协议: 署名-非商业性使用-禁止演绎 4.0 国际 转载请保留原文链接及作者。

na,给我一个棒棒糖!
0%