当前位置: 首页 > news >正文

Subversion+TortoiseSVN 版本控制

http://www.subversion.org.cn/svnbook/1.1/index.html

http://hi.baidu.com/yljf184/blog/item/c6d73818548e110f34fa41c6.html

 

1.下载所需程序
Subversion 1.3.2http://subversion.tigris.org/downloads/subversion-1.3.2.zip
TortoiseSVNhttp://tortoisesvn.sourceforge.net/downloads
2.安装(路径可以更改)解压subversion-1.3.2.zip并安装到C:\Subversion,同时安装TortoiseSVN

3.建立资料库(Repository)
在C盘或其他盘下建立文件夹RepositorySVN,这个文件夹用于保存所有你建立的资料库,
在ProjectSVN下建立一个子文件夹SampleRepository,然后在SampleRepository为咱们的例子创建一个资料库
创建方法是:SampleRepository下点击右键,选择TortoiseSVN->Create Repository here..然后选择Native filesystem(FSFS)
在URL of Repsitory中填入file:///C:/RepositorySVN/SampleRepository,注意file:后是三个///

或者 svn://localhost/SampleRepository

4.配置用户和权限
到刚才建立资料库下的C:\ProjectSVN\Sample\conf,修改svnserve.conf

‍# [general]
# password-db = passwd
改为:
[general]
password-db = passwd

然后修改同目录的passwd文件
# [users]
# harry = harryssecret
# sally = sallyssecret
改成
[users]
harry = harryssecret
sally = sallyssecret
其中左侧是用户名,右侧是密码
如果你还想加新的用户名和密码,可以在新的一行中创建,如:username = password

6.启动服务
当Subversion安装成功后,它已经加入到了path中,所以下面打开运行cmd,并输入如下命令启动Subversion服务,这样客户端就可以访问了

svnserve --daemon --rootC:\RepositorySVN
服务启动,--daemon可简写为-d,--root可简写为-r,不要关闭,否则以后导入不了.可以建立一个批处理文件并放在windows启动组中便于开机就运行SVN服务,或者下载那个svnservice.exe文件,拷贝到[Subversion安装目录\bin]目录下,再从命令行下执行:

svnservice -install --daemon --root "C:\RepositorySVN"
sc config svnservice start= auto
net start svnservice

此文件会将SVN变成windows系统的一个服务,并默认为自启动,注意:执行第三句时确保前面以命令行方式运行的SVN服务已经停止,如果没停止可在其窗口中按Ctrl+C中止运行。

其中在命令末尾加上C:\RepositorySVN是为了告诉svn我们的资料库都放在了什么地方,加上这个很重要,否则客户端可能会报找不到资料库的错误

7、客户端TortoiseSVN

点击右键并选择SVN CheckOut...这样就可以将资料从服务器端checkout了,如果访问的是一个有密码的资料库,还会要求输入用户名和密码

 

8、设置及备份

可在仓库中添加自己需要创建的版本库文件,checkout,将源文件夹文件全部移动到checkout的文件夹,然后再从该文件夹中选取需要做版本控制的文件。

添加需版本控制的文件(也可以远程,只需url为ip就行),在硬盘上任意位置,右键需要上传的文件的上级文件夹,TortoiseSVN->Import…

1)完全备份

最常见和简单的备份就是直接使用拷贝命令,将版本库目录拷贝到备份目录上,就可以了。但是这样不是很安全的方式,因为如果在拷贝时版本库发生变化,将会造成备份的结果不够准确,失去备份的作用,为此Subversion提供了“svnadminhotcopy”命令,可以防止这种问题。

还记得我们的版本库目录吗?

D:\SVNROOT
├─project1
│ ├─conf
│ ├─dav
│ ├─db
│ │ ├─revprops
│ │ ├─revs
│ │ └─transactions
│ ├─hooks
│ └─locks
└─project2
├─conf
├─dav
├─db
│ ├─revprops
│ ├─revs
│ └─transactions
├─hooks
└─locks
如果要把project1备份到d:\svnrootbak目录下,只需要运行:

svnadmin hotcopy d:\svnroot\project1 d:\svnrootbak\project1--clean-logs

//--clean-logs 选项并不必须,但是通过删除BDB版本库中多余的日志文件可以节省一些空间。

但是我们作为配置管理员,必须想办法优化这个过程,如果我们这个目录下有许多版本库,需要为每个版本库写这样一条语句备份,为此我写了下面的脚本,实现备份一个目录下的所有版本库。我们在D:\SVNROOT下创建了两个文件,simpleBackup.bat:

@echo off
@echo 正在备份版本库%1......
@%SVN_HOME%\bin\svnadmin hotcopy %1 %BACKUP_DIRECTORY%\%2
goto clean%ERRORLEVEL%

:clean0
@echo 版本库%1成功备份到了%2!
del /Q %BACKUP_SVN_ROOT%\delta\%2.dump
goto end

:clean1
echo Program had return code 1
goto end

:end

这个文件仅仅是对“svnadmin hotcopy”的包装,然后是backup.bat:

