您的位置:首页 > 运维架构 > Linux

linux常用svn命令

2013-03-11 09:02 246 查看
linux常用svn命令

 原地址:http://www.rjgc.net/control/content/content.php?nid=4418

 

      1、将文件checkout到本地目录

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

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

简写:svn co

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

svn add file

例如:svn addtest.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如何恢复误删除的数

 1、如果只是在本地删除,没有提交的话,只需要运行: 

    svn revert 文件名 

  命令即可。 

  如果是希望恢复整个目录的文件,可以用 --recursive选项: 

      svn revert --recursive 

2、如果是已经提交到服务器,那么运行: 

   svn merge命令 

   

  如,不小心将整个目录都删除了,你应首先将该目录的其他所有人的权限改为“只读”,以防止期间有其他人提交,然后通过查看历史记录查出没删除之前的版本号,接着运行如下命令进行恢复: 

  假设没删除之前的版本号为1151,删除后版本号变为1152,现在整个库的最新版本已经发展到1155了,运行: 

  svn merge http://www.scmbbs.com/repos/project1/trunk/@head http://www.scmbbs.com/repos/project1/trunk/@1151 

   注意:是“to最新版本,from老版本”的格式进行merge,因此head在前面,1151在后面。 

   

   合并完之后,再运行: 

    svn ci -m"revert the delete action" 

  进行提交到服务器。 

在到库中查看一下,发现此时被删掉的东西又回来了。

 有时候我们想丢弃对代码做过的改动。 

分两种情况: 

一、改动没有check in。这种情况下,我们使用svn revert就能把改动给扔掉了。 

  提示:CVS用户习惯于只把本地改动过的文件删掉,然后执行一次update来还原文件。在svn中也可以这么做,但最佳实践是执行svn revert,这个操作会更安全也更迅速。因为update需要去连接服务器而你没有准备好接受新的改动,而svn revert不会连接服务器也不会从服务器获取新的改动。 

二、改动已经check in。 

  这种情况下,有多种办法可以进行撤销修改。一般我们推荐用svn merge来达成目的。 

  典型的操作过程如下: 

  1、保证我们拿到的是最新代码: 

     svn update 

     假设是28版本。 

  2、然后找出要移除的确切版本: 

     svn log contacts.java 

    根据log怀疑是27版本改坏的,比较一下: 

     svn diff -r 26:27 contacts.java 

    发现果真是27版本坏事。 

  3、撤销27版本的改动: 

      svn merge -r 27:26 contacts.java 

    为了保险起见,再次确认合并的结果: 

      svn diff contacts.java 

    发现已正确撤销了改动,提交。 

  4、提交改动 

    svn commit -m "Revert wrong change from r27" 

    提交后版本变成了29。 
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: