git 命令(非常全)

来源:互联网 发布:final cut 7 for mac 编辑:程序博客网 时间:2024/05/29 08:14

git 命令(非常全)


一、前言

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

  [

  顺便问下园友们,怎么感觉博客园发布的博客搜索有时都搜不到,后台编辑能填的都填写了,还是觉得搜索排名不高?

  相同的标题搜索到的都是被抓取工具抓取的另一个平台下的文章了...

  ]

  还是先贴张图(此图来自阮大神的blog)

  

二、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 clone ssh://example.com/path/to/repo.git/
$ git clone git://example.com/path/to/repo.git/
$ git clone /opt/git/project.git
$ git clone file:///opt/git/project.git
$ git clone ftp[s]://example.com/path/to/repo.git/
$ git clone rsync://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 remote rm <主机名>  //删除远程主机
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     // 保存工作现场
 
do some 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 stash clear // 情况 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分支

十、参考资料

1
2
3
http://www.ruanyifeng.com/blog/2014/06/git_remote.html
http://gitbook.liuhui998.com/4_2.html
http://www.tuicool.com/articles/A3Mn6f
0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 痔疮内扎手术后直肠窄小怎么办 2个月大的宝宝鼻塞怎么办 宝宝鼻屎比较深怎么办 来例假痔疮犯了怎么办 微医爽约过一次怎么办 炸完的薯条软了怎么办 学信网号码换了怎么办 学信网注册换手机了怎么办 学信网手机号码已被注册怎么办 学信网手机号码被注册了怎么办 去英国留学不会做饭怎么办 小米陶瓷刀钝了怎么办 橱柜的缝擦不到怎么办 悠悠球上油早了怎么办 买了没有esp的车怎么办 饥荒海难狗来了怎么办 饥荒海难拖网掉水里了怎么办 饥荒遇到了猪人怎么办 饥荒龙蝇赖在家不走怎么办 饥荒海难崩档了怎么办 gta5全是rpf文件怎么办 饥荒没有海象人营地怎么办 饥荒海滩猎犬来了怎么办 宝宝换牙门牙上长颗尖牙怎么办 肉卡在牙缝里怎么办 电脑做系统卡死怎么办 苹果6升级太卡怎么办 电脑玩不了联机饥荒怎么办 饥荒渡渡鸟死了一只怎么办 饥荒电脑联机植物生病怎么办 开车蹭到别人车怎么办 立定跳不会收腹怎么办 1岁宝宝有蛔虫怎么办 手机屏幕总是有网页跳出来怎么办 cs游戏屏幕变成正方形怎么办 大王卡被收回了怎么办 模拟人生4小人生病了怎么办 创造与魔法死后怎么办? 脚不小心扭伤了该怎么办 小鸡脚扭伤了该怎么办 跳高比赛最终成绩相等怎么办