Linux下SVN常用命令

时间:2022-09-20 18:31:48
  • 将文件checkout到本地目录
    #svn co http://路径(目录或文件的全路径) [本地目录全路径]
    --username 用户名 --password 密码

    #svn checkout http://路径(目录或文件的全路径) [本地目录全路径]
    --username 用户名 --password 密码

    #svn co svn://路径(目录或文件的全路径) [本地目录全路径]
    --username 用户名 --password 密码

    #svn checkout svn://路径(目录或文件的全路径) [本地目录全路径]
    --username 用户名 --password 密码

注:如果不带--password 参数传输密码的话,会提示输入密码,建议不要用明文的--password 选项。其中 username 与 password前是两个短线,不是一个。不指定本地目录全路径,则检出到当前目录下。

  • sample
    #svn co svn://localhost/daobidao /home/daobidao
    --username daobidao --password daobidao

    #svn checkout svn://localhost/daobidao /home/daobidao
    --username daobidao --password daobidao

    #svn co http://localhost/daobidao /home/daobidao
    --username daobidao --password daobidao

    #svn checkout http://localhost/daobidao /home/daobidao
    --username daobidao --password daobidao

  • 导出(导出一个干净的不带.svn文件夹的目录树)
    #svn export [-r 版本号] http://路径(目录或文件的全路径)[本地目录全路径]#svn export [-r 版本号] svn://路径(目录或文件的全路径)[本地目录全路径]#svn export 本地检出的(即带有.svn文件夹的)目录全路径 要导出的本地目录全路径
注:第一种从版本库导出干净工作目录树的形式是指定URL,如果指定了修订版本号,会导出相应的版本,
如果没有指定修订版本,则会导出最新的,导出到指定位置。如果省略本地目录全路径,URL的最后一部分会作为本地目录的名字。
第二种形式是指定 本地检出的目录全路径 到要导出的本地目录全路径,所有的本地修改将会保留,但是不在版本控制下(即没提交的新文件,因为.svn文件夹里没有与 之相关的信息记录)的文件不会拷贝。
  • sample
    #svn export svn://localhost/daobidao /home/daobidao#svn export http://localhost/daobidao /home/daobidao#svn export /home/daobidao /tmp/daobidao

    有效选项:


    -r [--revision] ARG : ARG (一些命令也接受ARG1:ARG2范围)
    版本参数可以是如下之一:
    NUMBER 版本号
    '{' DATE '}' 在指定时间以后的版本
    'HEAD' 版本库中的最新版本
    'BASE' 工作副本的基线版本
    'COMMITTED' 最后提交或基线之前
    'PREV' COMMITTED的前一版本
    -q [--quiet] : 不打印信息,或只打印概要信息
    -N [--non-recursive] : 过时;尝试 --depth=files 或 --depth=immediates
    --depth ARG : 受深度参数 ARG(“empty”,“files”,“immediates”,或“infinity”) 约束的操作
    --force : 强制操作运行
    --native-eol ARG : 使用非标准的 EOL 标记
    系统中立的文件标记 svn:eol-style 属性取值为 “native”。
    ARG 可以是以下之一“LF”,“CR”,“CRLF”
    --ignore-externals : 忽略外部项目
    全局选项:


    --username ARG : 指定用户名称 ARG
    --password ARG : 指定密码 ARG
    --no-auth-cache : 不要缓存用户认证令牌
    --non-interactive : 不要交互提示
    --trust-server-cert : 不提示的接受未知的 SSL 服务器证书(只用于选项 “--non-interactive”)
    --config-dir ARG : 从目录 ARG 读取用户配置文件
    --config-option ARG : 以下属格式设置用户配置选项:
    FILE:SECTION:OPTION=[VALUE]

  • 往版本库中添加新的文件
    #svn add filename
    注:告诉SVN服务器要添加文件了,还要用svn commint -m真实的上传上去!

  • sample
    #svn add test.php /*添加test.php*/
    #svn commit -m "添加我的测试用test.php" test.php
    #svn add *.php /*添加当前目录下所有的php文件*/
    #svn commit -m "添加我的测试用全部php文件" *.php

  • 将改动的文件提交到版本库
    #svn commit -m "提交备注信息文本" [-N] [--no-unlock] filename
    #svn ci -m "提交备注信息文本" [-N] [--no-unlock] filename

    注:必须带上-m参数,参数可以为空,但是必须写上-m

  • sample
    #svn commit -m "提交当前目录下的全部在版本控制下的文件" *
    /* 注意这个*表示全部文件*/
    #svn commit -m "提交我的测试用test.php" test.php
    #svn commit -m "提交我的测试用test.php" -N --no-unlock test.php
    /*保持锁就用–no-unlock开关*/
    #svn ci -m "提交当前目录下的全部在版本控制下的文件" *
    /*注意这个*表示全部文件*/
    #svn ci -m "提交我的测试用test.php" test.php
    #svn ci -m "提交我的测试用test.php" -N --no-unlock test.php
    /*保持锁就用–no-unlock开关*/


  • 更新到某个版本
    #svn update#svn update -r 修正版本 filename
    #svn update filename
    #svn update /*后面没有目录,默认将当前目录以及子目录下的所有文件都更新到最新版本*/
    #svn update -r 200 test.cpp /*将版本库中的文件 test.cpp还原到修正版本(revision)200*/
    #svn updatetest.php /*更新与版本库同步*/

