SVN是什么 Svn是一个离线的代码管理,可以多个人一起修改,然后再将修改的内容提交到Svn中。 每一个svn服务器中的数据存储单位叫做存储,但是你不仅仅可以把整个存储当作你维护的内容,也可以将其中的某个分支目录像根存储一样的使用。 Svn是严格区分大小写的,存储中路径的名字只有大小写不同,也会当作不同的路径处理。注意这里会在windows平台下导致一些非常严重的问题。在windows下如果svn服务器上同一文件夹有两个只有大小写不同的文件时会出现则会出现总是提示某个文件丢失,而更新到哪个文件也是未知的。如果同一文件夹有只有大小写不同的文件夹会导致总是无法将一个文件夹同步下来。最严重的要数如果存储名称错误,则你没有办法提交数据,因为帐户认证是基于存储的。 SVN的版本概念 先说明一下几个版本概念。 一个是服务器版本,每一次提交svn都会将版本号加1,无论你是修改了文件,还是添加删除了,甚至修改一下文件夹的svn属性,只要你提交都会更新版本; 第二个是本地基础版本,也就是你上次进行update之后的和svn服务器上的版本,比如你update时服务器上是reverion11你的本地基础版本就是reverion11,无论别人改了什么,服务器上更新了多少版,只要你不执行update则你的基础版本永远是reverion11; 第三个是工作版本,就是你当前改着的版本,工作版本是基于基础版本的,如果没改,工作版本就和基础版本一致,如果你改了,你的工作版本就是从基础版本修改过来的。 SVN基本操作 总是有人问已经在本地删除了某个文件,可是一更新又从svn还原出来了,或者我已经把一个文件移动到另外的地方,可是怎么修改svn让他同步等等。在受svn管理的文件中,所有的文件操作不能想当然的进行,添加删除和移动改名都是有对应的svn操作的,这样才能自动的反映到svn上来,尤其是移动文件这样的操作,如果操作不慎,就会无法将文件的修改历史联系起来。不过,svn的操作有一些是需要连接服务器的“连线操作”有一些是之进行本地操作的“离线操作”。所以下面介绍一些svn使用的基本操作。 SVN基本操作之svncheckout 作为svn的用户,拿到一个svn地址,我们首先做的一个事情就是svncheckout,将svn上的关联到本地的一个文件夹中。这个文件夹最好是空的文件夹,或者确保没有和svn上相同名称的路径,当然这也说明这个操作是个连线操作。我们一般在执行checkout的时候只要给出svn的URL和本地的路径两个内容就可以了。这样svn上最新的数据会被传送到这个文件夹,目录结构会自动建好,svn上的文件会自动出现在对应的文件夹中。当然如果你愿意也可以选择一个旧的版本,或者只包含一层目录或者只是这个文件夹中的文件。或许你发现了,每一个文件夹中比服务器上的内容多了个.svn文件夹,这个文件夹中存放着文件夹的属性,这个文件夹中的每个文件的属性、版本还有对应版本的一个副本。 SVN基本操作之svnupdate 这个操作就是将本地的的数据更新到svn上的某个版本,默认的操作是更新到最新版本,这个操作也是个连线操作。在这个过程中如果有人删除了文件,它会你机器上的文件删除,如果别人改了某个文件,会将这个文件更新。如果你修改了某个文件,别人删除了它,则这个文件不会被删除,只会和svn没关系了。如果你修改了某个文件,而这个文件别人也修改了,在更新的过程中就会试图自动将你的修改合并,如果成功,他的内容就是你修改的和别人修改的内容的并集,如果失败,svn就会将这个文件标记为冲突。冲突的问题我们放在下个说。 SVN基本操作之svnresolve 使用svn意味着你已经走在了工作在编辑和合并的道路上,那么冲突的时候svn做了什么,出现了冲突怎么解决? 在标记为冲突的过程中,如果是文本文件,如cpp和h文件,svn会修改它让他不能进行编译,并产生一个theirs和mime,分别包含svn服务器上的和我自己原来的版本。 如果是二进制文件,svn不会修改它,而会在目录中产生一个r??和r??这两个r??一个是你update之前的svn基础版本,就是你上次执行update的版本,一个是svn上的当前update下来的版本。 你可以选择直接使用theirs或者使用mime或者退回到上一个update版本,或者将两个文件放在一起手工合并作为解决的方法。 这个操作是离线操作。 SVN基本操作之svncommit svn的commit操作就是将修改从工作拷贝发送到版本库并将版本标记为新的版本,这个过程中如果有人已经对这个版本进行了操作,也就是你的本地基础版本和服务器不同,将会强制你执行一个update操作,这个操作是个连线操作。commit的过程仅仅是将你本地的一些修改提交到svn中让svn上的和你的一致,在提交之前必须已经解决了需要提交文件已有的冲突才行。 SVN基本操作之svnadd 如果一个文件不受svn管理,你需要把它添加到svn中,这个操作是个离线操作,仅仅是把这个文件标记为需要添加,真正的添加到svn存储的操作将在下一次commit时执行。这个过程中需要注意不要把一些不必要的文件比如编译的临时文件添加到svn。 SVN基本操作之svnimport 当然你可以将一些文件直接添加到svn而不想修改这些文件的svn管理状态,可以选择将它们导入到svn。注意如果将一个文件导入,则给出的url就是它添加到svn的最终文件名,如果将一个文件夹导入,则会将根据目录树所有的子文件和文件夹放到对应的url的对应目录树中,根文件夹不会被添加。 这个操作是连线操作。 SVN基本操作之svncleanup 这个操作清理整个所选择的文件夹及其子文件夹,但是它不是清理垃圾文件什么的,这肯定不是svn的工作。它也不会把冲突自动解决,如果能自动解决,在更新的时候为什么不做。如果你在某个svn操作时强制中断了,比如svn的操作程序停止相应或者以外终止,就有可能导致文件夹处于锁定状态,这时需要清理。如果你的文件夹中的很多文件时间戳发生了变化,也最好执行以下cleanup这样可以加速svn操作的执行。 这个操作是离线操作。 SVN基本操作之svndelete 既然有方法添加文件,就一定有方法删除,虽然你看到的效果是文件直接被删除了,但是实际上和添加一样,这个操作是个离线操作,操作的结果将被标记,下次commit时服务器上的文件才会被删除。 SVN基本操作之svnrevert 如果你的修改出现了问题,或者添加或者删除了错误的文件,等等想还原操作,在commit之前可以执行revert操作,退回某步操作,这样这些修改都会被还原到基础版本状态。这个操作不会和svn服务器有关系,不会连接服务器也不会更新文件,只是简简单单的回复到基础版本。 这个操作是个离线操作。 SVN基本操作之svndiff 这个操作就是比较你的工作版本和某个svn版本的区别,当然默认是你的基础版本,因为你的工作版本就是从基础版本修改过来的么。在和基础版本比较时是个离线操作,和历史版本比较时是连线操作。 SVN基本操作之svnexport 这个操作可以将一个已经在svn管理下的文件夹中的所有工作版本导出到一个文件夹中,或者直接从svn服务器上将一个版本导出到一个文件夹中。导出的文件夹不再在svn的管理控制下,也不会有.svn目录,当然也不会包含不在svn管理下的文件。在导出工作版本时是个离线操作,从svn直接导出时是连线操作。 SVN基本操作之svncopy 操作的名字显而易见,就是复制操作,在svn上复制文件有什么好处呢,为什么不直接复制文件再添加到svn呢。这个问题我也考虑过,svncopy可以将文件在复制之前的历史保留下来,这应该是最大的好处了。这个操作是离线操作,需要提交才起效。 SVN基本操作之svnmove 和copy一样,历史的留存也是和复制后删除源文件这个方式最大的区别,并且它也是离线操作,需要提交才起效。 SVN基本操作之svnlock 如果你想独占修改这个文件,可以把文件锁定,这样就可以锁定这个文件,这样别人必须等待你提交了修改或者释放了锁才能提交他们的修改。这个操作不会对别人的svn本地存储有什么影响,而只是无法进行数据提交。如果某个文件有svn:needs-lock这样的标志时,文件会被设置为只读,提示你需要获得锁来修改。当然你也可以把文件的属性修改直接修改,这个只是防君子不防小人的。 这个操作时连线操作。 SVN基本操作之svnunlock 虽然是unlock但是实际上这个我们平常不会将他用来和lock配对,因为commit操作时,svn默认自动将锁释放了。这个操作的用处是在你得到锁了之后,又不想锁定这个文件时执行的。还有就是如果别人锁定了这个文件,想强制把这个文件解锁,就可以强制将这个文件解锁。这个操作时连线操作 |
相关推荐
本文将深入探讨SVN的基本操作,包括安装配置、基本命令和常见应用场景,旨在为新手提供全面的入门指南。 #### 一、安装SVN客户端与服务器 **1. 安装SVN客户端** 对于Windows用户,推荐使用TortoiseSVN,这是一款...
对新手而言,理解SVN的基本概念和操作至关重要,以便更有效地协同工作和管理代码。以下将详细解释新手在使用SVN时需要掌握的知识点。 1. SVN基本概念 - Repository(源代码库): 这是源代码统一存放的地方,可以...
SVN_基本操作与规程.ppt SVN_基本操作与规程.ppt
Windows 和 Mac 操作系统下 SVN 基本操作命令 SVN(Subversion)是一种版本控制系统,广泛应用于软件开发、文档管理等领域。本资源将介绍 Windows 和 Mac 操作系统下 SVN 的基本操作命令。 一、Windows 下 SVN ...
本手册将帮助新手快速掌握SVN的基本操作和核心概念,以便更好地进行团队协作。 ### 1. SVN基本概念 1. **仓库(Repository)**: 存储所有项目文件的中央数据库,保存文件的历史版本。 2. **工作副本(Working Copy)**...
"SVN 命令行操作详解" SVN(Subversion)是一种集中式版本控制工具,由 Apache 开发和维护。SVN 命令行操作指令是 SVN 的一部分,用于管理和维护版本控制系统。本文将详细介绍 SVN 命令行操作指令的使用方法和参数...
### SVN的基本操作详解 #### 一、SVN简介与安装 **Subversion**(简称SVN)是一种开源的版本控制系统,广泛应用于软件开发过程中对代码、文档等资源的管理。通过SVN,团队成员可以轻松地协作开发项目,同时保证源码...
SVN(Subversion)是一种版本控制系统,用于管理文件的历史版本,支持多人协作编写代码。SVN合并操作是版本控制中的一个核心功能,允许开发者将...对于初学者来说,理解和实践上述基本的合并操作步骤是一个很好的开始。
以下是对SVN基本操作的详细解释。 1. **安装与配置SVN** 在Windows环境下,可以下载并安装TortoiseSVN,这是一个直观的SVN客户端,提供了与文件资源管理器集成的图形用户界面。安装后,通过右键菜单即可进行SVN...
【SVN 分支合并基本操作】是软件开发中配置管理工具 Subversion (SVN) 的核心功能之一,它允许开发团队协同工作,各自在独立的分支上开发,然后将改动合并回主干,以保持代码的稳定性和一致性。以下是详细的操作步骤...
在本文中,我们将详细探讨如何安装和配置SVN的服务端和客户端,以及如何进行基本的操作。 1. **安装前的准备** 在开始安装SVN之前,确保你的计算机已连接到互联网,并且系统符合SVN软件的最低系统需求。对于...
本知识点将基于提供的文件内容展开,解释svn的基本操作,包括常用命令及其功能。 1. **创建版本库(Repository)**:在SVN中,版本库相当于存放项目所有版本数据的数据库。命令如“SVNB10030”和“SVNBC”可能是...
**SVN 教程文档** **一、理解 SVN** SVN,全称为 Subversion,是一种广泛使用的版本控制系统,类似于 CVS,具有跨平台的特性...无论你是新手还是经验丰富的开发者,了解和掌握 SVN 的基本操作和原理都是非常有益的。
本手册旨在指导用户如何使用SVN客户端TortoiseSVN进行基本操作及一些进阶功能。 1. **安装与配置** - 首先,用户需要下载TortoiseSVN的安装程序,例如`TortoiseSVN-1.4.0.7501-win32-svn-1.4.0.msi`,双击安装。...
本资源总结了 Linux 系统下 SVN 服务器操作命令的详细信息,涵盖了初学者可以使用的 Ubuntu 系统下的基本命令,希望对大家有帮助。 一、基本命令 1. 将文件 checkout 到本地目录:svn checkout path(path 是...
本 SVN 中文操作手册将深入讲解 SVN 的基本概念、安装与配置、命令行操作以及日常开发中的实践应用。 1. SVN 基本概念: - 版本库(Repository):存储所有文件和目录变更历史的中央数据库。 - 工作副本(Working...
【SVN基本使用详解】 SVN,全称Subversion,是一种版本控制系统,用于管理软件项目的源代码和其他资源。本教程将详细介绍SVN客户端的基本使用,包括常见...理解并熟练掌握这些基本操作,将极大地提高团队的协作效率。
### SVN操作完全手册知识点解析 #### 一、SVN检出(Checkout) SVN检出是初次将远程仓库中的文件或目录下载至本地的过程。在本地文件夹右击选择“Checkout”,随后输入拥有访问权限的URL地址及账号密码,使本地...