工作中常用到的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
21
22
23
24
25
26
27
28
29
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 --author= 'fanfan'   // 按作者筛选
 
git log --name-status -n 5 --grep= 'commit desc'   //按提交描述内容筛选
 
git log --name-status -n 5 -- path/file1 path/file2   //按提交的文件筛选
 
git log --name-status -n 5 -S "hello world"   //按文件内容筛选
 
git log --name-status -n 5 -G "xxx"  //按文件内容筛选(正则匹配)
 
常用的命令:
 
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
5
6
7
8
9
10
11
[Tips]:发生冲突时,你可以手工将需要合并的这个分支/版本merge到自己的分支上,解决冲突后提交,可避免此情况的发生.
[Tips]:你可以根据如下步骤解决冲突:
1、git fetch
2、git checkout releases/xxx (注:如本地还未检出过发布分支,请执行 git checkout -b releases/xxx origin/releases/xxx)
3、git pull
4、使用版本号合并,将出现的冲突一一解决
    git merge --no-ff b109eff1348a2fcf9a793deb81f3981d691e453c
5、git status 查看冲突,并按命令提示进行修复
6、git add xxx 
    git commit xxx
7、git push origin releases/xx

十、其他

1
2
3
4
5
6
7
8
9
10
$ git fetch <远程主机名> <分支名>
 
git fetch origin master
取回origin主机的master分支
 
 
git checkout . #本地所有修改的。没有的提交的,都返回到原来的状态
git stash #把所有没有提交的修改暂存到stash里面。可用git stash pop回复。
git reset --hard HASH #返回到某个节点,不保留修改。
git reset --soft HASH #返回到某个节点。保留修改

十一、参考资料

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
  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值