Git介绍

一、Git 介绍
       Git 是一个分布式版本控制/软件配置管理软件(SCM),和SVN、CVS不同,不是集中化的版本控制系统。提供全局的配置管理;
       支持Linux、BSD、Solaris、Windows、Android;
       作者为Junio Hamano (git负责人/日本人)、Linus Torvalds(linux kernel负责人);
       Git为英格兰俗语,为饭桶、猪头的意思,
       现在一般认为Git为the stupid content  tracker,傻瓜内容跟踪器
二、Git的基本概念
       工作目录(working directory)
       暂存区域(staging area)
       本地仓库(local repo)
       对于任何一个文件,在 Git 内都只有三种状态:已提交(committed),已修改    
(modified)和已暂存(staged)。
       已提交表示该文件已经被安全地保存在本地数据库中了
       已修改表示修改了某个文件,但还没有提交保存
       已暂存表示把已修改的文件放在下次提交时要保存的清单中
三、Git的基本操作-安装
       1、Ubuntu
         sudo apt-get install git-core
       2、Windows
         安装msysgit、tortoiseGit
         http://code.google.com/p/msysgit/
         http://code.google.com/p/tortoisegit/
       3、Eclipse
         安装egit
         http://eclipse.org/egit/
四、Git的基本操作-配置
       /etc/gitconfig 对于所有用户使用的配置,git config --system操作该文件
       ~/.gitconfig 对于当前用户使用的配置,git config --global操作该文件
       当前工作目录的.git/config,对于当前项目有效
       git config --global user.name 'zhangsan'
       git config --global user.emal '[email protected]'
       git config --global core.editor vim
       # 命令别名
       git config --global alias.co checkout
       git config --global alias.ci commit
       git config --global alias.st status
       git config --list
五、Git的基本操作-创建
       git init
         git init --bare 无工作目录,服务器版本一般这样操作

       git clone 
git clone ssh://[email protected]/~/nginx_ex.git nginx_ex
git支持多种协议,git/ssh/http/file
六、Git的基本操作-基本命令
  1、基础命令
       git add
添加到stage
       git rm
从stage或者仓库删除并删除本地文件
       git rm --cached 从stage或者仓库删除但并不删除本地文件
       git status 查看工作区状态
       git diff 比较差异
       git commit 提交更新
  2、tag标签命令
       分轻量级标签(lightweight)和带注释的标签(annotated)。
       轻量级标签和分支类似,只是不能移动。带注释的标签是存储在仓库的一个独立对象,建      
       议使用带注释的标签
       git tag 
查看所有标签
       git tag -l <pattern>
查看符合模式的标签
       git show <tagname>
查看标签信息
       git tag -a <tagname> -m <msg> <commit>
对于指定commit加带注释的标签 git tag -a v0.1 -m 'basic structure‘
       git  tag –d <tagname>
删除标签
       git push <remote-name><tagname>
       git push <remote-name> <brance-name> --tags 分享标签,推送到服务器
  3、stash命令
       在当前工作区比较凌乱,需要切换到其它分支,但不想提交现在的修改是可以使用stash功能。储藏修改过的被跟踪文件和暂存的变更,在某个时刻可以恢复到当前状态
       git stash list        查看储藏列表
       git stash apply   应用储藏但并未删除
       git stash pop     应用储藏并删除
       git stash drop    删除储藏
       git stash branch 在储藏的基础上创建分支
  4、Blame命令(责备命令)
       git blame <filename>
查看文件的每行的修改信息,用于排查问题
       git blame –L <sart>,<end>
查看指定范围的修改信息
七、Git的基本操作-祖父引用
       在引用后面加^,为本次提交的父引用
       ^后加数字表示本次提交的第几父引用,只有在分支合并的时候有用
       ~也是本次提交的父引用
       ~后加数字n表示本地提交的往上回溯n代的父引用
       例如:
         HEAD~  <==> HEAD^
         HEAD~2 <==> HEAD^^
八、Git的基本操作-撤销
       git checkout -- <filename>
撤销已索引文件的修改
       git commit --amend
修改最后一次的提交
其等价于
       git reset –soft HEAD^
…do something…
       git commit –c ORIG_HEAD
       git reset命令进行撤销重置操作
       --hard
重设 index和working directory,自从<commit>以来在working directory中的任何改变都被丢弃,并把HEAD指向<commit>。 
       --soft
index和working directory中的内容不作任何改变,仅仅把HEAD指向<commit>。这个模式的效果是,执行完毕后,自从<commit>以来的所有改变都会显示在git status的"Changes to be committed"中
       --mixed
仅reset index,但是不reset working directory。这个模式是默认模式,即当不显示告知git reset模式时,会使用mixed模式。这个模式的效果是,working directory中文件的修改都会被保留,不会丢弃,但是也不会被标记成"Changes to be committed",但是会打出什么还未被更新的报告。
回滚最近一次的提交
       git reset --soft HEAD^
HEAD^指向HEAD之前最近的一次commit。 
永久删除最后几个commit
       git reset --hard HEAD~3