注:提交的时候提示过期冲突,需要先 update 修改文件,然后清除svn resolved,最后再提交commit。

  • 删除文件
    #svn delete svn://路径(目录或文件的全路径) -m "删除备注信息文本"
  • 推荐如下操作
    #svn delete 文件名#svn ci -m "删除备注信息文本"

  • sample
    #svn deletesvn://192.168.1.1/testapp/test.php -m "删除测试文件test.php"
  • 推荐如下操作
    svn delete test.phpsvn ci -m "删除测试文件test.php"

  • 加锁/解锁
    svn lock -m “LockMessage“ [--force] PATH例如:svn lock -m “lock test file“ test.phpsvn unlock PATH

  • 查看文件或者目录状态
    1)svn status path(目录下的文件和子目录的状态,正常状态不显示)  【?:不在svn的控制中;M:内容被修改;C:发生冲突;A:预定加入到版本库;K:被锁定】2)svn status -v path(显示文件和子目录状态)  第一列保持相同,第二列显示工作版本号,第三和第四列显示最后一次修改的版本号和修改人。  注:svn status、svn diff和 svn revert这三条命令在没有网络的情况下也可以执行的,原因是svn在本地的.svn中保留了本地版本的原始拷贝。简写:svn st


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

  • 查看文件详细信息
    svn info path例如:svn info test.php

  • 比较差异
    svn diff path(将修改的文件与基础版本比较)
    例如:svn diff test.php
    svn diff -r m:n path(对版本m和版本n比较差异)
    例如:svn diff -r 200:201 test.php
    简写:svn di

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

  • SVN 帮助
    svn helpsvn help ci (查询ci关键字的帮助信息)


  • 版本库下的文件和目录列表
    svn list path显示path目录下的所有属于版本库的文件和目录简写:svn ls

  • 创建纳入版本控制下的新目录
    svn mkdir: 创建纳入版本控制下的新目录。用法:         1、mkdir PATH…        2、mkdir URL…创建版本控制的目录。        1、每一个以工作副本 PATH 指定的目录,都会创建在本地端,并且加入新增调度,以待下一次的提交。        2、每个以URL指定的目录,都会透过立即提交于仓库中创建。在这两个情况下,所有的中间目录都必须事先存在。

  • 恢复本地修改
    svn revert: 恢复原始未改变的工作副本文件 (恢复大部份的本地修改)。revert:         用法: revert PATH…         注意: 本子命令不会存取网络,并且会解除冲突的状况。但是它不会恢复被删除的目录

  • 代码库URL变更
    svn switch (sw): 更新工作副本至不同的URL。用法: 1、switch URL [PATH]        2、switch –relocate FROM TO [PATH...]        说明1、更新你的工作副本,映射到一个新的URL,其行为跟“svn update”很像,也会将服务器上文件与本地文件合并。这是将工作副本对应到同一仓库中某个分支或者标记的方法。        说明2、改写工作副本的URL元数据,以反映单纯的URL上的改变。当仓库的根URL变动(比如方案名或是主机名称变动),但是工作副本仍旧对映到同一仓库的同一目录时使用这个命令更新工作副本与仓库的对应关系。

  • 解决冲突
    svn resolved: 移除工作副本的目录或文件的“冲突”状态。用法: resolved PATH…注意: 本子命令不会依语法来解决冲突或是移除冲突标记;它只是移除冲突的相关文件,然后让 PATH 可以再次提交。

  • 输出指定文件或URL的内容
    svn cat 目标[@版本]…如果指定了版本,将从指定的版本开始查找。svn cat -r PREV filename > filename (PREV 是上一版本,也可以写具体版本号,这样输出结果是可以提交的)