svn教程,win7系统使用Subversion搭建SVN服务器的方法
svn教程,win7系统使用Subversion搭建SVN服务器的方法详细介绍
本文目录一览: 公司新人svn使用教程
公司新人svn使用教程如下:1。如果使用命令行,则拉取分支是SVNcopy。2.对于TortoiseSVN的客户端,右击源文件夹,在右击菜单中选择TortoiseSVN-“分支/标记”,在弹出窗口的“toURL”列中填写分支存储路径,然后确认。3.还有一种简单的方法可以在tortoisesvn客户机中提取分支。右键单击源文件夹,不要释放鼠标,将其拖到存储分支的文件夹中,释放鼠标,将出现菜单。在菜单中,选择“SVN将版本控制项复制到当前位置”。创建分支:1。您可以浏览TortoiseSVNpoint版本库,然后在需要创建分支的路径(例如trunk)中单击“复制到新分支名称”(注意:它不能与trunk同名,您可以创建一个新名称,例如branch)。2浏览TortoiseSVNpoint版本库,右键单击TortoiseSVN并选择createfolder,然后创建一个新的路径名(folder),并将主干或其他分支路径(在本例中,估计您希望并行开发)的代码导入该路径。
svn使用教程是什么?
分支在SVN中一点都不特别,其实它就是版本库中的另外一个目录。sVN是按文件:所有的资源控制系统都是把文件的元信息隐藏在一个类似。svn、cvs等的文件夹里。SVN有:目前为止这是跟SVN相比Git缺少的最大的一个特征。
将svnserve.conf中的#
authz-db=authz
和#password-db
=passwd的‘#’号去掉且前面不能存在空格。
应用途径:
SVN服务器既具有CVS所具有数据储存的优点,像是信息资源存储后会形成资源树结构,便于存储的同时,数据一般不会丢失,同时又拥有自己的特色。SVN是通过关系数据库及二进制的存储方式,同时解决了既往不能同时读写同一文件等问题,同时增添了自己特有的“零或一”原则。
以上内容参考:百度百科-版本控制
以上内容参考:百度百科-SVN
win7系统怎么安装SVN win7系统安装SVN的方法
SVN是Subversion的简称,是一个开放源代码的版本控制系统。在开发过程中,一个项目可能有好几人一起来开发,这个时候我们需要同步代码,就会用到SVN,那么如何在win7纯净版系统中安装SVN呢?下面小编和大家分享win7系统安装SVN的方法。具体方法如下:1、现在百度搜索svn并且下载;2、下载完成会在下载的目录得到一个软件双击并安装;3、安装完成以后鼠标右键在下面会出现两个选项;4、点击设置去选择语言,发现只有英文没有别的语言;5、这个时候我下载个语言包,并安装;6、安装完成以后再鼠标右键,发现下面两个选项,变成中文;7、这个再点击设置都变成中文。上述教程内容就是win7系统安装SVN的方法,有需要的用户可参考本教程安装,希望能够帮助到大家。
win10系统如何安装TortoiseSVN?Windows10安装TortoiseSVN教程
TortoiseSVN作为Subversion版本控制系统的一个免费开源客户端,一直深受着广大用户的喜爱。那么,在全新的win10操作系统中,我们该如何安装SVN客户端呢?下面,小编就为大家分享下具体操作方法吧!推荐:最新Windows10系统下载具体方法如下:1、我们百度搜TortoiseSVN就可以找到相应的资源了。2、TortoiseSVN文件保存在中央版本库,除了能记住文件和目录的每次修改以外,版本库非常像普通的文件服务器。我们找到百度资源后进入下载,下载好了可以我的下载中找到相的安装文件3、我们找开安装文包,进行TortoiseSVN的安装。首先他会告诉我们,我们安装的是什么版本,如我这里的就是安装的是64位的,版本是号多少,等信息,我们可以看一下是否跟我们的系统相符。相符就点下一步。4、这里是提示我们是否同意安装协议,这个没商量,我们点不同意就安装不了,必须点同意才可以安装。同意是上边那个选项。如图,点击后下一步,继续安装。5、接下来就是选择安装项目了,这里通常都有几个默认项,个人建议就不用动了。如果你清楚这里的每一项是什么,你也可以选择这几项不装。反正我是如图上这样的安装了。6、接下就是进入安装页面了。我们点击安装,就开始安装了,这个是自动安装的,我们也不需要操作。SVN(Subversion)作为CVS的重写版和改进版,其目标就是作为一个更好的版本控制软件,取代CVS.总的来说,CVS在发展的过程中逐渐失去优势,已经不再适合现代开发,目前,绝大多数CVS服务已经改用SVN.7、最后就是安装完成了,我们安装好了后,会提示完成了。安装完成后就可以进行很好的版本控制使用拉。版本控制是管理信息修改的艺术,它一直是程序员最重要的工具,程序员经常会花时间作出小的修改,然后又在某一天取消了这些修改,想象一下一个开发者并行工作的团队-或许是同时工作在同一个文件!-你就会明白为什么一个好的系统需要管理潜在的混乱。以上就是Windows10安装TortoiseSVN的具体方法介绍了。升级完win10系统后,想要直接体验SVN客户端的用户,赶紧试着操作看看吧!
win7系统使用Subversion搭建SVN服务器的方法
SVN是程序员常用的一款软件,它可以很好的帮助程序员进行版本控制以及代码管理,通常的SVN服务器是搭建在Linux等系统下进行的。但是今天小编分享一种在win7操作系统使用Subversion搭建SVN服务器的方法,而且设置方法也比较简单,感兴趣或有需要的用户可以一起参考下面教程进行设置体验。具体方法如下:1、首先来下载和搭建SVN服务器,进入网址后;2、点开上面红色框标记的VisualSVN连接,下载VisualSVNserver,下载完成后双击安装;3、点击Next下一步;4、然后再点击Next项,下一步;5、选择“标准版本”,点击【Next】如下;6、选择安装路径,服务器端文件存放位置,默认端口号(Location是指VisualSVNServer的安装目录,Repositorys是指定你的版本库目录.ServerPort指定一个端口,Usesecureconnection勾山表示使用安全连接),点击Next,进入下一步;7、准备安装,点击Install,进入下一步;8、等待安装;9、完成后,点击【next】,进入下一步;10、点击【Finish】即可完成安装。安装完成后,启动VisualSVNServerManage;11、可以在窗口的右边看到版本库的一些信息,比如状态,日志,用户认证,版本库等.要建立版本库,需要右键单击左边窗口的Repositores;12、在弹出的右键菜单中选择CreateNewRepository或者新建-Repository;13、键入对象库名称后,进入下一步;14、选择”空的对象库“,进入下一步;15、设置对象库的权限,点击【create】;16、点击【Finish】即可完成基本创建。上述就是win7系统使用Subversion搭建SVN服务器的方法,有需要的用户可以掌握。
详细使用TortoiseSVN的步骤
TortoiseSVN是一个SVN的客户端,下面是我以前不知道从哪复制的大致使用,希望对你有用:
五.客户端的使用
1.Checkout Repository
首先要Checkout服务器端的Repository,
所谓的Checkout就是指获得服务器端指定的Repository存储的所有文件。
这个Checkout和Visual Source Safe的Checkout意义完全不一样,
VSS的Checkout指的是锁定某个文件,如果你以前使用过VSS,
在学习Subversion时这个问题一定要注意。
Checkout的具体方式是:
在客户端新建一个空目录,比如:F:\Project1
在该目录上单击右键,在弹出式菜单中选中SVN Checkout...,
之后在“URL of Repository”文本框中填入你想要连接的Repository的地址,
这个URL地址可以用浏览方式加入。
对于在本教程第二节建立的Repository,
URL应该是“svn://xxx/project1”
(xxx可以是服务器端主机名,也可以是服务器端的ip地址)。
然后点OK,会弹出一个认证对话框,
输入在教程第三节设置的用户名和密码。
点OK后就完成了对Repository的Checkout。
比如:在服务器端Repository中有一个a.txt文件,
那么Checkout之后F:\Project1目录下也会出现一个a.txt文件。
在本例中由于服务器端的Repository还未添加任何文件,
所以在客户端的F:\Project1下没有文件被Checkout。
执行Checkout除了会在F:\Project1产生Repository存储的文件及目录外,
还会产生了一个“.svn”的隐含目录,该目录是由subversion管理的,
不要删除或者手工改动其中的文件和目录。
现在F:\Project1中的文件和目录就叫做Repository的“Working Copy”简写“WC”
(这个简写...汗)。
以后对Repository中文件和目录的修改,添加,删除的操作,
都是通过对这个“Working Copy”的操作实现的。
Checkout执行完后,
会发现F:\Project1目录的图标的左下角附着了一个小的状态图标
(当F:\Project1目录中的文件改变时,这个状态图标也会随之变化),
它表示F:\Project1是一个Repository的“Working Copy”,
F:\Project1内的所有文件和目录也会有类似的状态图标。
2.添加文件
将要添加的文件或者目录拷贝到F:\Project1下,
然后在该文件或目录上单击右键,TortoiseSVN->Add,点OK。
如果添加了不止一个文件或目录,
则鼠标不要在F:\Project1中点中任何文件,
然后单击右键,TortoiseSVN->Add,
就可以添加多个文件或目录。
这时文件的状态图标会发生变化。
Add命令只是告诉本地的“Working Copy”将该文件纳入版本管理,
并没有将这个改变提交到服务器端,
如果想要别人也看见你对Repository的修改,你需要
在F:\Project1下单击右键,SVN Commit...,
将你所做的修改提交到Repository。
文件的状态图标也会更新。
不管你在“Working Copy”内添加、修改、删除文件后,
要想其他人也看见你的修改,
都必须用Commit命令将所做修改递交到服务器端的Repository。
3.修改文件
用文本编辑器或IDE对文件修改后,
文件的状态图标会变化,
然后单击右键,SVN Commit...
提交修改,只有当执行Commit提交修改后,
你所作的修改才会反映到服务器端的Repository中。
4.删除文件
删除文件时,选中要删除的文件或目录,
单击右键,TortoiseSVN->Delete,提交修改。
注意千万不要用“Delete”键来删除文件,否则将无法提交你的修改。
这一点对目录的删除来说尤为重要。
5.放弃修改
当你添加、修改、删除文件后,决定放弃修改,
你可以单击右键,TortoiseSVN->Revert,
本地的“Working Copy”中的文件和目录会恢复到你修改前的状态。
6.获取Repository的最新版本
当一个团队合作开发项目时,
每一个人都在不断的对Repository进行更新,
你需要不断的更新自己的“Working Copy”,
以获取项目最新的文件。
当第一次获得最新Repository的文件时,
我们用Checkout命令,前面已经介绍了,
以后再获取最新文件时就不用Checkout了。
而改用Update命令。
接着前面的例子,这时F:\Project1已经成为一个“Working Copy”了
(通过执行Checkout命令),现在其他人已经对Repository进行了修改,
我想将别人的修改反映到我的“Working Copy”中,
具体的方法是:在F:\Project1目录上单击右键,
SVN Update。这时F:\Project1中的文件就是最新的版本了。
注意,如果当你的“Working Copy”中有被修改的文件,
或者有被删除的文件,并且还未提交这些修改时,
这些文件在执行Update过程中是不会被更新的。
比如你修改了F:\Project1下a.txt文件,
还未提交修改,那么,
当你对F:\Project1进行Update时,
a.txt文件是不会更新为Repository上的a.txt文件的。
所以如果想放弃当前的所有修改,
并将F:\Project1下所有文件及目录更新到最新版本,
应该先对F:\Project1执行Revert命令再执行Update命令。
7.subversion的版本控制模型
当你用subversion进行版本控制时,
Subversion会记录你对Repository进行的每一次修改(包括添加,修改,删除等等),
每修改一次Repository都会产生一个新的Revision(修订版本号),
不同的Revision代表了不同时刻Repository的状态,
因此我们可以用这个Revision回朔任意时刻Repository的状态,
就像时间机器一样,也就是说某一Revision
就是Repository在某一时刻的一个“快照”。
注意:Revision不是针对某一个文件或者目录,
而是针对整个Repository而言的。
每修改一次Repository,Revision 都会增加1。
Subversion的版本控制模型是一种叫做Copy-Modify-Merge
(拷贝-修改-合并)的模型。
考虑这种情况:
张三和李四是公司同一个部门的同事,
他们共同维护一个文本文件a.txt,
并且对该文件进行版本控制,
因此他们把这个文件放到一个Repository上共同维护该文件。
周一上午9点,张三和李四同时想对a.txt文件进行修改,
于是他们同时从Repository上取得该文件的最新版本(Revision 10),
然后进行修改。过了三分钟,张三首先完成了修改,
他在该文件的第五行修改了一个单词的拼写(将Typo改为Type),
于是张三对修改后的文件执行Commit命令,
将修改提交到服务器端的Repository中。
这时Repository的Revision变为11。
六分钟过后,李四也完成了他的修改,
他修改了该文件第十行上的一个单词拼写(将He改为She),
于是他也对修改后的文件执行Commit命令,
这时Subversion 在提交修改时会发现,
李四修改的文件是Revision10的a.txt文件,
而不是最新的Revision 11的a.txt文件。
于是,Subversion 提示李四在提交修改前,
应该先将Working Copy更新到最新版本,
李四执行Update命令将Working Copy更新到Revision 11,
这时Subversion会提示已经完成合并,
李四的a.txt文件的第五行的“Typo”已经变为了“Type”,
第十行还是“She”,就是说Subversion已经将张三的修改“合并”到李四的a.txt文件中了。
之后,李四再执行Commit命令,就能将他对第十行的修改(将He改为She)
提交到服务器端的Repository中了(生成Revision 12)。
但是这种合并在某些情况下会变得复杂一些,
比如:李四对a.txt文件的修改并不是第十行,
而是与张三同样修改第五行的单词,
李四将“Typo”改为“Typr”,并且提交修改,
这时Subversion会提示李四在提交修改前,
应该先将Working Copy更新到最新版本,
李四执行Update命令将Working Copy更新到Revision 11,
这时Subversion将Revision11的a.txt文件与
李四修改的a.txt文件进行合并时发现李四修改的同样是第五行,
于是Subversion就无法判断是李四的修改(“Tpyr”)
正确还是张三的修改(“Type”)正确,
因为他们都是在Revision10的a.txt基础上作的修改。
这种情况叫做Conflict(冲突),
a.txt文件的图标会变成一个黄色三角。
这时,只能依靠李四自己去判断到底第三行应该修改为“Typr”还是“Type”。
当李四确定修改之后,在a.txt文件上单击右键,TortoiseSVN->Resolved
告诉Subversion已经解决了Conflict。
这时再执行Commit命令就能提交修改(生成Revision 12)。
Subversion 这种控制方式保证了你对文件所作的修改都是基于文件的最新版本。
8.“.svn”目录
在客户端Working Copy的每一层目录中都会有一个“.svn”目录,
该目录是Subversion进行管理用的目录。
不要手动修改其中的文件。
该目录存储了Working Copy的一个副本
(实际存储副本的地方是F:\project1\.svn\text-base目录),
比如:F:\Project1是一个Working Copy,
该目录下有两个文件a.txt和b.txt还有一个子目录ccc,
子目录ccc中还有一个d.txt文件。
“.svn”目录中存储的是你最近一次执行完Update或者Commit命令之后当前目录中文件的副本,
比如:F:\project1\.svn\text-base中存储的a.txt和b.txt
是最近一次执行完Update或者Commit命令之后F:\project1下的a.txt和b.txt的拷贝。
也就是说你所作的修改都是基于“.svn”目录存储的那些文件。
这种机制可以让我们在不连接网络的情况下,
将Working Copy中的文件恢复到修改之前的状态。
Subversion的Revert命令就是利用了这种机制来实现的。
比如你修改了F:\project1\a.txt文件,
这时你又改变了主意想放弃对该文件的修改,
你可以单击右键,TortoiseSVN->Revert,
修改过的F:\project1\a.txt文件
就会被F:\project1\.svn\text-base中a.txt文件的副本所替代,
使得a.txt恢复到修改前的状态。
Working Copy中每一个子目录下都会有一个“.svn”目录,
并不是只有最上层目录才有“.svn”目录。
所以,F:\project1\ccc下也有一个“.svn”目录,
该目录存储的是F:\project1\ccc\d.txt的副本
(d.txt的副本位于F:\project1\ccc\.svn\text-base)。
也就是说每个“.svn”目录只存储同级目录中的“文件”副本,
而不存储“目录”副本。“.svn”目录存有许多重要的内容,
所以前面说在删除文件或目录时,
必须用TortoiseSVN->Delete,
而不能用“Delete”键来删除文件或目录,尤其是对于目录的删除。
9.混合版本
Subversion的Working Copy被设计成一种能够包含不同版本的文件共存的形式。
比如F:\Project1是一个Working Copy,
该目录下有两个文件a.txt和b.txt。
执行Update命令,将Working Copy更新到最新版本(Revision 24)。
这时,a.txt和b.txt的Revision都是24
(其实对于单个文件来说并不存在Revision,
Revision是对于整个Repository而言的,
这里所指的是Repository的Revision24所存储的a.txt和b.txt,
但为了方便而采用这种描述方式,请注意,下同)。
之后,你的同事修改了a.txt,并且提交了修改,
这时Repository的Revision就变成25了。
注意,这时你没有再次执行Update,
因此你的Working Copy的Revision还是24。
这时你修改了b.txt文件,并提交修改。
因为Revision25并没有对b.txt文件进行修改,
因此你对b.txt文件的修改是基于b.txt文件最新的版本,
所以不会出现Conflict。
当你提交b.txt的修改后,产生Revision26。
这时你会发现你的Working Copy中的a.txt文件并不是Revision25中的a.txt文件,
它还是Revision24的a.txt文件,而你的b.txt文件是Revision26的b.txt文件。
也就是说当你Commit时,你的Working Copy中只有你提交的那些文件是最新版本,
而其他没有修改的文件并不会更新为最新版本。
这样就造成了你的Working Copy由不同的Revision文件所组成
(Revision24的a.txt文件和Revision26的b.txt文件)。
前面说过在提交修改前必须保证你是在文件的最新版本基础上修改,
如果在这种混合版本的情况下,
怎样才能知道当前Working Copy中的文件是否为最新版本?
在前面所说的“.svn”目录中有一个文件名为“entries”的文件,
该文件记录了当前Working Copy中的每一个文件的Revision,
因此当你Commit时,Subversion会从该文件中取得你提交文件的Revision,
再与Repository的最新Revision一比较就可以知道你修改的文件是否基于该文件的最新版本。
10.文件的锁定
前面说过Subversion的版本控制模型是一种叫做Copy-Modify-Merge
(拷贝-修改-合并)的模型。
该模型在对文本文件进行版本控制时工作的很好,
但是有些需要进行版本控制的文件并不是文本文件,
比如说图像文件,这种模型在这种情况下就不能正常工作了,
因为文本文件可以合并,而二进制文件则无法合并。
所以Subversion从1.2开始支持一种叫Lock-Modify-Unlock
(锁定-修改-解锁)的版本控制模型。
在Windows下最常用的版本控制软件Visual Source Safe(VSS)就是采用这种模型。
这种模型要求在对一个文件修改前首先要锁定这个文件,
然后才能修改,这时,别人将无法对该文件进行修改,
当修改完后再释放锁,使其他人可以对该文件进行锁定,然后修改。
锁定文件的方法是:TortoiseSVN->Get Lock...再点OK按钮,
这时就完成了对文件的锁定。
这时,如果其他人想对文件进行锁定时,
Subversion会对他提示该文件已经被别人锁定。
当你修改完文件后,然后单击右键,SVN Commit...,
将修改提交,默认情况下,提交的时候就会对该文件解锁,
如果你想仍然锁定该文件,请在commit时弹出的对话框中选中keep lock复选框。
11.文件的附加属性
在Subversion中,每个文件可以拥有一种叫做附加属性的东西。
附加属性描述了该文件所拥有的一些特性。
Subversion已经预定义了一些附加属性
(这里只是指Subversion已经定义了一些附加属性的“名称”,
并不是指已经将这些属性附加在文件上了,
比如默认情况下文本文件一开始不含任何属性,
直到人为的对该文件添加附加属性),
并且你可以对文件添加自定义的属性。
Subversion对待附加属性就像对待文件内容一样,
当修改了一个文件的附加属性(添加,改变,删除附加属性),
即使没有对文件的内容进行修改,
同样可以Commit该文件,就像更改了文件内容那样,
Repository也会生成新的Revision,
所以从某种意义上来说,
Subversion不区别对待文件的附加属性的修改和文件的内容的修改,
文件的附加属性可以看成是一种特殊的文件内容。
Subversion预定义了若干个附加属性,
这里只讨论“svn:needs-lock”属性,
因为它与我们上面的文件锁定会产生的一个问题有关。
其他的属性可以参考Subversion自带的帮助文档。
考虑这种情况,
张三和李四同时想对一个图片文件a.jpg作修改,
张三在修改时先将该文件锁定,然后进行修改,
同时李四也开始对该文件进行修改,
但李四忘记了对非文本文件进行修改时应该先锁定该文件。
张三首先对该文件修改完毕,于是张三向服务器提交了他的修改。
之后,李四也完成了修改,当他提交修改时,
Subversion提示李四的文件版本不是最新的,
在Commit之前应先更新a.jpg到最新版本,
由于图片文件无法合并,
这就意味着张三和李四之间必定有一个人的修改会作废。
应用“svn:needs-lock”属性可以避免这个问题。
当一个文件拥有“svn:needs-lock”属性时,
该文件在没有锁定时,文件的图标是灰色的,
表示该文件是一个只读文件(该文件的Windows只读属性的复选框为选中),
这个灰色的图标就会提醒想对该文件进行修改的人,
在修改该文件之前应该首先锁定该文件。
锁定该文件之后,文件的只读属性就会去掉了,
一旦释放掉锁,文件的图标又会变成灰色,
文件也会变成只读的了。
李四在这种情况下就会避免在没有锁定文件时对文件进行修改。
对非文本文件添加“svn:needs-lock”
属性应该在将该文件第一次添加到Repository时就设置,
当然,一个文件可以在任意时刻添加附加属性,
这样做是为了减少李四所遇到的那个问题发生的几率。
具体的方法是:
首先将a.jpg文件拷贝到Working Copy中,
然后在该文件上单击右键,
TortoiseSVN->Add,告诉Subversion要将该文件纳入版本控制,
接着在该文件上单击右键并选中属性,
在弹出的属性对话框中选中Subversion页。
在下拉框中选中“svn:needs-lock”,
并在下面的文本框中填入“*”
(其实这里填什么都无所谓,只要文件有“svn:needs-lock”附加属性就行),
之后点Set按钮,“svn:needs-lock”附加属性就设置好了。
然后执行Commit命令提交修改。
这时当其他人执行Update时,
a.jpg就会添加到他们的Working Copy中,
并且文件的附加属性也会随文件一起被得到。
可以看到a.jpg此时的图标就是灰色的,
文件的Windows属性也是只读的。
12.回到以前的版本
由于Subversion会记录你对Repository的每一次修改,
因此能够很容易的获得Repository以前某一时刻的状态。
比如:现在Repository的最新Revision是56,
这时我想看看Repository在Revision24时的状态,
可以在本地的Working Copy中单击右键,
TortoiseSVN->Update to Revision...,
然后输入你想要回复到的Revision号,点OK按钮。
回到以前的版本还有一种情况是我想将Repository的
最新Revision的状态与以前某一个Revision的状态一模一样,
上面那种方法就不适合,
上面的那种方法只是将本地的Working Copy回复到以前的状态,
而服务器端的Repository并没有回到以前的状态。
将Repository的最新Revison的状态回复到以前某个Revision的状态具体的方法是:
先执行Update命令将Working Copy更新到最新的Revision,
然后在Working Copy中单击右键,
TortoiseSVN->Show Log,
弹出的Log Messages窗口中会显示该Repository的所有Revision,
选中最新的Revision,之后按住Shift键,
再单击你想回复到的Revision+1的那个Revision
(比如Repository的最新Revision是30,
你想将Repository的状态回复到Revision16,
那么就选中Revision30,再按住Shift键,
选中Revision17,
就是说选中Revision17到Revision30之间的所有Revision)。
然后在选中的Revision上单击右键,
选中“Revert changes from these revision”。
再点Yes按钮,就可以将Working Copy的状态回复到目标Revision。
注意,此时只是Working Copy回复到目标Revision,
之后应该用Commit提交修改,
这样Repository最新状态就与目标Revision的状态一样了。
这两种回复到以前版本的方式截然不同,
第一种方式是将整个Working Copy回复到某个Revision,
也就是说这种方式Working Copy中的“.svn”目录所存的文件副本也与目标Revision的一模一样,
如果这时你没有修改文件,你将不能执行Commit命令。
而第二种方式客户端Working Copy中的
“.svn”目录所存的副本始终是最新的Revision的文件副本
(这里我们基于一个假设:在Update之后没有其他人对Repository做修改)。
这种方式就像是我们自己手工将Working Copy的文件状态修改为目标Revision,
在修改之后提交修改一样。
13.查看修改
有时我们对Working Copy的许多文件进行了修改,
这些文件位于不同的子目录,我们就可以在Working Copy的最上层目录单击右键,
TortoiseSVN->Check For Modifications,
弹出的对话框就会显示你所做的所有修改明细。
还有一种情况是我们的Working Copy已经很久没有执行Update命令,
我们想看看Working Copy中有哪些文件已经发生修改了,
这时就可以在Working Copy的最上层目录单击右键,
TortoiseSVN->Check For Modifications,
在弹出的对话框点击Check Repository按钮后,
就会显示服务器端已经修改了的文件。
该方法还有一个用途就是查看文件的锁定,
当你想锁定一个文件时,你想先看看这个文件有没有被别人锁定,
点击Check Repository按钮会显示服务器端Repository所有被锁定的文件,
如果你想锁定的文件不在这里面,那就说明该文件目前没有人锁定。
如何利用svn自动同步更新到网站服务器?
一、安装 SVN服务器程序1.1运行 VisualSVN-Server-1.7.2.msi 1.2选择程序安装目录 和 SVN仓库目录 我程序装在 C:\Program Files\VisualSVN Server , SVN仓库目录在 D:\SVN1.3 安装完成,立即运行 二、服务器配置2.1服务器维护界面 2.2仓库目录默认的内容 2.3创建新项目wapzucom 2.3创建用户ve 2.4设置项目的用户权限 Properties Security Add 选择刚创建的用户 ve ok 应用 确认 三、创建测试服务器目录 D:\WWWROOT ,本地开发目录 D:\WORKDIR 四、将代码(D:\Code )导入到项目仓库输入用户名 密码 并 勾选 保存认证 导入成功,并返回版本号1 五、导出项目代码到工作副本、测试服务器目录同理,另外导出一份到测试服务器目录D:\WWWROOT (测试服务器的Apache目录指向该位置)六、使用Hooks自动更新测试服务器代码D:\WWWROOT6.1 进入 D:\SVN\wapzucom\hooks 建立 post-commit.bat 文件 编辑其内容 为"C:\Program Files\VisualSVN Server\bin\svn.exe" update "D:\www\test" --quiet --username name --password pwd 或者可参考下面这段话: 接下来最关键的一步是,我们需要找到服务器上安装的版本库的路径下面,以版本库名称命名的文件夹下,有一个名字为hooks的文件夹,在这个文件夹下建立post-commit.bat这样一个批处理文件,里面的内容如下: @echo off “D:\VisualSVN Server\bin\svn.exe” update “D:\Apache Software Foundation\Apache2.2\htdocs\soupei360″ _username XXXXX _password XXXXX update前面的路径,是SVN服务器端程序的执行文件路径, 后面的是在服务器上同步到的目录的路径,username和password后面是刚才建立用户的用户名和密码,这段批处理的意思是,当我们在本地编写代码,然后通过svn的commit提交时候,首先提交到版本库中,然后版本库自动用这个批处理,把内容同步到服务器上之前指定的文件夹中,从而实现本地和远程同步操作。 两款SVN配置软件的具体配置教程可以通过搜索引擎得到具体设置方法,在此需要特意强调的是,一定要将本地和服务器上的目录都check out后,批处理才能够自动同步,服务器上的目标文件夹没有check out的话,即使设置的路径正确,也是不能同步的。6.2 设置访问权限我的电脑 右键 管理 服务和应用程序 服务 VisualSVN Server 右键 属性 登陆 添加访问权限 用系统管理员账号(我这里是user) 重启服务器 6.3测试Hooks工作是否正常修改 index.php 状态 提交修改最后打开D:\WWWROOT\index.php 可以发现代码已经被成功update PS : 目录说明C:\Program Files\VisualSVN Server 服务器安装目录D:\SVN 仓库更目录D:\WORKDIR 本地开发用的工作目录D:\WWWROOT 服务器测试目录(Apache 指向该目录,即可实现工作目录内容修改后提交到SVN自动发布到测试目录)
svn如何使用
svn(subversion)是近年来崛起的版本管理工具,是cvs的接班人。目前,绝大多数开源软件都使用svn作为代码版本管理软件。如何快速建立Subversion服务器,并且在项目中使用起来,这是大家最关心的问题,与CVS相比,Subversion有更多的选择,也更加的容易,几个命令就可以建立一套服务器环境,
本文是使用Subversion最快速的教程,在最短的时间里帮助您建立起一套可用的服务器环境,只需略加调整就可以应用到实际项目当中。
本教程分为以下几个部分,为了说明简单,教程是在windows下使用的方式,以方便资源有限的项目使用。在UNIX环境下,只是安装方式不同,命令执行并无太大区别。
工具/原料
Subversion服务器程序安装包
Subversion的Windows客户端TortoiseSVN安装包
方法/步骤
1软件下载
<1>、下载Subversion服务器程序
到官方网站的下载二进制安装文件,来到二进制包下载部分,找到 Windows NT, 2000, XP and 2003部分,然后选择Apache 2.0 或者 Apache 2.2,这样我们可以看到许多下载的内容,目前可以下载Setup-Subversion-1.7.12.msi 。
<2>、下载Subversion的Windows客户端TortoiseSVN。
TortoiseSVN是扩展Windows Shell的一套工具,可以看作Windows资源管理器的插件,安装之后Windows就可以识别Subversion的工作目录。
官方网站是TortoiseSVN ,下载方式和前面的svn服务器类似,在Download页面的我们可以选择下载的版本,目前的最高稳定版本的安装文件为TortoiseSVN-1.5.5.14361-win32-svn-1.5.4.msi。
2svn服务器和客户端安装
<1>、安装Subversion,直接运行Setup-Subversion-1.5.3.msi ,根据提示安装即可,这样我们就有了一套服务器可以运行的环境。
<2>、安装TortoiseSVN,同样直接运行TortoiseSVN-1.5.5.14361-win32-svn-1.5.4.msi按照提示安装即可,不过最后完成后会提示是否重启,其实重启只是使svn工作拷贝在windows中的特殊样式生效,与所有的实际功能无关,这里为了立刻看到好的效果,还是重新启动机器。
<3>、安装svn的客户端程序,需要的话还可以安装svn的语言包,注意语言包的版本也必须与客户端程序的版本一致
3建立版本库(Repository)
运行Subversion服务器需要首先要建立一个版本库(Repository),可以看作服务器上存放数据的数据库,在安装了Subversion服务器之后,可以直接运行,如:
svnadmin create E:\svndemo\repository
就会在目录E:\svndemo\repository下创建一个版本库。
我们也可以使用TortoiseSVN图形化的完成这一步:
在目录E:\svndemo\repository下"右键->TortoiseSVN->Create Repository here...“, 然后可以选择版本库模式, 这里使用默认即可, 然后就创建了一系列目录和文件。
步骤阅读 .4SVN配置用户和权限
来到E:\svndemo\repository\conf目录,修改svnserve.conf:
# [general]
# password-db = passwd
改为:
[general]
password-db = passwd
然后修改同目录的passwd文件,去掉下面三行的注释:
# [users]
# harry = harryssecret
# sally = sallyssecret
最后变成:
[users]
harry = harryssecret
sally = sallyssecret
在passwd文件中,“=”前的字符就是用户名,后面的就是密码。还要注意“[users]”前面的注释“#”一定要删除掉。
步骤阅读 .5运行独立服务器
在任意目录下运行:
svnserve -d -r E:\svndemo\repository 我们的服务器程序就已经启动了。注意不要关闭命令行窗口,关闭窗口也会把svnserve停止。
6初始化导入
来到我们想要导入的项目根目录,在这个例子里是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”。
步骤阅读 .7基本客户端操作
取出版本库到一个工作拷贝:
来到任意空目录下,在本例中是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.服务器的版本号 是冲突后服务器版本文件
END注意事项
如果修改文件后提交不了,大多是因为版本不一致造成的。更新一下,不产生冲突的情况,就可以提交了。
更新文件,如果出现冲突的情况,打开冲突文件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文件,这样也会产生代码覆盖。
上面二种情况都是我亲眼看到新手这样操作的,要避免这二种操作方法。
svn怎么上传文件
这里有详细的图文教程http://jingyan.baidu.com/article/19020a0a27cf0c529c28426f.html
本地电脑需要安装SVN客户端,
从SVN版本库地址中下载版本库目录到本地电脑中
把需要上传的文件存放到本地电脑中的SVN目录下
选中文件,点鼠标右键选择TortoiseSVN ,选择add或加入。
选中文件会显示一个+的图标,在鼠标右键菜单中点击“SVN提交”
弹出一个窗口,输入提交文件的理由或日志。
点击右下角的确定,
这时,文件图标会显示“√”,代表文件上传完成。