SVN学习

TortoiseSVNSubversion版本控制系统的一个免费开源客户端,可以超越时间的管理文件和目录。在subversion管理下,文件和 目录可以超越时空。Subversion将文件存放在中心版本库中,这个版本库就像一个普通的文件服务器,不同的是,它可以记录每一次文件和目录的修改情况,每个文件的改变,甚至是目录树本身的改变,例如文件和目录的添加、删除和重新组织。许多人将此当做时间机器。

需要知道的是,subversion的客户端有两类,一类是webSVN等基于web 的,一种是以TortoiseSVN为代表的客户端软件。前者需要web服务器的支持,后者需要用户在本地安装客户端,两种都有免费开源软件供使用。

Subversion支持LinuxWindows,更多的是安装在linux下。SVN的服务器有2种运行方式:独立服务器和借助apache.SVN存储版本数据也有2种:Berkeley DBFSFS

Subversion是一个“集中式”的信息共享系统。版本库是subversion的核心部分,是数据的中央仓库。版本库以典型的文件和目录结构形式的文件系统树来保存信息。任意数量的客户端连接到SUBversion的版本库,读取、修改这些文件。客户端通过写数据将信息分享给其他人,通过读取数据获得别人共享的信息。

Apache subversion通常被缩写成SVNSVN相对于RCSCVS,采用了分支管理系统,它的设计目标就是取代CVS

SVN的一些概念

Repository(源代码库):源代码统一存放的地方;

Checkout(提取):当你手上没有源代码的时候,你需要从repository checkout一份;

Commit(提交):当你已经修改了代码,你就需要commitrepository;

Update(更新):当你已经checkout了一份源代码,update一下你就可以和Repository上的源代码同步,你手上的代码就会有最新的变更。

SVN可以合并这两个程序员的改动,实际上SVN管理源代码是以行为单位的,就是说两个程序员只要不是修改了同一行程序,SVN都会自动合并两种修改。如果是同一行,SVN会提示conflict,需要手动确认。

SVN 的主要功能

  • (1)目录版本控制

CVS 只能跟踪单个文件的历史, 不过 Subversion 实作了一个 "虚拟" 的版本控管文件系统, 能够依时间跟踪整个目录的变动。 目录和文件都能进行版本控制。

  • (2)真实的版本历史

自从CVS限制了文件的版本记录,CVS并不支持那些可能发生在文件上,但会影响所在目录内容的操作,如同复制和重命名。除此之外,在CVS里你不能用拥有同样名字但是没有继承老版本历史或者根本没有关系的文件替换一个已经纳入系统的文件。在Subversion中,你可以增加(add)、删除(delete)、复制(copy)和重命名(rename),无论是文件还是目录。所有的新加的文件都从一个新的、干净的版本开始。

  • (3)自动提交

一个提交动作,不是全部更新到了档案库中,就是不完全更新。这允许开发人员以逻辑区间建立并提交变动,以防止当部分提交成功时出现的问题。

  • (4)纳入版本控管的元数据

每一个文件与目录都附有一組属性关键字并和属性值相关联。你可以创建, 并儲存任何你想要的Key/Value对。 属性是随着时间来作版本控管的,就像文件內容一样。

  • (5)选择不同的网络层

Subversion 有抽象的档案库存取概念, 可以让人很容易地实作新的网络机制。 Subversion 可以作为一个扩展模块嵌入到Apache HTTP 服务器中。这个为Subversion提供了非常先进的稳定性和协同工作能力,除此之外还提供了许多重要功能: 举例来说, 有身份认证, 授权, 在线压缩, 以及文件库浏览等等。还有一个轻量级的独立Subversion服务器, 使用的是自定义的通信协议, 可以很容易地通过 ssh 以 tunnel 方式使用。

  • (6)一致的数据处理方式

Subversion 使用二进制差异算法来异表示文件的差异, 它对文字(人类可理解的)与二进制文件(人类无法理解的) 两类的文件都一视同仁。 这两类的文件都同样地以压缩形式储存在档案库中, 而且文件差异是以两个方向在网络上传输的。

  • (7)有效的分支(branch)与标签(tag)

在分支与标签上的消耗并不必一定要与项目大小成正比。 Subversion 建立分支与标签的方法, 就只是复制该项目, 使用的方法就类似于硬连接(hard-link)。 所以这些操作只会花费很小, 而且是固定的时间。

  • (8)Hackability

Subversion没有任何的历史包袱; 它主要是一群共用的 C 程序库, 具有定义完善的API。这使得 Subversion 便于维护, 并且可被其它应用程序与程序语言使用。

SVN的生命周期:

  1. 创建版本库(create);
  2. 检出(checkout):checkout操作是用来从版本库中创建一个工作副本。工作副本是开发者私人的工作空间,可以进行内容的修改,然后提交(commit)到版本库中.
  3. 更新:update是用来更新自己的的工作副本,这个操作将工作副本与版本库进行同步。由于版本库是由整个团队共用的,当其他人提交(commit)了他们的改动之后,你的原始工作副本就会失效。
  4. 执行变更(add,delele,modify,search)。注意:这些操作后不会立即变成为版本库的一部分,而是被添加到待变更列表中,直到执行了commit操作后才能做出改变。
  5. 复查变化:在对自己的工作副本进行一些修改之后,在commit操作之前复查下你的修改是一个很好的习惯。Status操作列出了工作副本中所进行的变动。你对工作副本的任何改动都会成为待变更列表的一部分。Status操作就是用来查看这个待变更列表。

注意:status只是提供了一个变动列表,但并不提供变动的详细信息。你可以用diff操作来查看这些变动的详细信息。

  1. 修复错误:假设对工作副本做了许多修改,但是现在不需要这些修改了,这时候revert(返回,恢复)操作就会帮助你。
  2. 解决冲突:合并的时候可能会发生冲突。Merge(混合)操作会自动处理可以安全合并的东西。其他的会被当做冲突。例如,“hello.c”文件在一个分支上被修改,在另一个分支上被删除了。这种情况就需要人为处理。Reslove操作就是用来帮助用户找出冲突并告诉版本库如何处理这些冲突。
  3. 提交更改:Commit操作是用来将更改从工作副本到版本库。这个操作会修改版本库的内容,其他开发者可以通过更新他们的工作副本来查看这些修改。

你可能感兴趣的:(SVN,工具,在线文档分享,运维,操作系统)