From svn to git 你要知道的东西

最近团队项目准备从svn往git迁,于是做了一些相关的了解,发现svn跟git还是有很多不一样的,下面写了一些个人理解。

核心区别

分布式 vs 集中式

  • git是分布式版本管理,也就是本地即完整的仓库,包括所有的提交,分支,标签等,而且提交,分支等操作都是在本地进行,与远程仓库只是相互同步的关系
  • svn是集中式版本管理,本地只是远程仓库的某个镜像,比如处于某个分支,某个版本,但不保存其他版本信息,提交或者建分支等操作都是要连接远程仓库的。

这是两者最根本也是最核心的区别,如果理解了这个区别,就会很容易理解其他比如下面说道工作流程等的不同。为了方便理解,这里举个不太恰当的比喻,svn中本地和远程的关系相当于我们浏览器打开网站和该网站的服务器的之间的关系,我们本地只是状态,而我们要提交修改或切换页面都是通过与服务交互进行的。而git中本地和远程的关系相当于两台服务器之间的关系,两者都能独立完成操作,两者之间需要的只是同步。下图为git和svn本地和远程之间关系的示例图:

工作流程区别

理解了上面的原理上的不同,就可以理解工作流程的不同了,svn是本地修改,远程提交,而git则是本地操作,远程同步,这里的操作包括修改,提交,分支操作等。

工具的区别

svn更倾向于GUI工具的使用,而git更倾向于命令行工具的使用,当然这两者也不是完全是死的,比如你觉得git命令行不直观的话,也可以使用一些GUI工具,比如windows上安装的git本身自带GUI工具,甚至还有丧心病狂的TortoiseGit工具。

命令上的区别

add

很多刚从svn迁到git的同学会很困惑,为什么每次commit之前都要add一下。事实上,在git后续的版本就增加了git stage命令,其作用跟之前版本的git add完全一样,就是官方为了强调,git add的作用是将修改的文件加到暂存区(stage),而git commit的时候只会提交在暂存区的修改,也就是说,暂存区就是本地修改和commit之间的缓冲,而这样做的好处按我的理解有2个:

  1. 分次缓存,方便review:如果你跟我有一样的习惯,就是提交之前都会review一下自己修改的代码,那么git add 是可以方便我们进行代码review的,每次我完成一部份相对完整或者独立的修改之后,我会reviwe完修改之后就执行git add,将这部分修改加入缓存区,而当我后面又做了一些修改要review的时候,我就可以只关心修改了但未add的文件。不然的话,要么每次commit的文件都很多,要么commit次数很多,很乱。
  2. 方便回退:git一旦commit了,要回退是很麻烦的,只是本地commit的话还有得救,已经同步到远程的话,就只能弄多一个revert的commit才能进行回退,而git add 是很方便回退的。

PS: 当然,如果你觉得上面说的东西都没卵用,那么可使用 git commit -a -m命令直接实现 git add . + git commit -m 的效果(注意当有文件增删的时候不行,还是要先add一下)

checkout

svn上checkout跟git的checkout是不同的,git上与svn checkout对应的命令是 clone,而git上checkout的作用分支切换或者代码还原。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏pangguoming

CentOS查询端口占用和清除端口占用的程序

995
来自专栏jeremy的技术点滴

nginx使用备忘

27411
来自专栏软件开发

HTML5 学习总结(三)——本地存储(localStorage、sessionStorage、WebSqlDataBase、IndexedDB)

HTML5问世以后,前端加入了一个重要的功能,便是本地存储,本地存储可分为4类: Local Storage:总的存储量有所限制,并不能提供真正的检索API,数...

40110
来自专栏光变

Spring MVC配置响应静态文件请求

在web项目中,如果使用了页面,就会涉及到css/js等组件。下面讲解了如何在SpringMVC项目中,相应css、js、img文件,并启用浏览器缓存等机制。

763
来自专栏blackheart的专栏

[Cake] 1. CI中的Cake

在上一篇C#Make自动化构建-简介中,简单的介绍了下Cake的脚本如何编写以及通过Powershell在本地运行Cake脚本。本篇在此基础上,介绍下如何在CI...

3317
来自专栏云计算

从零开始写一个运行在Kubernetes上的服务程序

这是一篇对于Go语言和Kubernetes新手来说再适合不过的文章了。文中详细介绍了从代码编写到用容器的方式在Kubernetes集群中发布,一步一步,一行一行...

19811
来自专栏流柯技术学院

windows / linux系统中,端口被占用解决方法

一、在windows操作系统中,查询端口占用和清除端口占用的程序 提升权限后用:netstat -b 或用 1、查询端口占用的进程ID          ...

952
来自专栏玩转JavaEE

Redis快照持久化

redis的基础知识我们已经准备的差不多了,接下来两篇文章,我想和大家聊聊redis持久化这个话题。

1020
来自专栏Python、Flask、Django

TP添加管理和修改管理功能(简单实现)

822
来自专栏决胜机器学习

《Redis设计与实现》读书笔记(二十五) ——Redis主从复制具体过程

《Redis设计与实现》读书笔记(二十五) ——Redis主从复制具体过程 (原创内容,转载请注明来源,谢谢) 一、PSYNC命令执行过程 ...

3415

扫码关注云+社区