




已阅读5页,还剩17页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
备注:本内容经过本人练习和测试简介VisualSVN Server是用于Subversion管理的windows程序,它整合了Subversion, Apache和一个命令行管理工具。提供了完全可视化的Subversion版本库创建,管理,人员管理的操作界面。TortoiseSVN是subversion的客户端工具,可以通过他连接到VisualSVN Server。细节:VisualSvn Server 已经将 Apache 和 Subversion 集成好了,生成 HTTP 的访问方式 :http:/计算机名:端口号/svn/Project_Name。windows下配置VisualSVN Server服务器(服务端和客户端)下载安装文件:服务端安装文件:VisualSVN-Server-1.6.2(下载地址)客户端安装文件:TortoiseSVN-4361-win32-svn-1.5.4在VisualSVN Server 的官网上提供了两个产品。一个是VisualSVN,另一个是VisualSVN Server (下面简称Server)。前者是一个集成到Visual Studio里的插件,功能挺强大,但是需要收费滴VisualSVN Server(服务器端)一、VisualSVN Server的配置和使用方法【服务器端】 1,VisualSVN Server的安装 下载安装包,解压后得到.exe文件,双击进行安装 其中的Location和Repositories存放位置可以自由设置,可以两个可以不在同一盘符下。建议复选 Usesecure connection项,这时候只有443和8443两个端口可用(注意自己公司的防火墙问题,如果有冲突则需要开放该对应端口以使用)。还有就是建议使用 Subversion身份验证模式。(具体如果处于域里面则已包含了域验证,相对安全了)一步步Next,安装完毕,默认选择打开操作管理界面(也可以开始-程序-VisualSVN打开操作管理界面)2,添加一个代码库【Repository】右击Repository上图中的CheckBox如果选中,则在代码库StartKit下面会创建trunk、branches、tags三个子目录;不选中,则只创建空的代码库StartKit,点击OK按钮,代码库就创建成功至此,完成代码库创建。3,给代码库创建用户及分配权限下面,我们开始安全性设置,在左侧的Users上点击右键点击OK,我们就创建一个用户了。按照上面的过程,分别添加用户Developer1、tester1、manager1,然后添加这些用户到我们刚才创建的项目里右击刚才新建的代码库StartKit点击上图中的Add.按钮,在下图中选择我们刚才添加的用户,点击OK按钮说明:大家可能注意到了下图中的Groups,是的,你也可以先创建组,把用户添加到各个组中,然后对组进行授权按照下图所示,分别对用户【或组】进行授权:因为用户starter在团队中是新来者,不希望他向代码库中提交新代码,所以他只能读取代码库中的代码,不能提交代码。tester1是测试人员,不负责代码编写,所以也是只读权限。而Developer1和manager1是开发人员和项目经理,自然具有读、写的权限。在实际的项目开发过程中,Developer和tester往往不可能只有一个人,这时候使用组来授权更加方便。权限分配要真正实现针对整个库的权限分配控制,即指定的用户不但只能访问给其指定的资源而且不能访问并没有设定限制的其它资源,就必须首先在Repositories级别把Everyone用户的权限设为无任何权限(No Access),然后再针对具体的目录或文件设置不同用户的权限。权限分配时具有父子继承和下级覆盖上级权限的特点:具体就是,如果上级目录给某用户设置了某权限,而下级目录并没有给该用户设置具体权限,则该用户对下级的子目录具有在上级目录所给予的权限。如果上级目录设置了某权限,同时在下级目录再次对该用户设置了其它权限,则该用户对下级目录所拥有的权限就不再是在上级目录所给予的权限。实际在权限分配时按照目录结构从上到下的顺序,应遵循由严到松的原则,在顶层目录设置大多数用户不具有任何权限(只有把Everyone用户的权限设为无任何权限即可实现,不需要分别把每个用户的权限设为无任何权限),在需要给用户分配一定权限的子目录设置适当的权限,防止其他用户访问和获得不能让其了解的资料。u 当权限设为No Access,指定用户不能检出和获得任何信息;u 当权限设为read only,指定用户可以检出和获得信息,但不能对信息修改后提交到服务器;u 当权限设为read/write,指定用户可以检出和获得信息,同时也可以把自己对信息的修改提交到服务器。备份VisualSVN Server中仓库(Repositories)中的代码一、 最好的方法就是使用TotoiseSVN(客户端)工具,把仓库中的代码直接检出(check out)。二、 可以直接把Repositories整个仓库文件拷贝到其它磁盘,在重新安装VisualSVN Server时,可以直接指定使用此仓库,可以使用仓库中原先的所有东西,不仅包括使用仓库中的资料,还可以使用原先的用户和权限设置。例如:d:Repositories为之前拷贝的仓库,在重新安装另一个VisualSVN Server时可以直接使用。三、 使用recommend命令实现备份。TotoiseSVN(客户端)TotoiseSVN的基本使用方法一、签入源代码到SVN服务器假如我们使用Visual Studio在文件夹StartKit中创建了一个项目,我们要把这个项目的源代码签入到SVN Server上的代码库中里,首先右键点击StartKit文件夹,这时候的右键菜单如下图所示:点击Import,弹出下面的窗体,其中 是服务器名,svn是代码仓库的根目录,StartKit是我们在上个教程中添加的一个代码库:说明:左下角的CheckBox,在第一次签入源代码时没有用,但是,在以后你提交代码的时候是非常有用的。点击OK按钮,会弹出下面的窗体,要求输入凭据源代码已经成功签入SVN服务器了。这时候团队成员就可以迁出SVN服务器上的源代码到自己的机器了二、签出源代码到本机在本机创建文件夹StartKit,右键点击Checkout,弹出如下图的窗体:在上图中URL of Repository:下的文本框中输入svn server中的代码库的地址,其他默认,点击OK按钮,就开始签出源代码了。说明:上图中的Checkout Depth,有4个选项,分别是迁出全部、只签出下一级子目录和文件、只签出文件、只签出空项目,默认的是第一项。上面的例子中,我们也可以使用web的方式访问代码库,在浏览器中输入/svn/StartKit/这时候也会弹出对话框,要求输入用户名和密码,通过验证后即可浏览代码库中的内容。源代码已经成功签出到刚才新建的StartKit目录中。打开StartKit目录,可以看到如下图的文件夹结构: 一旦你对文件或文件夹做了任何修改,那么文件或文件夹的显示图片机会发生变化。下图中我修改了其中的二个文件 (附:不同状态所对应的图片) 现在我们已经知道怎么将源代码签入到SVN服务器,怎么从服务器签出代码到本机,也简单了解了不同状态所对应的图案。 三、提交修改过的文件到SVN服务器上面的图2-2-7中,我修改了位于Model文件中的二个文件ImageInfo.cs和NewsInfo.cs,下面演示如何提交到SVN服务器。注意:提交源代码到服务器时,一定确保本机的代码是最新版本,否则可能提交失败,或者造成版本冲突。 在Model文件夹上点击右键或在Model文件下的空白处点击右键,点击SVN Commit弹出下面的窗体:点击ok四、添加新文件到SVN服务器我们在Model文件下添加一个新的类文件UserInfo.cs,在Model文件下的空白处点击右键,点击SVN Commit,和上面讲的提交修改过的文件到SVN服务器一样,就可以了。另外也可以在文件UserInfo.cs上点击右键,点击TortoiseSVN=Add,弹出如下图的窗体:选中UserInfo.cs文件,点击OK按钮,这样并没有将这个文件提交到SVN服务器,只是将这个文件标记为源代码库库中的文件,并将其状态置为修改状态。之后,我们要再SVN Commit这个文件一次,才可以将其真正提交到SVN服务器上的代码库中。上面讲是添加文件,实际上,添加文件夹的步骤也是一样的,这里就不说了。 五、更新本机代码与SVN服务器上最新的版本一致这个也很简单,只要在需要更新的文件夹上点击右键或在该文件下的空白处点击右键,点击SVN Update,就可以了。注意:更新操作可能会因为版本冲突而失败,这是可以使用合并【Merge】或其他方法解决;也可能因为锁定【Get Lock】而失败,这是需要先解锁【Release Lock】。 六、重命名文件或文件夹,并将修改提交到SVN服务器只要在需要重命名的文件或文件夹上点击右键,点击TortiseSVN=Rename,在弹出的窗体中输入新名称,点击OK按钮,就可以了。此方法也不是直接重命名,而是将该文件或文件夹的名称标记为重命名后名称,也需要我们使用SVN Commit提交到SVN服务器后才真正重命名。七、删除文件或文件夹,并将修改提交到SVN服务器最简单就是,你直接删除文件或文件夹,然后使用SVN Commit提交更新到SVN服务器。另外一种方法是在你要删除的文件或文件夹上点击右键=TortoiseSVN=Delete删除,此方法也不是直接删除,而是将该文件或文件夹的状态置为删除,也需要我们使用SVN Commit提交到SVN服务器后才真正删除。说明:实际上,从你把源代码迁签入SVN服务器开始,每一个版本的数据和文件,就算是你已经删除了的,也都可以随时迁出。以上只是TortoiseSVN最简单的几个功能,其实他的功能远不止这些,其他的功能大家可以在使用的过程中慢慢体会,有些功能我会在下面的教程中使用到,到时候会和大家讲清楚用法。注意:向SVN服务器提交源代码的时候,一定不要提交bin、obj等文件夹,否则会很麻烦。但是web项目的bin目录除外,但是web项目的bin目录中的引用其他项目而生成的dll不需要提交。一个好习惯:如果项目中引用了其他的第三方的程序集,比如EnterpriseLibrary、FCKEditor等,这时候不要简单从他们的安装位置引用,而是在你的解决方案下,添加一个Library的目录,把需要的程序集复制到这里,然后从Library目录引用,这样有什么好处,自己想一想吧八、使用TotoiseSVN在本地建立资源库(repository)1、在本地建立一个空文件夹,(必须是空的文件夹)2、右键点击此空文件夹,选择create repository here命令,即可成功在本地创建一个仓库。弹出成功提示打开该文件可以看到,该空文件夹下自动生成如下的文件。3、在VisualSvn Server中,右键点击仓库的根目录,选择导入已存在的仓库,选择刚才创建的文件夹,点击确定,此时在本地创建的仓库就导入服务器中了。如果查看VisualSVN Server在磁盘的Repositories目录,就可以看到,“新建测试的repository”已被从本地放入此根目录下了。此时完全可以删除原先创建的仓库。九、版本库迁移假如有两个服务器A和B,版本库原来在A服务器上,现在要移到B服务器,做法如下1、将A中的版本库更新到MYeclipse(注意要删除掉.WebRootWEB-INF下的calsses文件夹,因为这里包含Myeclipse自动编译文件,如果不删除就上传至版本库,check出来的项目同步时会报错),右击项目-team-disconntect(断开)-选择第一项-Yes,目的是将原来使用svn或cvs时项目中的.cvs和.svn文件清除掉2、在B上安装客户端和服务端,再按上面讲的步骤在B的服务端上建版本库,然后把项目拷贝到B中的某个位置,使用svn客户端右击项目,选择import导入到版本库中VisualSVN Server和TortoiseSVN的使用细节一、获得资源文件在VisualSVN Server中的路径右键点击要访问的资源,选择Copy URL to Clipboard命令,直接实现路径的拷贝。二、浏览svn服务器仓库repositories中的资源(一)使用客户端工具TortoiseSVN,右键点击Repo-browser,输入要浏览的资源的URL路径信息,点击OK确定;输入在svn服务器中为用户设置的用户名和密码,点击OK确定;出现需要浏览的信息,OK退出;(二)使用VisualSVN Server,右键点击要浏览的资源,选择Browse;打开浏览器,弹出提示框,输入在svn服务器中为用户设置的用户名和密码,点击确定;注意此处的用户名和密码不是VisualSVN Server所在的计算机的用户名和密码。出现需要浏览的信息三、删除svn服务器仓库repositories中的指定资源(一)在 VisualSVN Server中,只能直接删除文件夹,不能删除文件,要删除文件只能通过删除文件所在的文件夹来实现删除文件。可以看到,没有针对文件的删除命令。(二)在客户端,直接删除受版本控制的某个文件,再通过TortoiseSVN工具的SVN Commit命令提交修改后的项目,间接实现删除svn服务器仓库repositories中的指定文件。四、直接在VisualSVN Server中只能建文件夹而不能创建文件。五、SVN使用图标说明表示Subversion状态正常。当我们开始编辑一个文件后,图标将变成红色感叹号。通过这种方式,可以很容易地看出我们对哪些文件进行了修改操作,但是还没有提交到版本库中。如果在提交的过程中出现了冲突,图标将变成黄色感叹号。如果我们拥有了一个文件的锁,并且Subversion状态是正常,这个重载图标将提醒我们:如果不使用该文件的话,请进行释放锁操作,允许其他成员提交对该文件的修改。 表示当前文件夹下的某些文件或文件夹已经被计划从版本控制中删除,或是该文件夹下某个受控的文件丢失了。加号告诉我们有一个文件或是目录已经被计划加入版本控制。问号表示新建的文件或目录,还没有被加入版本控制解决冲突(conflict)一、冲突产生的原因:当两个或两个以上的用户对同一文件进行操作时,如果A对该文件修改操作完成后,将该文件提交到SVN上。此时,其他成员的本地文件与SVN上的文件版本不一致。当成员B对该文件修改操作完成并对文件进行更新或提交操作时,就会产生冲突。二、面对文件冲突,我们可以选择以下两种方式解决冲突:n 使用工具解决冲突n 用revert放弃所做的修改(一)使用TortoiseSVN自带工具编辑冲突右键点击产生冲突的文件,选择“编辑冲突”(Edit conflicts);红色标注的部分为不一致产生冲突的部分,编辑冲突时需选中冲突的文本;编辑完冲突后,点击图标,表示冲突已解决;冲突解决之后,及时提交(commit)该文件。(二)、用revert放弃所做的修改右键点击产生冲突的文件,选择“还原”(revert),放弃本地对该文件的修改,完成冲突解决。(三)、避免冲突的建议(1) 修改文件之前,先进行一次update操作;(2) 修改完成后,及时commit,不要在本地停留过长时间;(3) 在多位团队成员协作时,分工要分明,尽量修改自己撰写的部分,不要修改不属于自己撰写的部分;(4) 出现冲突很正常,可以通过前面介绍的方法解决,不要相互覆盖。在Myeclipse中使用SVN一、在Eclipse下使用的图标受SVN控制的文件被标记为小黄桶;修改过的文件都被标记上一个黑色星号;未受版本控制的文件被标记为问号;报错的文件被标记为叉号;二、在myeclipse中安装svn插件的方法: 方法一、如果可以上网可在线安装 1. 打开Myeclipse,在菜单栏中选择HelpSoftware UpdatesFind and Install; 2. 选择Search for new features to install,点击Next进入下一步; 3. 点击New Remote Site按钮,在弹出的对话框中输入: name:SVN url:/update_1.4.x 点击OK,关闭对话框,并点击Finish按钮,Myeclipse自动下载插件安装程序; 4. 下载完插件之后,进入安装画面。 5. 选择所要安装的SVN插件内容,这里去掉第二个选项Subclipse Integrations,点击下一步; 6. 选择 I accept the terms in the license agreements并点击Next,直到点击Finish即可,进入下一步。 7. 开始安装SVN插件,安装完成之后,重启Myeclipse。 方法二、无法连接网络的情况 1、下载SVN插件 下载地址:/files/documents/906/46495/site-1.6.5.zip 2. 在MyEclipse 6.5的安装路径下的plug_in(C:Program FilesMyEclipse 6.5eclipseplugins)下新建文件夹:site-1.6.5; 3. 打开MyEclipse 6.5,在菜单栏中选择 Help Software Updates Find and Install; 2. 选择Search for new features to install,点击Next进入下一步; 3. 点击New Local Site按钮,找到解压出来的文件夹(site-1.6.5) 点击OK,并点击Finish按钮,Myeclipse自动加载插件; 4. 在弹出的菜单中,select the features to insteall:在刚加进去的路径Subclipse-site-1.6.5这一项前打钩,此时会报错,然后展开Subclipse前的加号,去掉Subclipse Integration for Mylyn 3.x(Optional)3.0.0前的钩,错误消失 next 选 I accept the terms in the license agreements next next 选中所有的8项,然后Change Location,在弹出的菜单中选Add Location选择在第3步中建的文件夹的路径(C:Program FilesMyEclipse 6.5eclipsepluginssite-1.6.5) Finish 再弹出的菜单中选 Install All Yes 5. 开始安装SVN插件,安装完成之后,重启Myeclipse。方法三、无法连接网络的情况(link链接) 1、从官网下载 Site-1.6.5.zip 2、解压Site-1.6.5.zip至$eclipsePluginsSubclipse-1.6.5.zip,并删除 site.xml(很重要)(即把Site-1.6.5.zip解压出来的features和plugins文件夹里所有的jar包和两个XML文件artifacts.xml、content.xml添加并替换到plugins文件夹下。例如:我应添加在C:Program FilesMyEclipse 6.5eclipseplugins目录下) 3、创建link文件 $eclipselinksSubclipse-1.6.5.zip.link (即在link文件夹下添加linksSubclipse-1.6.5.link文件)其内容为: path=C:Program FilesMyEclipse 6.5eclipse 4、重启Eclipse就是把subclipse集成完毕二、从svn服务器中检出项目 1. 在MyEclipse 6.5 菜单栏中选择WindowOpen PerspectiveOther打开Myeclipse试图列表。这个时候Myeclipse的视图列表中,就出现了SVN Repository Exploring一项。 2. 打开SVN Repository Exploring视图。在左边空白区域,单击右键 New Repository Location。 3. 在Url一栏中输入svn:/IP,点击Finish按钮。 4. 选择要下载的项目右键选择checkout 就把项目下载到本地了三、基本操作 1.提交工程 右击工程-小组-共享项目-选择SVN-选择svn:/(如果没有,则创建一个新的资源库)-下一步-完成 2.下载工程 在SVN资源库透视图下,点开svn:/,会显示出现在本机SVN上的所有工程,右击你想下载的工程-检出为-下一步-完成 3.操作工程 3.1同步 在MyEclipse J2EE透视图下,右击你要同步的工程-小组-与资源库同步-这时会进入同步透视图,会显示出本机与SVN上内容有不同的文件,双击文件名,会显示出两个文件中哪里不同; 3.2提交 在同步透视图下有灰色向右的箭头,表示你本机修改过,右击该文件,可以选择提交操作; 3.3覆盖/更新 在同步透视图下有蓝色向左的箭头,表示你本机修改过,右击该文件
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 咨询服务协议书样本
- 解析卷-北师大版8年级数学上册期中试题及参考答案详解(B卷)
- 2025版电子信息设备融资租赁委托合同样本
- 2025年度国内高端柴油批发与物流配送合作合同
- 2025版城镇化改造土方工程劳务分包合同范本
- 2025版住宅小区改造工程委托施工合同
- 2025版企业间融资租赁借款合同汇编
- 2025年度智能停车场设备安装与租赁合同样本
- 2025年度城市公共交通系统采购框架合同
- 2025年度典当借款与艺术品市场风险管理服务协议
- 客服试题及答案
- 革命文物介绍课件
- 2025年山东省中考道德与法治试卷真题及答案详解(精校打印版)
- 资料员证考试题目及答案
- DB11T 689-2025 既有建筑抗震加固技术规程
- 2025年荧光内窥镜市场调研报告
- 教师培训安全课件
- 2025年兵团普通职工考试试题及答案
- 药品数据管理实务讲授人王婧64课件
- 2024-2025学年渤海船舶职业学院单招《语文》题库试题带答案详解(培优A卷)
- 2025至2030中国核桃油行业市场发展分析及投资前景与投资策略报告
评论
0/150
提交评论