echo off
rem Subversion的安装目录
set SVN_HOME="D:\Subversion"

rem 所有版本库的父目录
set SVN_ROOT=D:\svnroot

rem 备份的目录
set BACKUP_SVN_ROOT=D:\svnrootbak

set BACKUP_DIRECTORY=%BACKUP_SVN_ROOT%\%date:~0,10%
if exist %BACKUP_DIRECTORY% goto checkBack
echo 建立备份目录%BACKUP_DIRECTORY%>>%SVN_ROOT%/backup.log

mkdir %BACKUP_DIRECTORY%

rem 验证目录是否为版本库,如果是则取出名称备份
for /r %SVN_ROOT% %%I in (.) do @if exist "%%I\conf\svnserve.conf" %SVN_ROOT%\simpleBackup.bat "%%~fI" %%~nI
goto end

:checkBack
echo 备份目录%BACKUP_DIRECTORY%已经存在,请清空。
goto end

:end


rem at 15:10 /every:M D:\svnroot\backup.bat

你在使用的时候,只需要修改backup.bat开头的三个路径,将两个脚本拷贝到“SVN_ROOT”下就可以了。根据以上的配置,你只需要运行backup.bat,就可以把“SVN_ROOT”下的版本库都备份到“BACKUP_SVN_ROOT”里,并且存放在备份所在日的目录里,例如“D:\svnrootbak\2006-10-22”。

虽然这部分工作很简单,可是必须有人定时地去执行这个操作(例如每周一凌晨),为了避免发生遗忘的情况,我们可以将这个操作加入到系统的at任务当中去,例如还是上面的环境,为了安装at任务,我们运行:

at1:00/every:M D:\svnroot\backup.bat

这样在每周一凌晨1:00都会执行这个备份过程。当然备份在本机也是不安全的,你也许需要上传到别的机器,这个就要靠你自己去实现了。

(2)增量备份

尽管完全备份非常简单,但是也是有代价的,当版本库非常巨大时,经常进行完全备份是不现实的,也并不必要,但是一旦版本库在备份之间发生问题,该如何呢,这里我们就用到了增量备份。

增量备份通常要与完全备份结合使用,就像oracle数据库的归档日志,记录着每次Subversion提交的变化,然后在需要恢复时能够回到最新的可用状态。在我们这个例子中我们使用的是,svnadmin dump命令进行增量的备份,使用方法是:

svnadmin dump project1 --revision 15 --incremental > dumpfile2

上面的命令实现了对修订版本15进行增量的备份,其中的输出文件dumpfile2只保存了修订版本15更改的内容。

为了记录每次提交的结果,我们需要使用一项Subversion的特性--钩子(hook),看看我们的project1目录:

├─project1
│ ├─conf
│ ├─dav
│ ├─db
│ │ ├─revprops
│ │ ├─revs
│ │ └─transactions
│ ├─hooks
│ └─locks

其中的hooks目录里存放的就是钩子脚本,我们在此处只使用post-commit钩子,这个钩子会在每次提交之后执行,为了实现我们的备份功能,我们在hooks下建立一个文件post-commit.bat,内容如下:

echo off
set SVN_HOME="C:\Program Files\Subversion"
set SVN_ROOT=D:\svnroot
set UNIX_SVN_ROOT=D:/svnroot
set DELTA_BACKUP_SVN_ROOT=D:\svnrootbak\deltaset LOG_FILE=%1\backup.log
echo backup revision %2 >> %LOG_FILE%for /r %SVN_ROOT% %%I in (.) do if D:/svnroot/%%~nI == %1 %SVN_ROOT%\%%~nI\hooks\deltaBackup.bat %%~nI %2
goto end:end

通过这个脚本,可以实现D:\svnroot下的版本库提交时自动增量备份到D:\svnrootbak\delta(确定这个目录存在),其中使用的deltaBackup.bat其实可以放在任何地方,只是对脚本的svnadmin dump的包装,内容如下:

@echo 正在备份版本库%2......
%SVN_HOME%\bin\svnadmin dump %SVN_ROOT%\%1 --incremental --revision %2 >> %DELTA_BACKUP_SVN_ROOT%\%1.dump
@echo 版本库%2成功备份到了%3!

以上两个脚本可以直接拷贝到project2的hooks目录下,不需要修改就可以实现project2的自动备份。

以上的操作已经OK了,现在需要做的是将完全备份和增量备份结合起来,也就是在完全备份后清理增量备份的结果,使之只保存完全备份后的结果。

当果真出现版本库的故障,就要求我们实现版本库的恢复操作了,这是用要使用svnadmin load命令,同时也需要上次的完全备份例如要把上次完全备份backuprepo,和之后的增量备份dumpfile:

svnadmin load backuprepo < dumpfile

最后的结果,可以下载svnroot.rar,将之解压缩到d:\下,然后修改几个bat文件的SVN_HOME就可以使用了。

(3)版本库同步

Subversion 1.4增加了同步机制,可以实现一个版本库同另一个版本库的同步(但好像只是单向的),我们可以用来实现版本库的备份或镜像。

