`

SVN

阅读更多

下面内容转载别人的,方便自己使用

 

1.svnadmin create path  创建一个新的版本库,(path为你想创建版本库的目录路径,如创建版本库目录为cellsms:svnadmin create/home/c7mon/svn/cellsms)。

 

 

 

2.svn mkdir URL  创建目录,向版本库新添加一个目录,(立即提交,所以需要日志信息):如新增trunk目录:svn mkdir file:///home/c7mon/svn/cellsms/trunk -m "此目录的说明信息"。

 

  svn mkdir newdir 在工作拷贝下新建一个目录,如新增hello目录,即在工作拷贝(svn checkout数据的目录下):svn mkdir hello。

 

 

 

3.svn import URL 向版本库导入数据,需要日志信息。如导入当前目录下wwm目录到版本库trunk目录中:svn import file:///home/c7mon/svn/cellsms/trunk/wwm-m "日志说明信息"

 

 

 

4.svn checkout URL 导出一个工作拷贝,cd到你要存放导出数据的目录,如导出wwm目录:svn checkout file:///home/c7mon/svn/cellsms/trunk/wwm,或 svn checkoutsvn://192.168.3.33/home/c7mon/svn/cellsms/trunk/wwm。svn://方式需要用户名和密码,(svn co为svn checkout简写)。

 

 

 

5.svn commit  提交工作拷贝的修改到版本库中,如对wwm下的文件进行修改后提交:svn commit -m "",""可以为空,最好加上日志说明。svn ci 为其简写。

 

 

 

6.svn add file/dir 新添加的文件或目录,此处dir为linux命令mkdir在工作拷贝下创建的目录,不是svn mkdir命令创建的目录,所以需要svn add预订添加。svn add需要在工作拷贝下执行,如在4中svn co出的工作拷贝目录wwm下新添加了hehe.c:svn add hehe.c。 然后执行svncommit提交到版本库。

 

 

 

7.svn copy URL URL 完全的服务器端拷贝,通常用在分支和标签。 如wwm项目完成后发布版本wwm_1.0:                                                                                   

 

svn copy file:///home/c7mon/svn/cellsms/trunk/wwm file:///home/c7mon/svn/cellsms/trunk/tags/wwm_1.0 -m "it's the wwm_1.0 foranhui" 。                      或  svncopy svn://192.168.3.33/home/c7mon/svn/cellsms/trunk/wwmsvn://192.168.3.33/home/c7mon/svn/cellsms/trunk/tags/wwm_1.0 -m "it's thewwm_1.0 for anhui"。(tags目录需提前在版本库中建好。)

 

 

 

如果wwm_1.0版本出现BUG,可以拷贝tags目录下的wwm_1.0到建好的branches目录下,然后svn co 出branches下的wwm_1.0进行修改。这样trunk目录下的wwm可以继续进行开发,而不会与branches下1.0版本的修改产生冲突。当branches下的wwm_1.0版本修复bug后,可以使用svn merge命令,将修改的部分合并到trunk下的wwm工程中。

 

 

 

8.svn list URL 显示path目录下的所有属于版本库的文件和目录(简写 svn ls)

 

      如列出cellsms下目录信息:svn list svn://192.168.3.33/home/c7mon/svn/cellsms

 

9.svn info URL 显示本地或远程条目的信息。

 

       如查看cellsms下信息:svn infosvn://192.168.3.33/home/c7mon/svn/cellsms

 

10.svn log URL 查看版本日志信息。

 

       如查看cellsms下所有版本信息:svn log svn://192.168.3.33/home/c7mon/svn/cellsms

 

 

 

11.svn mergeURL@version URL 合并,应用两组源文件的差别到工作拷贝路径。

 

假设情景:trunk/smpp  trunk为smpp项目开发的主目录,当开发完成时,smpp被拷贝打标签到tags/smpp_1.0.0,这里smpp_1.0.0为发布版本。此时trunk下smpp继续进行smpp第二版本的开发,这时发现发布的smpp_1.0.0版本有BUG需要修改,于是拷贝tags下的smpp_1.0.0到分支目录branches/smpp_1.0.0进行修改。当改好smpp_1.0.0后,问题来了,我们此刻需要把修改好后的smpp_1.0.0合并到此时正在trunk目录下正在开发smpp中。

 

解决:

 

(1)一个URL,为起始状态,其后的@version,表示取版本号,这个version就是svn cp到branches成功之后的那个版本。第二个URL,为最终状态,既修改好的smpp_1.0.0的URL。 其实就是左边和右边做了 一个diff,应用到当前工作区目录,也就是trunk的工作拷贝。

此时  $svn status 就可以看到变化了

 

(2)我们需要知道smpp_1.0.0被拷贝到branches目录时得版本号,命令为:

 

svnlog -stop-on-copy svn://192.168.3.33/home/c7mon/svn/cellsms/branches/

 

(3)此命令需要在合并到trunk的工作拷贝中执行:(可以加上--dry-run选项模拟merge,但不真正的去做)

 

Svn merge

 

svn://192.168.3.33/home/c7mon/svn/cellsms/branches/mscid_1.0.0@18svn://192.168.3.33/home/c7mon/svn/cellsms/branches/mscid_1.0.0

 

 

 

(4)svn commit 提交。(是在trunk的工作拷贝中)

 

 

 

12.svn delete path/URL从工作拷贝或版本库删除一个项目。

 

    如想删除工作拷贝smpp下的main.c文件: svndelete main.c (需cd到smpp的工作拷贝的目录下)。然后 svn commit提交。

 

    如想删除trunk/smpp/main.c文件:svn delete –m “delete the main.c of smpp”

 

Svn://192.168.3.33/home/c7mon/svn/cellsms/smpp/main.c(需要日志信息,即-m “”)。然后svn commit提交。

 

 

 

13.svn revert取消所有的本地编辑。

 

如12中,你执行了svn delete后,想取消其delete操作,那么你在svn commit提交之前执行本命令。例如:svn revert main.c。

 

 

 

14. svn update更新你的工作拷贝。

 

    如你的工作拷贝为trunk下smpp,现在你想将修改的smpp_1.0.0的内容更新到你当前的工作拷贝中,你可以:svn update –rversion(version为smpp_1.0.0版本号)。如果你执行:svn update命令,则默认更新最新的版本内容到当前工作拷贝中。

 

 

 

15.svn status打印工作拷贝文件和目录的状态。

 

       如打印当前工作拷贝的状态:svnstatus –u。

 

 

 

16.svn lock 锁定工作拷贝中文件,避免其他用户修改导致冲突。

 

       如:svn lock main.c(需要在工作拷贝中执行)。

 

       如果有其他用户已锁定,你可以强制加锁,需要选项 --force。

 

17. svn unlock 解除锁定操作,如svn unlock main.c。

 

 

 

18.svn help 执行此命令可以查看svn所有的子命令。

 

  svn 子命令 --help,查看子命令选项信息,如:svn lock - -help。

 

 

 

1、将文件checkout到本地目录 

 

svn checkout path(path是服务器上的目录) 

例如:svn checkout svn://192.168.1.1/pro/domain 

简写:svn co 

2、往版本库中添加新的文件 

svn add file 

例如:svn add test.php(添加test.php) 

svn add *.php(添加当前目录下所有的php文件) 

3、将改动的文件提交到版本库 

svn commit -m “LogMessage“ [-N] [--no-unlock] PATH(如果选择了保持锁,就使用–no-unlock开关) 

例如:svn commit -m “add test file for my test“ test.php 

简写:svn ci 

4、加锁/解锁 

svn lock -m “LockMessage“ [--force] PATH 

例如:svn lock -m “lock test file“ test.php 

svn unlock PATH 

5、更新到某个版本 

svn update -r m path 

例如: 

svn update如果后面没有目录,默认将当前目录以及子目录下的所有文件都更新到最新版本。 

svn update -r 200 test.php(将版本库中的文件test.php还原到版本200) 

svn update test.php(更新,于版本库同步。如果在提交的时候提示过期的话,是因为冲突,需要先update,修改文件,然后清除svn resolved,最后再提交commit) 

简写:svn up 

6、查看文件或者目录状态 

1)svn status path(目录下的文件和子目录的状态,正常状态不显示) 

【?:不在svn的控制中;M:内容被修改;C:发生冲突;A:预定加入到版本库;K:被锁定】 

2)svn status -v path(显示文件和子目录状态) 

第一列保持相同,第二列显示工作版本号,第三和第四列显示最后一次修改的版本号和修改人。 

注:svn status、svn diff和 svn revert这三条命令在没有网络的情况下也可以执行的,原因是svn在本地的.svn中保留了本地版本的原始拷贝。 

简写:svn st 

7、删除文件 

svn delete path -m “delete test fle“ 

例如:svn delete svn://192.168.1.1/pro/domain/test.php -m “delete test file” 

或者直接svn delete test.php 然后再svn ci -m ‘delete test file‘,推荐使用这种 

简写:svn (del, remove, rm) 

8、查看日志 

svn log path 

例如:svn log test.php 显示这个文件的所有修改记录,及其版本号的变化 

9、查看文件详细信息 

svn info path 

例如:svn info test.php 

10、比较差异 

svn diff path(将修改的文件与基础版本比较) 

例如:svn diff test.php 

svn diff -r m:n path(对版本m和版本n比较差异) 

例如:svn diff -r 200:201 test.php 

简写:svn di 

11、将两个版本之间的差异合并到当前文件 

svn merge -r m:n path 

例如:svn merge -r 200:205 test.php(将版本200与205之间的差异合并到当前文件,但是一般都会产生冲突,需要处理一下) 

12、SVN 帮助 

svn help 

svn help ci 

—————————————————————————— 

以上是常用命令,下面写几个不经常用的 

—————————————————————————— 

13、版本库下的文件和目录列表 

svn list path 

显示path目录下的所有属于版本库的文件和目录 

简写:svn ls 

14、创建纳入版本控制下的新目录 

svn mkdir: 创建纳入版本控制下的新目录。 

用法: 1、mkdir PATH… 

2、mkdir URL… 

创建版本控制的目录。 

1、每一个以工作副本 PATH 指定的目录,都会创建在本地端,并且加入新增 

调度,以待下一次的提交。 

2、每个以URL指定的目录,都会透过立即提交于仓库中创建。 

在这两个情况下,所有的中间目录都必须事先存在。 

15、恢复本地修改 

svn revert: 恢复原始未改变的工作副本文件 (恢复大部份的本地修改)。revert: 

用法: revert PATH… 

注意: 本子命令不会存取网络,并且会解除冲突的状况。但是它不会恢复 

被删除的目录 

16、代码库URL变更 

svn switch (sw): 更新工作副本至不同的URL。 

用法: 1、switch URL [PATH] 

2、switch –relocate FROM TO [PATH...] 

1、更新你的工作副本,映射到一个新的URL,其行为跟“svn update”很像,也会将 

服务器上文件与本地文件合并。这是将工作副本对应到同一仓库中某个分支或者标记的 

方法。 

2、改写工作副本的URL元数据,以反映单纯的URL上的改变。当仓库的根URL变动 

(比如方案名或是主机名称变动),但是工作副本仍旧对映到同一仓库的同一目录时使用 

这个命令更新工作副本与仓库的对应关系。 

17、解决冲突 

svn resolved: 移除工作副本的目录或文件的“冲突”状态。 

用法: resolved PATH… 

注意: 本子命令不会依语法来解决冲突或是移除冲突标记;它只是移除冲突的 

相关文件,然后让 PATH 可以再次提交。 

18、输出指定文件或URL的内容。 

svn cat 目标[@版本]…如果指定了版本,将从指定的版本开始查找。 

svn cat -r PREV filename > filename (PREV 是上一版本,也可以写具体版本号,这样输出结果是可以提交的)

分享到:
评论

相关推荐

    svn插件myeclipse+svn插件

    【标题】:“svn插件myeclipse+svn插件” 【描述】:“svn 插件 myeclipse 插件文件+安装方法在压缩包内” 本文将深入探讨如何在MyEclipse集成开发环境中安装和使用Subversion(SVN)插件,以便更有效地进行版本...

    svn服务用svnsync命令双机热备

    ### SVN服务用svnsync命令实现双机热备 #### 概述 在软件开发过程中,版本控制系统(Version Control System, VCS)是必不可少的工具之一。Subversion(SVN)作为一款广受欢迎的集中式版本控制系统,在企业级项目...

    svn-win32-1.7.2.zip (win32svn) [SVN 绿色版]

    将文件解压缩到 C:\ 下,将解压缩后的 svn-win32-1.7.2 文件夹名改为 svn,然后将 C:\svn\bin 加入到系统的 PATH 环境变量中,即可开始使用。 将 svnserve.exe 设置为系统服务: sc create svn binpath= "C:\svn\...

    RapidSVN:轻量级、可视化SVN客户端RapidSVN-0.13.0.8249-PortableSoft

    RapidSVN是一款轻量级且用户友好的可视化Subversion(SVN)客户端,专为开发者和团队协作设计。Subversion是一种版本控制系统,用于管理软件项目中的文件和目录的更改历史,使得多人协同开发变得更加高效和有序。...

    获取svn最新版本号示例 以及svn常用命令

    在软件开发过程中,版本控制系统是不可或缺的工具,其中Subversion(简称svn)是广泛应用的一种集中式版本控制系统。本文将深入探讨如何获取svn的最新版本号,并介绍一些常用的svn命令。 首先,获取svn的最新版本号...

    VS2022 SVN 插件

    **Visual Studio 2022 SVN 插件详解** 在软件开发过程中,版本控制是至关重要的环节,它帮助团队协作并跟踪代码的变化。Subversion(简称SVN)是一款流行的开源版本控制系统,而AnkhSVN则是一个针对Microsoft ...

    清楚svn目录下生成的.svn文件夹

    在使用Subversion(SVN)版本控制系统管理代码时,`.svn`文件夹是SVN用于存储元数据的地方,包括版本信息、工作副本配置等。这些文件夹对于SVN的正常运行至关重要,但有时它们可能会占用大量的磁盘空间,或者在不...

    VS2019 svn插件

    VS2019 SVN插件是Visual Studio 2019开发者为了集成版本控制系统Subversion(SVN)而设计的一款工具。Subversion是一款开源的版本控制系统,它允许开发者跟踪和管理源代码的变化,便于团队协作和项目管理。VS2019 ...

    svn账号密码找回,本地svn账户查看

    在IT行业中,版本控制系统是开发团队协作的重要工具,其中Subversion(简称svn)是一种广泛应用的集中式版本控制系统。本文将详细讲解如何进行“svn账号密码找回”以及“本地svn账户查看”的操作。 首先,让我们来...

    svn清理sqlite3

    在IT行业中,版本控制系统是开发团队协作的重要工具,Subversion(简称svn)就是其中的一款广泛应用的开源版本控制系统。本文将详细讲解如何解决“svn无法清理、上传、下载”的问题,以及涉及的SQLite3数据库相关...

    如何去掉svn标记

    在软件开发过程中,版本控制系统扮演着至关重要的角色,其中Subversion(简称SVN)作为一款开源的集中式版本控制系统,被广泛应用于项目管理之中。然而,在使用SVN的过程中,用户可能会遇到一个常见的问题:如何去除...

    实例方式讲解svn目录权限设置

    svn目录权限设置详解 随着软件开发的日益复杂,版本控制系统的重要性变得更加明显。Subversion(SVN)是一种流行的版本控制系统,能够帮助开发者 efektively 管理项目的版本变更。但是,SVN的权限设置一直是开发者...

    myeclipse2017SVN插件

    【Myeclipse2017 SVN插件】是一款专为Myeclipse 2017集成开发环境设计的版本控制系统工具,它使得开发者能够在Myeclipse中直接进行SVN(Subversion)的操作,如代码的版本控制、提交、更新、解决冲突等。SVN是分布式...

    svn绿色windows版本,客户端,支持IntelliJ IDEA配置svn客户端环境

    SVN(Subversion)是一种广泛使用的版本控制系统,用于管理文件和目录的历史版本,便于团队协作和项目管理。在Windows平台上,有许多SVN客户端可供选择,其中SlikSVN是一款流行的轻量级绿色版本,尤其适合那些希望...

    清理SVN、断开SVN连接,工具

    在IT行业中,版本控制系统是开发团队协作的重要工具之一,Subversion(简称SVN)就是其中广泛应用的一款。SVN能够帮助开发者追踪代码的变化,合并不同人的修改,并管理项目的多个版本。然而,有时候我们可能需要断开...

    centos 7.9服务器 离线 搭建svn服务器

    centos 7.9服务器 离线 搭建svn服务器 ,该文章适用于 开发人员 实施人员 项目经理用于项目文档管理 代码管理,而不指定如何在centos7.9环境下离线搭建svn服务器,因为大多数的网站只是介绍yum install 的方式,但是...

    Jenkins SVN Publisher Plugins下载

    Jenkins SVN Publisher Plugin是Jenkins生态系统中的一个重要组件,主要用于自动化构建过程中的版本控制集成。它允许用户在Jenkins持续集成服务器完成构建后,自动将生成的成果物发布到Subversion(SVN)仓库中,...

    取消已设置为SVN的文件夹(清理SVN标志)

    标题 "取消已设置为SVN的文件夹(清理SVN标志)" 涉及的知识点主要集中在版本控制系统Subversion(SVN)的管理和清理上。Subversion是一种广泛使用的集中式版本控制系统,它用于跟踪文件和目录的变更,便于团队协作...

    如何通过公网以http方式访问单位的svn.让svn支持http协议

    在IT行业中,版本控制系统是开发团队协作的重要工具,而Subversion(简称SVN)就是其中的一种。本篇文章将深入探讨如何通过公网以HTTP方式访问单位的SVN服务器,使远程开发者能够便捷地进行代码同步与协作。我们将...

Global site tag (gtag.js) - Google Analytics