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 条评论
登录 后参与评论

相关文章

来自专栏我是攻城师

spark on yarn 如何集成elasticsearch

3736
来自专栏维C果糖

IntelliJ IDEA 中 Project 和 Module 的概念及区别

在 IntelliJ IDEA 中,没有类似于 Eclipse 工作空间(Workspace)的概念,而是提出了Project和Module这两个概念。接下来,...

20910
来自专栏Kirito的技术分享

java实用小技巧(一)--远程debug

该系列介绍一些java开发中常用的一些小技巧,多小呢,从不会到会只需要一篇文章这么小。这一篇介绍如何使用jdk自带的扩展包配合Intellij IDEA实现远程...

2744
来自专栏pangguoming

Centos7下yum安装配置nginx与php

实现LNMP环境搭建。 开始安装Nginx和PHP-FPM之前,首先卸载系统中以前安装的Apache和PHP保证安装不会冲突。用root登录输入下面的命令: y...

5417
来自专栏后端技术探索

Nginx + FastCGI 程序(C/C++) 搭建高性能web service的Demo及部署发布

由于最近工作的需要,本人学习了一下利用高性能web server - Nginx,来发布C/C++编写的fastCGI程序,详细细节如下。

692
来自专栏林德熙的博客

WPF DrawingVisual

为何需要学这个?如果需要画出图形,对性能有要求,或者需要了解WPF如何画图,就需要知道这个。

632
来自专栏猛牛哥的博客

nginx rewrite伪静态配置参数详解

1965
来自专栏Linyb极客之路

Spring Boot DevTools使用教程

DevTools通过提供自动重启和LiveReload功能,使您更快、更轻松地开发Spring Boot应用程序。除此之外,它还将各种属性设置为更适合本地开发的...

553
来自专栏tkokof 的技术,小趣及杂念

疑难杂症又一记

下了 OGRE 的 1.10.11 版本,使用 CMake 生成了相应的工程文件,遂而编译源码和示例,一切都挺顺利,但是当尝试 Debug 模式下执行 Samp...

441
来自专栏静默虚空的博客

Ant 简易教程

前言 Apache Ant,是一个将软件编译、测试、部署等步骤联系在一起加以自动化的一个工具,大多用于Java环境中的软件开发。由Apache软件基金会所提供。...

19710

扫码关注云+社区