有时候测试环境会让更新到指定版本,用以验证问题或者其他原因

具体方法有两种:

方法1: svn merge回滚
1) 先 svn up,保证更新到最新的版本,如2106;
2) 然后用 svn log ,查看历史修改,找出要恢复的版本,如2105 。如果想要更详细的了解情况,可以使用svn diff -r 2105:2106 [文件或目录];
3) 回滚到版本号2105:svn merge -r 2106:2105 [文件或目录],注意版本号之间的顺序,这个叫反向合并;
4) 查看当前工作版本中的文件,如test.cpp和版本号10中文件的差别:svn diff -r 2105 test.cpp, 有差别则手动改之;
5) 若无差别,则提交:svn ci -m“back to r 2105,xxxxx” [文件或目录]。这时svn库中会生成新的版本,如21。

方法2: 用svn up
前2步如方法1,然后直接 svn up -r 2105。当前的工作版本就是版本2105了。但是注意,这时svn库中会并不会生成新的版本,下次在本地svn up之后,还是会回到之前的版本。

SVN命令介绍
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变动
(比如方案名或是主机名称变动),但是工作副本仍旧对映到同一仓库的同一目录时使用
这个命令更新工作副本与仓库的对应关系。
例子:svn switch –relocate http://10.244.6.11/portal http://www.mysvn.com/myportal

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

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

19、 查找工作拷贝中的所有遗留的日志文件,删除进程中的锁 。

当Subversion改变你的工作拷贝(或是.svn 中 的任何信息),它会尽可能的小心,在修改任何事情之前,它把意图写到日志文件中去,然后执行log文件中的命令,然后删掉日志文件,这与分类帐的文件系统 架构类似。如果Subversion的操作中断了(举个例子:进程被杀死了,机器死掉了),日志文件会保存在硬盘上,通过重新执行日志文 件,Subversion可以完成上一次开始的操作,你的工作拷贝可以回到一致的状态。

这就是svn cleanup 所作的:它查找工作拷贝中的所有遗留的日志文件,删除进程中的锁。如果Subversion告诉你工作拷贝中的一部分已经“锁定 ”了,你就需要运行这个命令了。同样,svn status 将会使用L 显示锁定的项目:

$ svn status
L somedir
M somedir/foo.c

svncleanup svn cleanup svn status
M somedir/foo.c

20、 拷贝用户的一个未被版本化的目录树到版本库。
svn import 命令是拷贝用户的一个未被版本化的目录树到版本库最快的方法,如果需要,它也要建立一些中介文件。

svnadmincreate/usr/local/svn/newrepos svnadmin create /usr/local/svn/newrepos svn import mytree file:///usr/local/svn/newrepos/some/project Adding mytree/foo.c Adding mytree/bar.c Adding mytree/subdir Adding mytree/subdir/quux.h Committed revision 1.

在上一个例子里,将会拷贝目录mytree 到版本库的some/project 下:

$ svn list file:///usr/local/svn/newrepos/some/project bar.c foo.c subdir/

注意,在导入之后,原来的目录树并没有 转化成工作拷贝,为了开始工作,你还是需要运行svn checkout 导出一个工作拷贝。

另附:为SVN 加入Email通知
可以通过Subversion的Hook脚本的方式为SVN 加入邮件列表功能
编译安装了Subversion后 在源码的tools 下有一个comm-email.pl的Perl脚本,在你的档案目录下有一个hooks目录,进入到hooks目录把post-commit.tmpl 改名为post-commit并给它可执行的权限。
更改post-commit脚本 把comm-email.pl脚本的决对路径加上,否则 SVN 找不到comm-email.pl

REPOS="$1"
REV="$2"
/usr/local/svn /resp/commit-email.pl "$REPOS"
"$REV" email@address1.com email@address2.com
#log-commit.py --repository "$REPOS" --revision "$REV"

最后一行是用来记日志的 我不用这个功能 所以注释掉了

