关于Git

转载 2015年11月17日 16:20:59

一、前言

  记录一下工作中常用到的git命令,只是简单的笔记,欢迎大家交流…

二、git branch 和 git checkout

1
2
3
4
5
6
7
8
9
10
11
12
git branch//查看当前分支
git branch -r//列出远程分支
git branch -a//列出所有分支
 
git branch branchName//创建分支
git checkout branchName//切换分支
git checkout -b branchName//创建并切换到分支
 
git checkout //后面不跟任何参数,则就是对工作区进行检查
git checkout –filename//从暂存区中恢复文件(确保filename与branch名称不同)
 
git status//查看状态

三、git clone 和 git remote

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
git clone <版本库的网址> <本地目录名>
git clone支持多种协议,除了HTTP(s)以外,还支持SSH、Git、本地文件协议等,下面是一些例子。
 
$ git clone http[s]://example.com/path/to/repo.git/
$ git clonessh://example.com/path/to/repo.git/
$ git clone git://example.com/path/to/repo.git/
$ git clone/opt/git/project.git
$ git clonefile:///opt/git/project.git
$ git cloneftp[s]://example.com/path/to/repo.git/
$ git clonersync://example.com/path/to/repo.git/
 
SSH协议还有另一种写法
$ git clone [user@]example.com:path/to/repo.git/
 
=========================================
 
git remote
git remote -v //查看远程主机的网址
git remote show <主机名>//查看该主机的详细信息
git remote add <主机名> <网址>//添加远程主机
git remoterm<主机名> //删除远程主机
git remote rename <原主机名> <新主机名>//重命名远程主机

四、git pull 和 git push

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
31
32
33
34
$ git pull <远程主机名> <远程分支名>:<本地分支名>
$ git push <远程主机名> <本地分支名>:<远程分支名>
                         from         to
 
git pull origin master:master
取回origin主机的master分支,与本地的master分支合并
 
git push origin master:master
推送本地的master分支,与origin主机的master分支合并
 
 
 
git pull origin master
如果远程分支是与当前分支合并,则冒号后面的部分可以省略。
 
git push origin master
本地的master分支推送到origin主机的master分支。如果后者不存在,则会被新建
 
 
 
git pull origin
本地的当前分支自动与对应的origin主机”追踪分支”(remote-tracking branch)进行合并。
追踪分支 是 远程的同名分支
 
git push origin
当前分支与远程分支之间存在追踪关系,则本地分支和远程分支都可以省略
 
 
 
git pull
当前分支自动与唯一一个追踪分支进行合并
 
git push
当前分支只有一个追踪分支,那么主机名都可以省略

五、git merge 和 git rebase

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
git merge
用”pull”命令把”origin”分支上的修改拉下来并且和你的修改合并;
结果看起来就像一个新的”合并的提交”(merge commit):
 
 
//使用 rebase 合并
$ git checkout mywork
$ git rebase origin
这些命令会把你的”mywork”分支里的每个提交(commit)取消掉,
并且把它们临时 保存为补丁(patch)(这些补丁放到”.git/rebase”目录中),
然后把”mywork”分支更新 到最新的”origin”分支,
最后把保存的这些补丁应用到”mywork”分支上
 
 
在rebase的过程中,也许会出现冲突(conflict). 在这种情况,
Git会停止rebase并会让你去解决 冲突;在解决完冲突后,
用”git-add”命令去更新这些内容的索引(index), 然后,你无需执行 git-commit,只要执行:
 
$ git rebase –continue
这样git会继续应用(apply)余下的补丁。
 
在任何时候,你可以用–abort参数来终止rebase的行动,并且”mywork”分支会回到rebase开始前的状态。
$ git rebase –abort

六、git log

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
git log –stat -n 5  //简单的列出了修改过的文件
 
git log -p  -n 5 //详细的列出修改过的文件,及提交文件的对比
 
git log –graph//ASCII 字符串表示的简单图形,形象地展示了每个提交所在的分支及其分化衍合情况
git log –all –decorate –graph
 
git log –pretty=oneline//只显示哈希值和提交说明
 
git log –pretty=oneline/short/full/fuller/format:””(格式等)
 
git log –name-only //仅在提交信息后显示已修改的文件清单
 
git log –no-merges//不显示merge的log
 
 
常用的命令:
 
git log –name-status -n 5 –no-merges path/filename//显示新增、修改、删除的文件清单(不包含merge的log)
git log –name-status –skip=5 -n 5 –no-merges path/filename//略过5条,从第6条开始取5条log

