svn教程

概况

本文主要介绍svn的使用,转载自svn使用教程总结1

SVN简介

Subversion的简称,是一个自由/开源的版本控制系统,一组文件存放在中心版本库,记录每一次文件和目录的修改,Subversion允许把数据恢复到早期版本,或是检查数据修改的历史,Subversion可以通过网络访问它的版本库,从而使用户在不同的电脑上进行操作。

SVN服务器搭建和使用

Note:下面操作在Windows环境下进行

VisualSVN下载

VisualSVN2官网选择VisualSVN Server下载

VisualSVN安装

双击下载应用,选择标准版模式,并且设置好相关的配置,如版本库目录(Repositories)、端口(Server Port)、安全连接(勾选Use secure connection)等,一直到安装完成

建立版本库

打开应用,右键单击左边窗口的Repositories,选择Create New Repository,输入版本库名称后,最后会生成一个版本库URL(Repository URL)地址

建立用户和组,并分配权限

  • 在应用窗口左侧单击用户,选择Create User,要求填写UsernamePassword,点击OK按钮后,再点击Add按钮即完成用户建立操作
  • 在应用窗口左侧单击组,选择Create Group,要求填写Group name,点击Add按钮,在弹出窗口中选择该组,即加入到该组
  • 在版本库上右键,选择Properties...,选择Security选项卡,点击Add按钮,选中某一用户添加进来,权限设置为Read/Write,即完成用户权限设置操作

TortoiseSVN客户端

下载

TortoiseSVN3官网选择适合当前系统位数的版本下载

安装

双击下载应用,安装完成后可以通过右键看到TortoiseSVN选项,即安装成功

检出项目文件

新建并进入目录下,右键选择Svn Checkout,然后将SVN服务器获取到的版本库地址填写到弹出窗口的URL of repository栏,点击OK按钮即可检索出来

Note.svn这个隐藏目录记录着两项关键信息,即工作文件的基准版本和本地副本最后更新的时间戳,不要手动修改或更新该隐藏目录或里面的文件,否则将导致本地的工作拷贝被破坏,无法再进行操作

基础操作

SVN检出(SVN Checkout)

在文件夹或者目录下单击右键 –> 选择SVN检出 -> 在弹开窗口的版本库url框中输入版本库的目录地址 -> 点击ok按钮 -> 在弹出的对话框中输入用户名和密码,验证成功后,项目文件开始从远程服务器下载到本地工作目录中

增加(Add)

提交到版本库有两种方法

  1. 先提到变更列表中,再commit到配置库中,选择新增文件,右键SVN菜单执行Add操作提交到变更列表中,然后右键SVN菜单执行SVN Commit提交到版本库中
  2. 不提交到变更列表中,而是直接commit配置库中,选择该文件,右键svn菜单执行SVN Commit操作

删除(Delete)

  • 如果被删除的文件还未入版本库,则可以直接使用操作系统的删除操作删除该文件
  • 如果被删除的文件已入版本库,选择被删除文件,右键svn菜单执行delete操作,然后选择被删除文件的父目录,右键svn菜单执行SVN Commit,使用操作系统的删除操作删除该文件,然后选择被删除文件的父目录,右键svn菜单执行SVN Commit,在变更列表中选择被删除的文件

改名(Rename)

修改文件名,选中需要重命名的文件或文件夹,然后右键TortoiseSVN Rename,在弹出的对话框中输入新名称,点击”ok”按钮,并将修改文件名后的文件或文件夹通过SVN Commit提交到SVN服务器上

SVN还原(SVN Revert)

右击想要回退的文件或者文件夹,在TortoiseSVN弹出菜单中选择Update to reversion…,然后会弹出一个窗口,只需要在Revision中填写相应的版本号,然后点击ok即可

检查更新(Check for modifications)

此功能可以显示你所做的修改有哪些还没有提交的,此功能不光能看到对文件的修改变化,所有的变化都能看到,包括增加文件或者目录,删除文件或者目录,移动文件或者目录等,如果你点击了检查版本库,那你还可以看到版本库里的改动,既别人提交了哪些文件的改动,你还没更新到本地

SVN更新(SVN Update)

更新本地代码与SVN服务器上最新的版本一致,只要在需要更新的文件夹上点击右键或者在文件下空白处点击右键,选择SVN Update(获取指定版本中的内容,点击右键执行SVN菜单中的Update to reversion)

SVN提交(SVN Commit)

SVN的提交是将在工作空间做的修改进行提交,包括文件内容的修改,文件或目录的添加、删除、命名、移动等操作

显示日志(Show log)

通过此功能可以查到谁,什么时候,对那个目录下的那些文件进行了那些操作

版本库浏览(Repo-browser)

此功能是用来浏览需要查看的资料库,在本地文件夹下点击右键,选择TortoiseSVN Repo-browser,在弹出的对话框中输入资料库地址,再输入用户名和密码,就能查看到你需要查看到版本库的内容,在这你还能看到那些文件被谁锁定了

创建分支合并相互操作

提取主干上的代码

点击trunk -> 右键SVN Checkout -> 弹出对话框中输入版本库URL -> 点击OK按钮可以在主干上把代码从远程服务器上获取到

新建分支

右键trunk -> 选择Branch/Tag -> 指明新分支的路径 -> 点击OK按钮可以在VisualSVN Server上新增分支

合并分支到主干上

右键trunk -> 选择TortoiseSVN -> Merge -> 弹出窗口中选择Merge two different trees -> 分别输入主干上和分支下的URL地址 -> 点击Merge按钮

合并主干到分支

右键分支 -> 选择TortoiseSVN -> Merge -> 弹出窗口中选择Merge two different trees -> 分别输入分支上和主干下的URL地址 -> 点击Merge按钮

参考方案

  1. SVN百度百科