linux svn更新到指定版本相关推荐

  1. svn恢复到指定版本

    svn恢复到指定版本 1.在源文件夹右键-tortoiseSVN-show log 2.显示出来的版本 3.在要恢复到的版本上右键 4.reverse to this revision是恢复到此版本 ...

  2. win10系统更新到指定版本

    N年前配的台式机想要升级系统,目前win10v1809,打算升级v1909(因为20H1和22H2都试过了但是安装失败,猜测是硬件太老).在网上查了好久,升级方法无非是1.易升2.在线更新3.下载镜像 ...

  3. Android Studio 更新到指定版本

    一. 检测并更新最新版本 查看Android Studio 的版本: 检测及版本更新: ①Help --> Check for Updates... ② File --> Settings ...

  4. Win10如何设置更新到指定版本

    一些使用Win10的用户不愿意更新到最新版本,又怕电脑自动进行更新,所以想要设置一下只更新到指定版本,具体应该如何操作呢?下面我来告诉大家Win10如何设置更新到指定版本,一起来看看吧! 具体操作如下 ...

  5. 如何给Mac OS 更新到指定版本系统

    当Mac发布最新版本时候我们想更新到上一个大版本,但是发现只有最新的 此时在商城搜不到,我们需要在官网入手 1.在Apple网站,Apple - 技术支持 - 搜索 (中国),搜索指定的系统版本做下载 ...

  6. linux中更新perl的版本

    做生信的每次学一个软件,需要装一堆东西,而且还对perl或者pyhton的版本有要求.感觉花在软件维护上的时间就很长,要是以后有个超级计算机,每个公司去上面申请个服务器,有个专门的管理员维护就好了,需 ...

  7. 使用Nuget 安装指定版本package或者更新package到指定版本

    最近在琢磨MVC和EntityFramework,使用的VS是2013版的,在Nuget的GUI界面下安装了EntityFramework(默认安装最新版的,怎么安装指定版本还没找到),按照MVC的示 ...

  8. npm 更新升级(最新版本 | 指定版本)

    查看 npm 当前版本 $ npm -v 更新到最新版本 $ npm install -g npm 更新到指定版本 $ npm -g install npm@6.8.0 清理 npm 缓存数据 $ n ...

  9. Linux svn使用

    1.检出(check out) 功能:从SVN库中取出已有的文件. 命令行操作: 在本地创建工作空间,创建一个空的文件夹           $>mkdir filename 在新建文件夹下执行 ...

  10. Ubuntu 升级/降级 Kernel 到指定版本

    目录 文章目录 目录 升级/降级 Kernel 到指定版本 删除不需要的 Kernel. 升级/降级 Kernel 到指定版本 查看当前版本. $ uname -r 4.15.0-101-generi ...

最新文章

  1. 2022-2028年中国渣油行业市场研究及前瞻分析报告
  2. 教程:4、文件权限和访问方式
  3. 【Android 组件化】使用 Gradle 实现组件化 ( Gradle 变量定义与使用 )
  4. 浅谈线程池(上):线程池的作用及CLR线程池
  5. 进入软件开发行业必须要掌握的基础知识(2005-5-18)
  6. Mybatis-sql语句的抽取
  7. 《Python数据挖掘:概念、方法与实践》——1.5节小结
  8. 十年 IT 老兵带你通过案例学架构,附C#代码
  9. 生信分析和统计作图资源推荐
  10. 如何用Python破解验证码,适合新手练手
  11. NYOJ-58 最少步数
  12. 停止做这7件事,你的工作效率至少翻一倍!
  13. windows下Apache 启动出错的解决
  14. 移动通信技术的未来发展趋势分析
  15. 如何在 Excel 图表中添加或删除次坐标轴?
  16. Nacos注册中心和配置中心
  17. 全国大江大河实时水情数据下载
  18. linux查看进程状态
  19. 使用PyQt绘制精美的股票行情分时线图
  20. 音视频传输-之RTP/RTCP协议

热门文章

  1. java断言与断点_断言 - 游戏蛮牛 - Unreal中文翻译用户手册
  2. 高数 | 【微分方程】技巧性例题 及 李林880详解
  3. dm数据库 linux版下载,达梦(DM)数据库Linux部署安装
  4. 修改 apk 默认的安装位置(不需要 Root)
  5. SAF手持式频谱分析仪SC和手持式信号发生器SG的应用概述
  6. Unity 插件及资源28G列表
  7. vue展示日历 考勤展示_Vue编写可显示周和月模式的日历 Vue自定义日历内容的显示...
  8. srvany.exe和instsrv.exe打包exe为windows服务趟的坑
  9. 河南高二计算机会考excel,(完整版)高中信息技术学业水平考试Word、Excel操作题考点总结...
  10. 猿创征文 | 2022 我的开发者工具