3.1. 对目标库初始化svnsync init svn://localhost/project2 svn://localhost/project1

其中project2是目标的版本库,而project1是源版本库。其中的目标版本库必须为空,而且必须允许修订版本属性的修改,也就是在目标的版本库的hooks目录里添加一个文件pre-revprop-change.bat,内容为空即可。

 

3.2. 同步project2到project1svnsync sync svn://localhost/project2

这时候你update一下你的project2的一个工作拷贝,就会发现有了project1的所有内容。如果project1又有提交,这时候project2的版本库无法看到最新的变化,还需要再运行一遍sync操作,这样才能将最新的变化同步。需要注意的是,目标版本库只能做成只读的,如果目标版本库发生了变更,则无法继续同步了。

 

3.3. 同步历史属性的修改

因为同步不会更新对历史属性的修改,所以svnsync还有子命令copy-revprops,可以同步某个版本的属性。

 

3.4. 钩子自动同步

希望在每次提交时同步,则需要在源版本库增加post-commit脚本,内容如下:

echooff
set SVN_HOME="D:\Subversion"
%SVN_HOME%\bin\svnsync sync --non-interactive svn://localhost/project2

把以上内容存放为post-commit.bat,然后放到版本库project1下的hooks目录下,这样project1每次提交,都会引起project2的同步。

 

9)如何去除文件夹的svn属性

Windows Registry Editor Version 5.00
[HKEY_LOCAL_MACHINE\SOFTWARE\Classes\Folder\shell\DeleteSVN]
@="Delete SVN Folders"
[HKEY_LOCAL_MACHINE\SOFTWARE\Classes\Folder\shell\DeleteSVN\command]
@="cmd.exe /c \"TITLE Removing SVN Folders in %1 && COLOR 9A && FOR /r \"%1\" %%f IN (.svn) DO RD /s /q \"%%f\" \""

复制以上代码到文本文件重命名为svn.reg,导入到注册表中,然后右键就会出现 delete svn folders . 选择delete svn folders就可以了。文件夹就变为普通的文件夹了。

 

 

相关文章:

  • 使用 UNIX 的 10 个良好习惯
  • vmstat参数说明
  • KDE致力于发展Wayland和Frameworks 5.0
  • about jni
  • poj1978
  • 从高朋裁员说起——山寨,不是创新的“中国模式”
  • linux系统下查看硬件信息
  • 领域驱动设计和实践
  • Windows 7的预备知识系列之一:Windows 7启动与停止
  • C#后台,执行前台js 脚本
  • VMware vCenter 添加ESX(i)宿主机
  • 美国人的婚姻方式
  • 软件设计:“度”、“裁剪”与“变通”
  • mantis 汉化的有效方法
  • windows 2003活动目录如何选择dns类型
  • android百种动画侧滑库、步骤视图、TextView效果、社交、搜房、K线图等源码
  • Flannel解读
  • JavaScript异步流程控制的前世今生
  • JS 面试题总结
  • magento2项目上线注意事项
  • Mysql优化
  • node 版本过低
  • php ci框架整合银盛支付
  • React-Native - 收藏集 - 掘金
  • webpack入门学习手记(二)
  • weex踩坑之旅第一弹 ~ 搭建具有入口文件的weex脚手架
  • 第十八天-企业应用架构模式-基本模式
  • 复杂数据处理
  • 汉诺塔算法
  • 前端存储 - localStorage
  • 一个完整Java Web项目背后的密码
  • 译自由幺半群
  • 赢得Docker挑战最佳实践
  • 硬币翻转问题,区间操作
  • 用Visual Studio开发以太坊智能合约
  • UI设计初学者应该如何入门?
  • 阿里云服务器如何修改远程端口?
  • ​什么是bug?bug的源头在哪里?
  • #13 yum、编译安装与sed命令的使用
  • (145)光线追踪距离场柔和阴影
  • (2020)Java后端开发----(面试题和笔试题)
  • (C#)Windows Shell 外壳编程系列4 - 上下文菜单(iContextMenu)(二)嵌入菜单和执行命令...
  • (C语言)求出1,2,5三个数不同个数组合为100的组合个数
  • (zz)子曾经曰过:先有司,赦小过,举贤才
  • (第27天)Oracle 数据泵转换分区表
  • (含react-draggable库以及相关BUG如何解决)固定在左上方某盒子内(如按钮)添加可拖动功能,使用react hook语法实现
  • (转)Android学习笔记 --- android任务栈和启动模式
  • (转)mysql使用Navicat 导出和导入数据库
  • ./configure、make、make install 命令
  • ./和../以及/和~之间的区别
  • .mysql secret在哪_MySQL如何使用索引
  • .NET Micro Framework 4.2 beta 源码探析
  • .net on S60 ---- Net60 1.1发布 支持VS2008以及新的特性
  • .NET Remoting Basic(10)-创建不同宿主的客户端与服务器端
  • .net 打包工具_pyinstaller打包的exe太大?你需要站在巨人的肩膀上-VC++才是王道