git 工具的用法

这是个人经验的一点总结 仅供参考
一、新建代码库

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

git init

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

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

git init [dir-name]

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

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

二、配置

1、显示当前Git配置

git config --list

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

git config [–global] user.name “username”

git config [–global] user.email “email address”

三、增加删除文件

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

git add [file1] [file2] ···

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

git add [dir name]

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

git add .

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

git rm [file1] [file2]

从版本库中找回rm的文件

git checkout --[file]

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

git rm --cached [file]

四、代码提交

1、提交暂存区到版本库

git commit -m [message]

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

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

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

git commit -a

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

git commit -v

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

git commit --amend -m [meesage]

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

git commit --amend [file1] [file2]

五、分支

1、列出所有的分支

git branch

2、列出所有的远程分支

git branch -r

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

git branch [branch-name]

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

git checkout -b [branch-name]

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

git branch [branch-name] [commit id]

6、切换到上一个分支

git branch -

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

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

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

git merge [branch]

9、删除分支

git branch -d [branch-name]

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

git branch -D [branch-name]

11、删除远程分支

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

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

git checkout -b [branch] [tag]

13、显示分支图

git log --graph

14、修改分支名称

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

15、合并多次commit

git rebase -i [commit]

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

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

Commands:

p, pick = use commit

r, reword = use commit, but edit the commit message

s, squash = use commit, but meld into previous commit

f, fixup = like “squash”, but discard this commit’s log message

x, exec = run command (the rest of the line) using shell

d, drop = remove commit

l, label = label current HEAD with a name

t, reset = reset HEAD to a label

m, merge [-C | -c ] [# ]

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

16、恢复删除的分支

git reflog 查看之前的这个已经删除的分支的提交历史

git branch

六、标签

1、列出所有标签

git tag

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

git tag [tag-name]

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

git tag [tag-nam] [commit]

4、删除本地tag

git tag -d [tag-name]

5、删除远程tag

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

6、查看tag信息

git show tag

7、提交本地所有tag

git push [origin-name] --tags

8、提交指定tag

git push [origin-name] [tag]

七、查看信息

1、查看有变更的文件

git status

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

git log

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

git log --stat

4、显示代码差异

git diff

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

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

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

git diff --cached [file]

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

git diff head

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

git diff [commit1] [commit2]

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

git show [commit]

八、远程同步

配置远程仓库:

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

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

删除远程仓库:

git remote rm test

test为别名

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

git fetch [remote]

2、显示所有的远程仓库

git remote -v

和git remote的差别

$ git remote

origin

$ git remote -v

origin https://github.com/DimpleFeng/GitTest.git (fetch)

origin https://github.com/DimpleFeng/GitTest.git (push)

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

git pull [remote] [branch]

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

git push [remote] [branch]

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

git push [remote] --force

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

git remote add 添加远程主机

git remote rm 删除远程主机

git remote rename

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

git pull :

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

git pulll origin next:master

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

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

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

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

git push :

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

如果省略本地分支名,则表示删除指定的远程分支:git push origin :master

如果当前分支和远程分支存在追踪关系,则本地分支和远程分支都可以省略。

如果只存在一个追踪分支,那么主机名可以省略.

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

九、撤销

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

git checkout [file]

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

git checkout [commit] [file]

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

git checkout .

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

git reset --hard

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

git reset --hard [commit]

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

6、将未保存的变化隐藏

git stash

弹出

git stash pop

7、查看历史命令

git reflog

技术交流群:
在这里插入图片描述

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值