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,&joe hquGroup = zhangsan,lisi # [/foo/bar] # harry = rw # &joe = r # * = [/] @hquGroup = rw wangwu = 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隐藏目录和里面的文件!!! 否则将会导致你本地的工作拷贝 (静态视图)被破坏,无法再进行操作。
学习笔记_TortoiseSVN使用