Chinaunix首页 | 论坛 | 博客
  • 博客访问: 550303
  • 博文数量: 66
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 1810
  • 用 户 组: 普通用户
  • 注册时间: 2013-07-23 13:53
个人简介

linux

文章分类

全部博文(66)

文章存档

2016年(1)

2015年(14)

2014年(32)

2013年(19)

分类: LINUX

2014-07-22 11:08:56

1 git

参考资源

  • Git-Fast Version Control System.  
  • Git 简易指南. 
  • Git Tutorial.
  • Pro Git. 
  • Git Manual Page.
  • 图解Git.http://blog.jobbole.com/22647
  • Git Reference. 

1.1 git repo

git分为远程仓库和本地仓库。可以从不同的远程仓库拉下内容到本地仓库,并且也可以推送本地仓库到不同的远程仓库去。 可以通过git remote add origin 来为仓库建立别名。在pull或者是push的时候就 可以指定远程仓库。

1.1.1 local

git本地仓库由下面三棵树构成:

  • 工作目录(working directory/WD).我们实际持有的文件。分为untracked和tracked两类。
  • 缓存区(index/stage,INDEX).临时保存我们所做的修改。
  • HEAD.指向我们最后一次提交的结果。

整个变化过程是这样的:WD -> "git add" -> INDEX -> "git commit" -> HEAD

  • git init 初始化本地git仓库
  • git clone 克隆到本地git仓库
  • git add 将WD放入INDEX(不管是tracked还是untracked)
  • git commit 将INDEX放入HEAD
  • git commit -a 将WD放入INDEX和HEAD(对于已经tracked的文件)
  • git commit –amend 修改最后一次提交
  • git checkout – 放弃本地修改,将INDEX移到WD
  • git checkout HEAD – 放弃本地修改,HEAD移到INDEX和WD
  • git diff WD和INDEX差别
  • git diff –cached INDEX和HEAD差别
  • git diff > {patch} / git apply [-R] {patch} # 制作patch以及应用patch. -R可以撤销patch.
  • git reset HEAD 保留本地修改,取消INDEX
  • git reset –hard # 回退到某个commit-id,包括commit/index信息.
  • git reset –soft # 回退到某个commit-id,只是commit不包括index.
    • note(dirlt):commit-id只能是本地commit. 可以使用HEAD^1这样类似游标方式
  • git rm 从HEAD删除
  • git rm –cached 从INDEX删除
  • git mv 重命名文件
  • git log 察看日志

1.1.2 remote

  • git remote -v 显示远程仓库信息(本地信息)
  • git remote add 添加远程仓库
  • git remote show 显示远程仓库信息(远程信息)
  • git remote rename
  • git remote rm 删除某个远程仓库

1.2 git branch

默认来说git包含一个master分支,也可以很容易地创建和删除分支。当从远程clone到本地的时候, 会将远程repo里面所有的分支内容全部clone到本地,维护所有版本信息以及历史文件,所以本地切换分支非常快。

  • git checkout 切换分支
  • git checkout -b 创建并且切换分支,可以指定这个branch以哪个commit-id为起点
  • git branch -va 察看当前所有分支包括本地和远程
  • git branch 创建分支
  • git branch -d 删除分支 / -D 强制删除分支
  • git push 将本地branch HEAD信息推送到远程repo的branch.
  • git push -f # 如果本地某个commit已经提交到server, 但是想修改这个commit并且重新push, 可以使用在这个命令 note(dirlt):not recommended
  • git push : 将删除分支信息推送。 note(dirlt):这个可以这样理解,:之前表示null,将null推到branch相当于清空x。
  • git pull [] 将远程repo合并到本地HEAD.
  • git merge 将本地branch进行合并
    • –no-ff 将多个commit合并成为一个commit(不进行fast-forward)
    • –squash 将多个commit合并在一起放在WD, 之后需要用户手动发起commit.
  • git cherry-pick # pick commit to merge
  • git fetch 将远程repo的branch拉到本地但是并不进行任何修改
    • -p/–prune 如果远端删除分支的话,那么也删除本地分支

如果合并过来的分支,是当前分支的child的话,那么执行fast-forward合并(除非指定–no-ff),否则会执行普通的合并生成一个新的node,这个node是两个分支的共同child。

如果没有指定repo的话,根据上下文可能会指代当前branch所在的远程repo, 也可能会指代所有远程repo. 同理对于branch来说,根据上下文可能会指代当前所使用的branch, 也可能会指代repo下面所有的branch.

1.3 git tag

Git使用的标签有两种类型:轻量级的(lightweight)和含附注的(annotated)。轻量级标签就像是个不会变化的分支,实际上它就是个指向特 定提交对象的引用。而含附注标签,实际上是存储在仓库中的一个独立对象,它有自身的校验和信息,包含着标签的名字,电子邮件地址和日期,以及标签说明,标签本身也允许使用 GNU Privacy Guard (GPG) 来签署或验证。一般我们都建议使用含附注型的标签,以便保留相关信息;当然,如果只是临时性加注标签,或者不需要旁注额外信息,用轻量级标签也没问题。

  • git tag 列出所有的标签
  • git show 察看相应标签的版本信息
  • git tag -a -m [] 添加含附注的标签
  • git tag [] 添加轻量标签
  • git push /–tags 推送某个标签或者是全部的标签

1.4 git flow

参考资源

git-flow主要推行的就是一种开发方式,然后通过工具来配合这种开发方式。git-flow分为下面几类分支:

  • master 线上使用版本始终都是ready状态。
  • develop 作为开发基线版本。
  • feature 专门用于开发特性(可以有很多).
  • release 开发到一定阶段发布的版本,作为master candidate.(直接在上面做bug修复)
  • hotfix master上面出现bug临时修复(可以有很多).

然后说说各个分支之间的关系(这个在链接里面给出的图表示非常清楚)

  • master
    • 第一个版本之后,就会从master开出develop
    • release OK会merge回master.
    • hotfix OK会merge回master.
  • develop
    • hotfix OK会merge回develop.
    • feature开发完毕会merge回develop,
    • release做完bug fix之后会merge回develop.
    • 从develop可以开出新的feature分支。
    • develop OK之后可以开出release.
  • feature
    • 从develop开出
    • OK之后会合并到develop
  • release
    • 从develop开出
    • 期间测试发现的问题会在上面修复
    • 修复会同时merge回develop
    • OK之后会合并到master
  • hotfix
    • 从master开出
    • OK之后合并到master和develop

关系还是非常清楚的(不过我这里可能描述比较混乱).

1.5 FAQ

1.5.1 合并多个commit

合并两个commit

$ git reset –soft HEAD^1
$ git commit –amend

合并最后n个commit

$ git rebase -i HEAD~n
>>>> 然后替换第n个pick为s保存

视频: 感觉不错:)

转载:   大牛的博客值得学习:)

阅读(1519) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~