ps:不要担心,其实也能找到,通过git ref-log或者git log –g 查看引用日志就可以找到以前的记录
回滚pull
       git reset --hard ORIG_HEAD
执行git reset|pull|merge 时,git会把老的HEAD拷贝到文件.git/ORIG_HEAD中,在命令中可以使用ORIG_HEAD引用这个commit
九、Git的基本操作-日志
       git log -<n>
最近的几条日志
       git log -- filename
查看文件的提交记录
       git log --pretty=<format>
控制输出格式
       git log –oneline
单行显示日志
等价于 git log –pretty=oneline –abbrev-commit
       git log –graph
提供文本化图像的提交历史图
       git log --since <date>
       git log –unitl <date>
       git <since>..<until>
       git log origin/master..HEAD
在当前分支而不再远程分支的提交
        使用--not或者^表示不希望提交被包含在指定的分支
       git log refA..refB
       git log refB ^refA
       git log refB --not refA
        三个点,被两个引用的任意一个包含但不是同时包含的提交
       git log --left-right master...experiment
十、Git的基本操作-分支
       git 分支就是指向某个commit对象的指针,实际上就是一个包含所指对象校验和(40个字符的SHA-1)的文件 。
       可以参考 .git/refs 目录,查看所有的相关引用。
       分支合并是git相对别的SCM提供的强大功能,对于git而已,创建分支的代价很小,强烈推荐使用。
       git brance
列出分支
       git brance –v
列出分支并包含最后一次提交的信息
       git brance -a
        列出所有分支,包含远程跟踪分支(远程跟踪分支为不可移动的,只有在与远程仓库发生操作时才可能移动)
       git brance --merge
        列出已合并的分支
       git brance --no-merged
列出未被合并的分支
       git brance <name>
添加分支
       git brance -d <name>
删除已被合并的分支
       git brance -D <name>
强制删除分支(不论是否合并)
       git checkout <name>
切换到分支
       git checkout -b <name> <start-point>
根据起始点新建分支并切换到分支
       git merge <name>
合并分支
       git rebase <name>
衍合分支
        当发生冲突的时候,合并会被取消,需要手动解决冲突
       git mergetool
       git merge
        寻找最近的共同祖先进行三方合并,合并产生新的commit对象,其有两个parent或者快速递进
       git rebase
        回到两个分支共同祖先,根据当前分支的历次commit对象,生成补丁文件,以基底分支的最后一次commit对象为出发点,逐步应用补丁文件,生成一个新的commit对象。
       git rebase
        能产生更整洁的提交历史。
十一、Git的基本操作-远程仓库
       git remote -v
列出远程仓库
       git remote add <name> <url>
添加远程仓库
       git remote  -v show <name>
查看远程仓库
       git remote rm <name>
删除远程仓库
       git remote rename <old> <new>
重命名远程仓库
       git pull <remote-name>
        从远程仓库获取更新并合并到当前分支
       git fetch <remote-name>
从远程仓库获取更新但并不合并
       git push <remote-name>
推送更新到远程仓库
       git push <remote-name> <local brance>:<remote brance>
        推送更新到远程仓库的指定分支
       local brance
        为空则删除远程分支
十二、Git的基本操作-GIt目录
       decription :供GitWeb程序使用
       branches : 新版不在使用该文件夹
       config : 项目配置信息
       info目录 : 项目忽略模式
       hooks : 客户端或者服务器端钩子
       HEAD :指向当前分支
       index : 保存了暂存区域信息
       objects目录 :所有数据内容
       refs 目录:指向数据(分支)的提交对象的指针
十三、Git与SVN的不同之处
       svn为集中化的版本控制,svn获取最新的版本或者提交更新,历史记录等信息每次都要连接中央版本库 ;
       git为分布式的版本控制,git跟svn一样也可以有中央版本库,每个开发人员克隆原始的代码仓库,在连接不了中央服务器的情况下依然能进行本地操作;
       git把文件内容按元数据存储,svn按文件名称存储 ;
svn分支就是备份所有项目文件到版本库中的另一个目录,速度慢而且合并起来复杂
       git 分支就是指向某个commit对象的指针,实际上就是一个包含所指对象校验和(40个字符的SHA-1)的文件;
       svn每次提交会把全局版本号加一,为连续的数字版本号;
       git每次提交的生成一个SHA1的版本号,git识别简短的SHA1字符,只要大于4个字符且没有歧义就成;
       git 的工作模式很多,svn只有集中式的工作模式。
**参考资料**[i][/i][u][/u]
       http://progit.org/
       http://progit.org/book/zh/
       http://git-scm.com/
       http://github.com
       https://git.wiki.kernel.org/articles/g/i/t/GitFaq_ebc3.html
       http://sixrevisions.com/resources/git-tutorials-beginners/
       http://book.git-scm.com/
       http://gitbook.liuhui998.com/index.html
       http://sandofsky.com/blog/git-workflow.html
       http://nvie.com/posts/a-successful-git-branching-model/
       http://scottchacon.com/2011/08/31/github-flow.html


你可能感兴趣的:(分布式,git,版本控制)