七、git stash

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
保存工作现场
 
git stash    //保存工作现场
 
dosome work
 
git pop//返回工作现场
 
 
 
git stash list//查看 stash 队列
 
git stash pop stash@{num} 
//num就是list中要恢复的工作现场编号
//使用pop命令恢复的工作现场,其对应的stash 在队列中删除
 
git stash apply stash@{num}
//num就是list中要恢复的工作现场编号
//使用apply命令恢复的工作现场,其对应的stash 在队列中不删除
 
 
git stashclear//情况 stash 队列

八、分支合并

1
2
3
4
5
6
7
8
9
分支合并:
 
1.保持工作目录 clean
2.git checkout master //切换到主干
3.git merge subscribeQY //在主干上合并分支
4.如果有冲突就解决一下
 
master push前,在分支上merge master
然后,在master上,merge 分支,在 push

九、其他

1
2
3
4
$ git fetch <远程主机名> <分支名>
 
git fetch origin master
取回origin主机的master分支

当git上只做文件大小写重命名的修改时,如何躲坑...

git对文件名的大小写默认是不敏感的,因此有些朋友在进行了仅涉及大小写的重命名的时候,会遇到提交或更新的问题,本文教你如何躲坑...本文内容基于我电脑上的测试下结论,如有其它情况,请留言,谢谢。...
  • get_set
  • get_set
  • 2016年03月30日 18:45
  • 9938

git checkout -f实例|Git打包压缩方法

像android一样的源码,一个源码就有10G,如果要想发送或者刻录,这么大的代码很难传输。因此,可以这样做: 1.把工作目录下的.git复制一份。 2.压缩这个.git文件夹。linux中可以tar...
  • xzongyuan
  • xzongyuan
  • 2013年09月11日 17:46
  • 5863

git基础学习(二):对修改的文件进行提交 git diff 和 git status

我们已经成功地添加并提交了一个readme.txt文件,现在,是时候继续工作了,于是,我们继续修改readme.txt文件,改成如下内容: Git is a distributed version ...
  • xiaoshan812613234
  • xiaoshan812613234
  • 2014年04月30日 11:20
  • 1632

win10下乌龟git安装和使用

一、安装git for windows 首先下载git for windows客户端http://msysgit.github.io/  安装过程没什么特别的,不停next就ok了         ...
  • jdsjlzx
  • jdsjlzx
  • 2016年04月08日 17:55
  • 22021

Git 撤销合并

Git 的 revert 命令可以用来撤销提交(commit),对于常规的提交来说,revert 命令十分直观易用,相当于做一次被 revert 的提交的「反操作」并形成一个新的 commit,但是当...
  • sndamhming
  • sndamhming
  • 2017年02月20日 13:31
  • 856

学习搭建Git服务器和多人协作开发

一,搭建Git服务器>>>>>>>>>>>>>>>>> 环境基于Ubuntu-12.04 项目服务器管理员:              用户添加及ssh RSA登录(免密登录)          ...
  • nan2ziyou
  • nan2ziyou
  • 2016年03月27日 13:35
  • 1284

windows环境 - 手把手教你使用Git

Git是分布式版本控制系统,那么它就没有中央服务器的,每个人的电脑就是一个完整的版本库,这样,工作的时候就不 需要联网了,因为版本都是在自己的电脑上。既然每个人的电脑都有一个完整的版本库,那多个人如何...
  • u012246458
  • u012246458
  • 2015年08月18日 10:48
  • 9767

git创建仓库,并提交代码(第一次创建并提交)

一直想学GIT,一直不曾学会。主要是GUI界面的很少,命令行大多记不住。今天尝试提交代码,按GIT上给的方法,没料到既然提交成功了。 于是把它记下来,方便以后学习。 代码是学习用的,没多大意义; ...
  • kazeik
  • kazeik
  • 2013年06月17日 17:21
  • 96464

git 分支使用

最近在公司使用git,由于之前接触不深,看了如下文章,感觉不错,分享如下: 转自 http://www.zhihu.com/question/21995370 另:http://www.liaox...
  • nothingl3
  • nothingl3
  • 2015年08月07日 12:26
  • 900

Eclipse与Git结合使用

在Eclipse下安装使用EGit
  • Geurney
  • Geurney
  • 2015年09月07日 03:33
  • 2846
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:关于Git
举报原因:
原因补充:

(最多只允许输入30个字)