svn老鸟转用git必须理解的概念
不都是SCM代码管理嘛,有很大区别么?很多svn老鸟都是抱着这样的心态去学习git,然后无一幸免地陷入“查阅过很多资料,依然掌握不好”的困境,至少我们团队是这样的。
网上的资料确实已经很多了,却没有把整个知识结构串起来。通读《git权威指南》是可行的,只是大家都急着用,没那耐性。我这里熬一碗鸡汤,整理供大家享用。
一、安装
服务器端不展开,因为主要面向搬砖的码农。
客户端可参见大神 廖雪峰 的Git教程-安装git
需要特别说明的是,在windows中,msysgit才是真正的git客户端,乌龟tortoisegit只是个界面。mercurial和sourcetree也是类似道理。
二、本地版本库
又见 工作区和暂存区
这里容易是初学者容易踩坑的地方,代码只提交到本地版本库,却没有推送到远程版本库。(其实是选型的人的反人类设定吧,用分布式的工具去做集中式的管理。)
svn是本地-远程两层的结构,而git则是工作区-本地-远程三层的结构。
在客户端看的见到的源码文件是工作区,提交到的是本地版本库,本地版本库的修改如果不推送,就是单机自己玩,不会影响其他人。
三、相关命令和冲突合并
命令方面资料很健全,我就不重复造轮子了。见上文的Git教程。
命令的查阅很流行这种叫Cheatsheet(考试作弊的小抄么?)速查手册,也是一搜一大把~
比如 http://ndpsoftware.com/git-cheatsheet.html 清晰地指出从哪个区到哪个区对应的命令是什么~

又比如上图,图示说明了遇到各种场景应该怎么办。
至于冲突,都是发生在跨分支或跨库的修改。比如,工作区的修改未commit而pull远程的更新时会报错(要先commit),本地库push发现远程库有其他人提交时会报错(要先pull并在本地解决冲突),暂存区取回stash pop时可能发生冲突。
而当合并发生冲突需要手动解决时,svn老鸟肯定是懵逼的,三路对比合并,哪个打哪个啊。。。这是因为,在svn中只有“我和中央库”的冲突,而git中却是“我和他”的冲突。
所以在git中做合并有三个源:base是分支的共同祖先,local是本地仓当前分支,remote是要从这个分支合过来,output当然就是合并结果的预览啦。
详见 对于解决 Git 的 Merge Conflict 你有哪些经验和技巧?
四、命令行or图形界面?
两者没有本质区别,图形界面最后也还是触发命令。直接用命令行能更好理解整个操作的过程。
图形界面则操作方便。但新手一定要对图形界面中的参数保持敏感,可能多勾了选项结果就完全不一样,比如--force。。。
五、分支管理
查阅过很多git分支管理的资料,依然用得不好,直到踩过若干个月的坑。。。
git的发源是开源系统,思想是分布式、去中心化,用svn的集中式管理是很容易踩坑的。
首先,svn是针对文件内容的对比,而git是针对文件增量和提交时间的对比,多人的频繁的冲突合并极容易发生错误。
其次,git的去中心化思想认为每个开发者都是熟练的负责任的。而事实上不是的,如果团队里有一两个“流氓”,遇到冲突没有细看,直接--force或use mine,测试会抓狂的,然后开发和项目经理都会抓狂的~
然后最后,你便会质疑:为什么不用svn啊?git跟svn没什么区别啊,还更难用!
且看看开源项目对git是怎么用的。 Git使用规范流程 开发者先fork复制出自己的库(远程),然后一系列的开发(本身也可以有分支管理),push上自己的远程库后,再pull request提交给管理员review和合并。而开源项目的发布,是有stable和nightly update等不同的发布版本。
回过头来看,公司团队里的项目要怎样管理git的版本和分支呢?

