svn如何安装,svn如何配置,svn安装配置

svn(subversion)是近年来崛起的版本管理工具,是cvs的接班人。目前,绝大多数开源软件都使用svn作为代码版本管理软件。如何快速建立Subversion服务器,并且在项目中使用起来,这是大家最关心的问题,与CVS相比,Subversion有更多的选择,也更加的容易,几个命令就可以建立一套服务器环境,

本文是使用Subversion最快速的教程,在最短的时间里帮助您建立起一套可用的服务器环境,只需略加调整就可以应用到实际项目当中。 
本教程分为以下几个部分,为了说明简单,教程是在windows下使用的方式,以方便资源有限的项目使用。在UNIX环境下,只是安装方式不同,命令执行并无太大区别。




软件下载

<1>、下载Subversion服务器程序

下载链接: 点击打开链接  

到官方网站的下载二进制安装文件,来到二进制包下载部分,找到 Windows(在最下面),一般选择都是最后一个Win32SVN,目前可以下载Setup-Subversion-1.8.3.msi

<2>、下载Subversion的Windows客户端TortoiseSVN。

下载链接:点击打开链接

TortoiseSVN是扩展Windows Shell的一套工具,可以看作Windows资源管理器的插件,安装之后Windows就可以识别Subversion的工作目录。

官方网站是TortoiseSVN ,下载方式和前面的svn服务器类似,在Download页面的我们可以选择下载的版本(注意需要与使用的svn版本对应),目前的最高稳定版本的安装文件为TortoiseSVN-1.8.2.24708-win32-svn-1.8.3.msi


svn服务器和客户端安装

<1>、安装Subversion,直接运行Setup-Subversion-1.8.3.msi ,根据提示安装即可,这样我们就有了一套服务器可以运行的环境

         安装完成之后,需要将Subversion添加到path路径下,本人笔记本,

          我的电脑-->邮件-->属性-->系统保护-->高级-->环境变量-->找到path-->将svn添加到path路径下

          D:\svn\subversion\bin(类似于这种路径)
<2>、安装TortoiseSVN,同样直接运行TortoiseSVN-1.5.5.14361-win32-svn-1.5.4.msi按照提示安装即可,不过最后完成后会提示是否重启,其实重启只是使svn工作拷贝在windows中的特殊样式生效,与所有的实际功能无关,这里为了立刻看到好的效果,还是重新启动机器

<3>、安装svn的客户端程序,需要的话还可以安装svn的语言包,注意语言包的版本也必须与客户端程序的版本一致

下载链接:点击打开链接

        第四个为中文简体


建立版本库(Repository)

<1>、启动svn

本人根目录为D:\svn\root


<2>、建立一个版本库(Repository),可以看作服务器上存放数据的数据库

           svnadmin create D:\svn\root\oa

           就会在目录D:\svn\root下创建一个版本库。:一个版本库(工厂)对应一个项目

         我们也可以使用TortoiseSVN图形化的完成这一步: 
         在目录D:\svn\root下"右键->TortoiseSVN->Create Repository here...“, 然后可以选择版本库模式, 这里使用默 认 即可, 然后就创建了一系列目录和文件。

svn如何安装,svn如何配置,svn安装配置

---------

SVN配置用户和权限


来到D:\svn\root\conf目录,修改svnserve.conf:

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

然后修改同目录的passwd文件,去掉下面三行的注释: 
# [users] 
# harry = harryssecret 
# sally = sallyssecret 
最后变成: 
[users] 
harry = harryssecret 
sally = sallyssecret

在passwd文件中,“=”前的字符就是用户名,后面的就是密码。还要注意“[users]”前面的注释“#”一定要删除掉。

初始化导入

来到我们想要导入的项目根目录,在这个例子里是E:\svndemo\initproject,目录下有一个readme.txt文件:

右键->TortoiseSVN->Import... 
在URL of repository输入“svn://localhost/trunk” 
在Import Message中输入你的日志信息

