首页 > 代码库 > 学习笔记_TortoiseSVN使用

学习笔记_TortoiseSVN使用

TortoiseSVN是Subversion版本控制系统的一个免费开源客户端,不需要为使用它而付费。


TortoiseSVN是 Subversion 的 Windows 扩展。它使你避免接触 Subversion 枯燥而且不方便的 Command Line。它完全嵌入 Windows Explorer,使用时只需在正常的窗口里右键操作就可以了。


Tortoisesvn下载安装

 文章包含被禁用的url,无法保存和发布。 

我们安装版本TortoiseSVN-1.6.6.17493-win32-svn-1.6.6.msi

在服务器上创建仓库:
手动创建目录C:\repository\svn\test


创建成功,和用命令创建的一样

如下:


创建客户端:
创建目录C:\client\zhangshan  (记得启动SVN服务)
进入该目录,右击→SVN Checkout 填写URL:svn://localhost/test →OK

创建成功,新建a.java,将a.java纳入版本控制:右击a.java→TortoiseSVN→Add..

设置权限:

修改:C:\repository\svn\test\conf\svnserve.conf
12,13 行 
anon-access = read
auth-access = write
20行:password-db = passwd
27行:authz-db = authz

修改C:\repository\svn\test\conf\passwd 
添加:相当分配三个帐号

zhangsan = 123
lisi = 123
wangwu = 123

修改C:\repository\svn\test\conf\authz
添加两段:

最好手动修改不要复制,复制有时候会有问题可能是格式之类的;

[groups]# harry_and_sally = harry,sally# harry_sally_and_joe = harry,sally,&joehquGroup = zhangsan,lisi# [/foo/bar]# harry = rw# &joe = r# * =[/]@hquGroup = rwwangwu = rw * =
@hquGroup = rw   #组前面用@不然会被当成人
 * =     #除了以上的人剩下的是*没有任何权限

提交:右击commit,填写messages;输入用户名密码 zhangsan 123 提交成功;


李四也可以同样操作;
第一次使用 右击checkout
新建一个b.java  纳入版本控制 提交;


第二天张三来了使用update;如果只更新一个,选中它右击update即可;提交选中的也可以;

导入文件结构:
新建文件夹test,在test新新建doc和src,右击tset TortoiseSVN→Import,将当前的test结构导入到SVN服务器上;

 
权限控制:
 
修改C:\repository\svn\test\conf\authz
[/]
@hquGroup = rw
wangwu = rw
 * =
zhangsan,lisi对doc文件夹有读的权限没有写的权限:
[/doc]
@hquGroup = r
wangwu = rw
 * =
王五对src文件夹有读的权限没有写的权限:
[/doc]
@hquGroup = rw
wangwu = r
 * =


问题:张三的修改a.java 的时候 李四也在修改a.java 导致冲突
张三修改完a.java, 提交,李四也修改完a.java提交报错:
说a.java已过时,要先update;李四update后冲突
冲突后产生如下:

a.java.mine是自己写的(李四)
a.java.r3 是没更新也没修改之前的
a.java.r4 是张三写的
a.java 是张三李四写的处理后的

解决办法:
编辑冲突



第一和第二个都是以自己为本覆盖,三四个 是整合一起,一般使用三四选项
修改完,保存
右击a.java标记已解决 右击a.java→TortoiseSVN→Resolved...

然后就可以了,两个人写的代码就整合到一起了,然后李四这里在提交就可以了


百分百避免冲突:
锁定:
右击要设置的文件 右击a.java TortoiseSVN→Properties→New Property name:svn:needs-lock Property valu:true,
右击提交;
这样a.java 修改不了,要修改要get lock,张三get lock后 没有提交,李四不能操作a.java 不能get lock;要张三gen lock后修改完提交以后,别人才可以操作a.java;这样就肯定不会冲突了;

释放锁  拿到锁后,选中右击TortoiseSVN→Release lock

解锁 右击a.java TortoiseSVN→Properties Remove

这个方法在实际开发中不常用,导致效率低; 

导出:项目做完了,里面有很多原信息文件.svn ..,我们右击桌面TortoiseSVN→Reop-browser选择数据仓库,登陆,右击左边的数据仓库 Export选择要导出到的文件夹 OK,倒出来的就是我们最终的代码;

Tortoisesvn图标介绍


恢复版本:
在客户端目录 右击 TortoiseSVN→Update to revision… Show log可以查看版本选择要恢复的OK就可以,右击TortoiseSVN→Export . 选择路径 就可以导出,执行update恢复到最新坂本;


注意:.svn这个隐藏目录记录着两项关键的信息: 工作文件的基准版本和一个本地副本最后更新的时间戳。千万不要手工修改或删除这个 .svn隐藏目录和里面的文件!!! 否则将会导致你本地的工作拷贝 (静态视图)被破坏,无法再进行操作。