上图 git flow 便是最完整最科学的分支管理模型了。
这里有四点血泪经验要谨记:
1.不要吝啬开分支,git开分支的代价很小。
2.合并是容易出事的环节,要让负责任的熟手来把关。
3.以feature划分开发分支是非常好的思维方式,把相互依赖的内容放在一起、把不相关的内容隔离开、让“这个功能暂时不上”这种需求变更变得可行。
4.分支是活的、会变动的,标签tag才是一个确切的版本。
至此,使用git做源码管理的项目和团队足以运作起来而且可以避开大部分的坑。要用得更溜的话可以继续精修patch、rebase、revert、--fast-forward、cherry pick等更高阶的用法。
最后彩蛋:老司机温馨提醒,请把eclipse项目文件、编译后文件(文件夹)加入.gitignore文件,这个问题在svn就存在了~
svn老鸟转用git必须理解的概念的更多相关文章
- svn git 必须理解的概念
不都是SCM代码管理嘛,有很大区别么?很多svn老鸟都是抱着这样的心态去学习git,然后无一幸免地陷入“查阅过很多资料,依然掌握不好”的困境,至少我们团队是这样的. 网上的资料确实已经很多了,却没有把 ...
- iOS开发——源代码管理——git(分布式版本控制和集中式版本控制对比,git和SVN对比,git常用指令,搭建GitHub远程仓库,搭建oschina远程仓库 )
一.git简介 什么是git? git是一款开源的分布式版本控制工具 在世界上所有的分布式版本控制工具中,git是最快.最简单.最流行的 git的起源 作者是Linux之父:Linus Bened ...
- svn迁移到git
步骤命令如下: > git svn clone https://svn-url/ProjectName --no-metadata --authors-file=user.txt --trunk ...
- svn 版本转为git
git clone 相当于git init 和 git svn fetch.git svn rease git svn fetch 从svn服务器取指定区间的版本转化成git库 git svn reb ...
- SVN迁移到Git的过程(+ 一些技巧)
SVN迁移到Git的过程(+ 一些技巧) 李顺利 Key Words SVN,Git,Clone,Conversion,Tips,VCS,Pro Git 关于在VCS中SVN和Git之间的迁移(Clo ...
- SVN迁移到Git的过程(+ 一些技巧
关于在VCS中SVN和Git之间的迁移(Clone)这个部分网上已经有大批的文章介绍,而且都非常不错,能够满足我们的常见的需求,这里介绍的是我自己整理的一些技巧和使用中出现的一些问题和疑问.阅读本篇文 ...
- svn迁移到git仓库并保留commit历史记录
svn迁移到git仓库并保留commit历史记录 最近在做svn迁移到gitlab,由于之前一直是由svn做版本控制.最简单的方式是将svn的内容export出来,然后添加到gitlab即可.但是,如 ...
- git - svn 平滑到 git
1. 建立自己的git仓库,需要是空git仓库 2. checkout 你的 git仓库 3. svn忽略.git文件,忽略.git .gitignore 4. 把 .git文件拷到你的 svn仓库 ...
- Git的一些基本概念
Git的一些基本概念 设置自己的用户名和邮箱git config –global user.name "Your Name"git config –global user.emai ...
随机推荐
- IntelliJ IDEA通过Spring配置连接MySQL数据库
先从菜单View→Tool Windows→Database打开数据库工具窗口,如下图所示: 点击Database工具窗口左上角添加按钮"+",选择Import from sour ...
- webstorm 10 设置文件的默认编码
我在使用webstorm时,发现文件的默认编码是GBK 然后我找到了点击此处可以修改这个文件的编码,但是以后新建文件和项目默认生成的文件还是GBK, 设置项目文件的默认编码可以在 File----Se ...
- 【Linux】之shell特殊变量整理
目录 1. 特殊变量列表 2. 特殊说明 在shell中变量名只能包含数字.字母和下划线,因为某些包含其他字符的变量有特殊含义,这样的变量被称为特殊变量. 例如,$ 表示当前Shell进程的ID,即p ...
- C# Winform中WndProc 函数作用
http://blog.csdn.net/xochenlin/article/details/4328954 C# Winform中WndProc 函数作用: 主要用在拦截并处理系统消息和自定义消息 ...
- 使用 Entity Framework
ORM 和 EF 当我们要开发一个应用程序,就要考虑怎样展示数据,怎样持久化数据.考虑这个问题时我们所要关心的东西,最重要的莫过于程序的性能.开发的简易性和代码的可维护.可扩展性. 持久化(Persi ...
- AP_应付税务预扣税Withholding Tax的设定和使用(案例)
2014-07-13 Created By BaoXinjian
- OAF_架构MVC系列1 - MVC的概述(概念)
2015-04-03 Created By BaoXinjian
- Codeforces Round #365 (Div. 2) Chris and Road
Chris and Road 题意: 给一个n个顶点的多边形的车,有速度v,人从0走到对面的w,人速度u,问人最快到w的时间是多少,车如果挡到人,人就不能走. 题解: 这题当时以为计算几何,所以就没做 ...
- 3. Windows根据端口查进程---ADB 相关报错 ADB server didn't ACK cannot bind ':5037'
1.ADB server didn't ACK,一般报ADB相关的错误,大部分是端口被占用了 处理方法: 在命令行输入>adb nodaemon server 如果返回: cannot bind ...
- git的使用(3) 多分支情况下的pull
当你存在多个分支的时候,你需要pull下来分支上面的内容,你需要指定分支进行同步命令: git pull origin branch (branch 是你的分支的名字)