Subversion(SVN) 是一个开源的版本控制系統,与 Git 一样是一个代码控制系统。
前文
SVN 相关的概念
- repository
源代码
源代码库,是源代码统一存放的位置 - checkout
拉取
从 repository 中 checkout(相当于 Git 的 pull)最新的代码 - update
更新
当你已经 checkout 了一份源代码,可以 update 一下保持本机与 Repository 上的源代码同步。 - commit
提交
当你已经修改了代码,你就需要 commit 到 repository。(注意:每次 commit 前需要 update)
SVN 的主要功能
- 目录版本控制 CVS 只能跟踪单个文件的历史, 不过 Subversion 实作了一个 "虚拟" 的版本控管文件系统, 能够依时间跟踪整个目录的变动。 目录和文件都能进行版本控制。
- 真实的版本历史 自从 CVS 限制了文件的版本记录,CVS 并不支持那些可能发生在文件上,但会影响所在目录内容的操作,如同复制和重命名。除此之外,在 CVS 里你不能用拥有同样名字但是没有继承老版本历史或者根本没有关系的文件替换一个已经纳入系统的文件。在 Subversion 中,你可以增加(add)、删除(delete)、复制(copy)和重命名(rename),无论是文件还是目录。所有的新加的文件都从一个新的、干净的版本开始。
- 自动提交 一个提交动作,不是全部更新到了档案库中,就是不完全更新。这允许开发人员以逻辑区间建立并提交变动,以防止当部分提交成功时出现的问题。
- 纳入版本控管的元数据 每一个文件与目录都附有一組属性关键字并和属性值相关联。你可以创建, 并儲存任何你想要的 Key/Value 对。 属性是随着时间来作版本控管的,就像文件內容一样。
- 选择不同的网络层 Subversion 有抽象的档案库存取概念, 可以让人很容易地实作新的网络机制。 Subversion 可以作为一个扩展模块嵌入到 Apache HTTP 服务器中。这个为 Subversion 提供了非常先进的稳定性和协同工作能力,除此之外还提供了许多重要功能: 举例来说, 有身份认证, 授权, 在线压缩, 以及文件库浏览等等。还有一个轻量级的独立 Subversion 服务器, 使用的是自定义的通信协议, 可以很容易地通过 ssh 以 tunnel 方式使用。
- 一致的数据处理方式 Subversion 使用二进制差异算法来异表示文件的差异, 它对文字(人类可理解的)与二进制文件(人类无法理解的) 两类的文件都一视同仁。 这两类的文件都同样地以压缩形式储存在档案库中, 而且文件差异是以两个方向在网络上传输的。
- 有效的分支
branch
与标签tag
在分支与标签上的消耗并不必一定要与项目大小成正比。 Subversion 建立分支与标签的方法, 就只是复制该项目, 使用的方法就类似于硬连接(hard-link)。 所以这些操作只会花费很小, 而且是固定的时间。
正文
安装 SVN
在电脑本机中需要先安装VisualSVN-Server
服务的支持,很多人采用的是TortoiseSVN
可视化工具来进行代码的更新、提交、融合、解决冲突。这也是不错的做法。
方法下载相关的软件安装即可
vscode 配合使用 SVN
在 vscode 中利用Gitlens
扩展来操作和查看代码版本的控制是十分直观高效的。因此,在 vscode 利用相关的扩展是否也能做到差不多的效果呢?答案是有的。
安装 SVN 扩展
我们可以在扩展商城安装一个 SVN 扩展(下载量最多的一个)。这时候控制台输出会显示Svn installation not found
。
安装 TortoiseSVN
这个报错需要TortoiseSVN
的支持(可以不需要VisualSVN-Server
,因为它是 SVN 的服务器端,本地是可以不用的),但是这时候的TortoiseSVN
的默认安装是不勾选command line client tools
,我们需要将其选上。
查看提交文件变更
在 vscode 中的左侧菜单栏中会有S
的标志,这个就是 SVN 扩展应用的功能入口了。
在这里面有三个主要主要功能:仓库(REPOSITORIES)、文件历史(FILE HISTORY)、分支改变(BRANCH CHANGES)
我们可以在仓库REPOSITORIES
中,查看每次提交的文件变更,这样更加直观。