完成之后目录没有任何变化,如果没有报错,数据就已经全部导入到了我们刚才定义的版本库中。

需要注意的是,这一步操作可以完全在另一台安装了TortoiseSVN的主机上进行。例如运行svnserve的主机的IP是133.96.121.22,则URL部分输入的内容就是“svn://133.96.121.22/trunk”。


基本客户端操作

取出版本库到一个工作拷贝:

来到任意空目录下,在本例中是E:\svndemo\wc1,运行右键->Checkout,在URL of repository中输入svn://localhost/trunk,这样我们就得到了一份工作拷贝。

在工作拷贝中作出修改并提交: 

打开readme.txt,作出修改,然后右键->Commit...,这样我们就把修改提交到了版本库,我们可以运行。

察看所作的修改: 

readme.txt上右键->TortoiseSVN->Show Log,这样我们就可以看到我们对这个文件所有的提交。在版本1上右键->Compare with working copy,我们可以比较工作拷贝的文件和版本1的区别。

最后,所有的内容都已经录制为动画文件,大家可以参考。

关于本教程大家有什么意见,可以这里讨论 。

如果更新文件以后,有两个人或者多个人同时修改了某个文件的某个位置,是否冲突,(一般不会这样子,因为上传的版本是可以编译通过的,而且每个人负责自己的模块,不会多人独立修改同一个文件,别人也是先更新,后上传修改,,,,)

开发者习惯性动作。早上上班第一件事就是更新svn版本库,再开始一天的工作。

晚上下班,或者其他时候要上传东西可以直接上传因为你负责的东西没人去修改。

冲突是怎么产生的呢:因为不同的人,同时修改了同一个文件的同一个地方,这个时候,他提交了,你没有提交,你就提交不了,这个时候,你要先更新,更新就会出现代码冲突问题。最好不要多人同时修改一个文件,公用的文件,更改之前要和大家沟通一下,或者解决冲突 呵呵

先更新,没有冲突,再提交。有冲突,解决冲突再提交。否则也提交不了。

对于一些处于冲突状态下的文件 ,右键TortoiseSVN ->Resolved,解决冲突。解决冲突: http://www.blogjava.net/jasmine214--love/archive/2011/04/07/347769.html

更新-解决冲突-删掉以下三个文件-提交(如果自己没有修改的文件有冲突,删除再更新即可,自己修改的文件解决冲突)

test.php.mine   是冲突前自己的文件

test.php.版本号   是冲突前本地的版本文件

test.php.服务器的版本号   是冲突后服务器版本文件

注意事项

  • 如果修改文件后提交不了,大多是因为版本不一致造成的。更新一下,不产生冲突的情况,就可以提交了。

  • 更新文件,如果出现冲突的情况,打开冲突文件test.php会看到类似以下的内容

    <<<<<<<<<<<<<<<
    asdfadfadfadf
    11111111111111
    =======
    asdfadfadfadf
    111111111111111
    222222222222
    >>>>>>>>>>>>>>>>

    结合别人修改的内容和自己修改的内容,然后把文件中的<<<<<,=====,>>>>>>>这类冲突符号去掉。去掉后,还是不能提交的,为什么?因为冲突时会产生三个文件,有这三个文件存在肯定提交不了。

    客户端用的tortoisesvn(这个估计程序员用的最多),冲突时会多产生,三个文件

    test.php.mine   是冲突前自己的文件

    test.php.版本号   是冲突前本地的版本文件

    test.php.服务器的版本号   是冲突后服务器版本文件

    提交的时候,把这三个文件删除掉就可以提交了。


  • 产生覆盖的原因。

    a),在修改冲突文件test.php时,把别人代码都删除掉了,只留下了自己的代码。这样就会产生覆盖了。

    b),把test.php.mine中的内容直接copy到test.php文件,这样也会产生代码覆盖。

    上面二种情况都是我亲眼看到新手这样操作的,要避免这二种操作方法。



         
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值