从svn迁移到git

我使用了十几年的svn,然而现在我转投了git的怀抱~

关于svn和git的使用

我不会在这里讲如何使用svn和git,因为网上已经有大量的文章详细讲解如何使用它们。要注意的是svn和git有很多不同的软件可以选择。每种软件的使用习惯都有点不同。学习使用版本管理系统会有一些成本,但一旦你掌握了如何使用它们你会发现它对你的帮助很大。

SVN :windows系统推荐使用 TortoiseSVN ,苹果系统推荐使用 Cornerstone

Git :windows系统推荐使用 TortoiseGit ,苹果系统推荐使用 Tower

下面就说说为何我从svn迁移到git

诚然svn是一个很不错的系统。我有无数个项目使用它。包括之前工作的公司和现在我自己的团队。但是git有很多优秀的地方填补了svn功能空缺也解决了很多svn使用上的问题。

当没有网络的时候

有很多次我外出的时候需要修改一些代码,而且有时候咖啡厅的wifi并不好或者所处的地方根本没有网络。这个时候我会像没有版本管理系统一样把准备要修改的文件复制一份出来保存然后再开始工作。这个就是svn最大的问题,如果你断网了,你就不能使用版本管理系统了。

这是由于svn的版本库存只有一个而且存放在服务器上。而git的版本库概念和svn很不一样。你可以理解为在服务器上依然有一个集中了所有东西的版本库。同时,在你的电脑和其他使用这个项目的成员的电脑里都有一个独立的版本库。这样的好处就是即使没有网络我也可以放心的在本地修改文件,可以使用版本管理带来的各种好处。当我需要把修改内容上传到服务器的时候我只需要把本地的版本库同步到服务器的版本库上。

当你需要修改一个项目但又不想影响现在项目的内容

在版本控制系统里面你需要通过分支来实现。然而svn的分支很坑爹。它会在你原有的工程里复制你需要分支的文件夹然后改名。对你没看错。你的工程突然就多了一个文件夹,而且当你分支很多的时候各种文件夹就到处飞了。在git里面分支是基于整个工程的。它不会新建新的文件夹来存储分支的内容而是使用类似快照的方式。

例如你项目有文件夹 a ,在svn里面创建分支后你的项目是这样的:a a1 a2 a3 a4 a5。不管你分支里面是否有修改内容,即使什么修改都没有,每创建一个分支都会复制一份文件夹。在git里面创建分支之后你的项目是这样的 a 。对,还是你原来的文件夹。当你切换分支之后a会变成a1。在git里面不用担心在一个分支里面修改会影响其他的分支,它们是独立的。

如果上传了错的内容

在svn里面如果你上传了错的内容,或者你后悔某次提交的内容。不好意思,你只能再提交一次新的内容上去。svn会记录每一次修改而且是不可逆的。而且因为svn只有一个在服务器上的公共版本库,所以如果多人协作开发一个项目,这个问题会是很大的麻烦。如果有人刚好上传了有问题的内容而其他成员又刚好更新了一次。这个时候有问题的内容就会扩散到其他人手中。如果负责人修改时间长,所有人都需要回滚到上一个版本再开发,不过通常这样会带来更多的版本冲突问题。或者有人使用上一个版本的内容重新提交了一个版本让大家更新。这种方法大家会很开心。但修改问题的负责人会遇到版本冲突问题。如果负责人修改时间短,那么大家可能停下来喝杯咖啡等他修改好上传大家再下载一遍。

在git里面每个人的电脑里都会有一个独立的版本库。我是指每个人的电脑里的每个项目都有一个本地的独立版本库。一般你需要先把修改提交到本地的版本库确认无误之后再同步到服务器。如果你发现某次提交有问题,你可以在本地库里删除这次修改。在你最终上传服务器之前你的修改不会影响其他人。

发现关注的点么?git可以让你使用版本管理的特性而无需担心影响其他人的工作。

关于多项目管理

一般情况下一个团队会有一个svn库。在这个库里面使用文件夹区分项目。文件夹的管理方式每间公司都不一样。svn的管理员会给每个成员对应每个目录分配权限。也就是谁可以访问什么目录不能访问什么目录。如果svn稳定的话这样有个好处,就是所有的项目都在一个地方管理。为何我说稳定问题呢?svn的服务端是很稳定的至少我用svn这十几年没有遇到过一次问题。但svn的客户端总有各种各样的原因导致你的工作目录崩溃掉。如果你上网找相关的内容你会发现很多关于svn工作目录无法被svn识别,或者工作目录无法更新和提交等问题。解决方法可以很直接,直接删除原有的工作目录重新checkout一次服务器上的内容就行了。如果你刚好遇到本地修改了东西没有提交,你就需要把你修改过的文件先保存出来。重点来了,如果你修改的东西很多,这个时候没有svn提示你哪些文件被修改了。你要把这些文件找出来会是一件很痛苦的事情。我就遇到过很多次这样问题。

为何不能每一个项目一个svn版本库?因为那样的话你需要管理员为每个库重新配置你们的用户名密码以及权限。当然了你其实也可以不checkout整个svn。你可以把svn里面项目的目录一个个独立的checkout下来。

如果你使用github或者gitlab这种管理系统。每个项目在服务器上都会是一个独立的版本库。

关于版本库迁移

如果你使用svn,当你需要切换当前电脑里面的项目到另一个服务器上。你需要先把原有的项目导出一份不带svn信息的版本。然后把项目放到新服务器checkout的工作目录里上传。这个时候你会发现项目虽然迁移到了新的服务器。但所有之前到版本信息都丢失了。新的服务器会认为你是一个新添加的工程,没有历史记录。

如果你使用git。你只需要在原有的项目里添加一个新的远端服务器然后提交上去。是的你没看错,git支持多个远端服务器。经常一种用法是你checkout了a服务器上的项目然后把它传到自己的b服务器。你自己新的修改假设都传到b服务器。a服务器上的项目可能会时不时更新。你可以从a上更新新的内容。然后把合并的修改再传回b。当然如果有需要并且你有a服务器的上传权限,你可以把内容传到a服务器上。

可以看到git处理多个远端版本库的方式很自由而且很优雅。重点是,你所有的版本修改记录都好好的呆在那。

今天先说这么多,之后有其他内容再更新上来。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,658评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,482评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,213评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,395评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,487评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,523评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,525评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,300评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,753评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,048评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,223评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,905评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,541评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,168评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,417评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,094评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,088评论 2 352

推荐阅读更多精彩内容

  • 更新完android3.0以后,发现gradle 已经依赖gradle4.0.1-all.zip,而且在proje...
    好好的1111阅读 254评论 0 0
  • 小雨轻轻油伞撑,碧草红花水露生。 青鱼戏水游云际,荷下蛙鸣一片争。
    诗词人子虚雨阅读 170评论 0 0
  • 1.我自是年少,韶华倾负(本宝宝还小,浪费了不少时间) 2.你要记得,那年那月,垂柳紫陌洛城东(哎呀妈呀,这城树可...
    孙昊之阅读 397评论 4 5
  • 秋丝与大地缠绵 凉气随风卷起 带着一缕熟悉的味道 感觉的味道 回忆的味道 眷恋的味道 不舍的味道 无需经过味蕾的品...
    闲少幽阅读 229评论 2 2
  • 孩子星期六日没有完成作业,今天特意打电话问他如何处理的,他说跟老师解释了,中午已经将作业补交上去了,我肯定他...
    英才日记阅读 186评论 0 0