svn和git的区别以及使用方法
svn的优势:
SVN是Subversion的简称,是一个开放源代码的版本控制系统
优异的跨平台支持,对windows平台支持非常友好。
简单易用,安装后稍微培训下就知道怎么操作。
代码,需求,文档,涉及稿都可以用svn进行管理,适合不同部门的技术非技术的同事协作。
说得简单一点SVN就是用于多个人共同开发同一个项目,共用资源的目的。
git的优势:
去中心化:Git是没有中心服务器的,每个人机器上都是一个完整的库,我们平时开发代码时的中央服务器其实和我们自己机器上的库内容是完全一样的(格式有点不同,是bare的)。虽然平时大家都是将代码提交到中央服务器上再统一pull别人的代码,但实际情况你可以总是pull张三的库,然后push给李四等等操作。
本地提交:本地提交好处主要有3点:一, 断网提交 。二, 小步提交。可以对自己的阶段成果有跟踪,并且提高每次变更的安全性。三,本地库。这个和断网提交是同一个实现,但从需求角度出发则略有不同,主要是说即使只有自己一个人开发项目,也可以轻易的让自己的代码有版本跟踪,而不需要去费力建个什么svn server。四,本地回滚。这个其实是由于本地库的存在而产生的,但可以减少中央库上的冗余版本
分支策略:在Git实际开发中分支的分离和merge是属于日常操作,开启和合并分支成本相比SVN要小得多:SVN是复制一份代码到分支目录,Git则是在分支点做一下标记。随便一次冲突就会自动产生分支,所以大家每天都在与分支打交道。这便是弱化了分支的概念,由于分支成本很小,因此使得按功能分支的开发模式(每个分支一个功能,开发完了再merge到主干)变得非常简单,大家可以完全不需要再因为担心SCM成本太高而选用主干开发模式(所有功能都在主干上开发,到了发版本前再分离出分支)。
两者的工作流对比:
svn模式
写代码。
从服务器拉回服务器的当前版本库,并解决服务器版本库与本地代码的冲突。
将本地代码提交到服务器。
git模式
写代码。
提交到本地版本库。
从服务器拉回服务器的当前版本库,并解决服务器版本库与本地代码的冲突。
将远程库与本地代码合并结果提交到本地版本库。
将本地版本库推到服务器。
表格式分析
集中式 | 分布式 |
---|---|
有中央服务器,开发人员需要从中央服务器获得最新版本的项目然后在本地开发,开发完推送给中央服务器。因此脱离服务器开发者是几乎无法工作的 | 没有中央服务器,开发人员本地都有 Local Repository |
必须要联网才能工作,而且对网络的依赖性较强,如果推送的文件比较大而且网络状况欠佳,则提交文件的速度会受到很大的限制。 | 分布式在没有网络的情况下也可以执行commit、查看版本提交记录、以及分支操作,在有网络的情况下执行 push 到 Remote Repository。 |
文件存储格式:按照原始文件存储,体积较大 | 按照元数据方式存储,体积很小 |
有版本号 | 无版本号 |
分支操作的影响 :创建新的分支则所有的人都会拥有和你一样的分支 | 分支操作不会影响其他开发人员 |
– | – |
提交的文件会直接记录到中央版本库 | 提交是本地操作,需要执行push操作才会到主要版本库 |
接下来就是svn的使用方法
简单术语
*仓库
*提交
*检出/更新checkout
SVN数据结构
https://tortoisesvn.net/downloads.html(下载地址(也有语言包))
大家直接进行傻瓜式安装就可以了!一路next
[一路next安装。安装完毕后,在任意地方右键查看快捷菜单。发现TortoiseSVN即表示安装成功。]
这个,也可以查看是否安装成功
在这里,我们可以选择适配的电脑系统设置语言
选择喜欢的语言(比如中文),然后确定,不出意外,现在的语言已经切换到中文了。
检出项目
假如项目已经在服务器的仓库里,那么现在你要做的就是把它检出到本地。
首先创建一个空文件夹。在空文件夹内右键,选择SVN检出。
填入版本库地址,选择确定
此时会弹出一个对话框让你输入账号密码,输入你的账号密码即可。记得勾选保存认证,不然每次操作都会让你输入。
检出完毕。如上图所示,好了,源代码已经成功签入SVN服务器了。这时候团队成员就可以迁出SVN服务器上的源代码到自己的机器了。
签出源代码到本机
在本机创建文件夹StartKit,右键点击Checkout,弹出如下图的窗体:
打开StartKit目录,可以看到如下图的文件夹结构:
如果做了修改,会有这样的效果
这张图片,大家可以看出,每个图标所对应的意思
我们已经将源代码签入到SVN服务器,怎么从服务器签出代码到本机
提交修改过的文件到SVN服务器
点击ok
添加新文件到SVN服务器over