##SVN常用命令说明
1.checkout 检出 svn co URL
检出app/news/apache/主干上最新版本到本地工作副本,可执行命令:
svn co https:/svn.server.com/app/news/trunk/apache/
2.up 更新到当前URL的末端 svn up
执行svn info ,根据第二行URL显示,若当前工作副本为主干,执行svn up则将版本更新到了主干末端;若当前工作副本显示为分支,执行svn up 则将版本跟新到了分支末端。
3.switch 更新到某一tag/branch svn switch (tag/分支)URL
执行svn info 查看当前工作副本在主干上,想要更新到分支news_2-23-33_BRANCH,可执行命令:
svn switch https:/svn.server.com/app/news/branches/apache/news_2-23-33_BRANCH/
4.add 增加 svn add 文件名
在本地工作副本新增test.cpp到版本库,可执行命令:
svn add test.cpp
svn ci -m "commit log"
5.rm 删除文件 svn rm 文件名
删除版本库中的test.cpp文件,可执行命令:
svn rm test.cpp svn ci -m "commit log"
删除目录 svn rm 目录名 删除版本库中的test目录,可执行命令:
svn rm test svn ci -m "commit log"
6.diff 对比 svn diff
svn diff
与base版本(最后检出或者更新到的版本)对比
svn diff -r head
与版本库中最新版本对比
svn diff -r reversion1:reversion2
当前工作副本,两个版本之间对比
svn diff (tag1)URL (tag2)URL
版本库中任意两个tag做对比
想要查看apache_2-0-32-0_PD_BL和apache_2-0-31-0_PD_BL两个tag的diff svn diff https:/svn.server.com/app/news/tags/apache/apache_2-0-32-0_PD_BL/ https:/svn.server.com/app/news/tags/apache/apache_2-0-31-0_PD_BL/
7.ci 提交 svn ci -m "commit log"
8.log 查看日志 svn log
当前工作副本log svn log
执行svn log显示如下:
r7525 | sunbing | 2010-07-14 13:53:39 +0800 (三, 2010-07-14) | 1 行 modify by sunbing
svn log -r
只查看指定版本的log
svn log -v
打印log所有附加信息
执行svn log -v
显示如下:
r7525 | sunbing | 2010-07-14 13:53:39 +0800 (三, 2010-07-14) | 1 行 改变的路径: M /branches/checkd/checked_1-0-2_BRANCH/test.docx modify by sunbing
svn log --stop-on-copy -v
查看当前tag/branch版本详情 执行svn log --stop-on-copy -v
显示如下:
r7524 | sunbing | 2010-07-14 13:52:39 +0800 (三, 2010-07-14) | 1 行 改变的路径: A /branches/checkd/checked_1-0-2_BRANCH (从 /trunk/checkd:7522) branch by sunbing
9.info 信息 svn info
查看当前工作副本所在URL
执行svn info 后我们可以从第二栏URL处,获知当前工作副本所在位置,最后修改的作者,最后修改的时间等信息如:路径: .
URL: https:/172.22.1.15/app/iknow/branches/checkd/checked_1-0-2_BRANCH
版本库根: https:/172.22.1.15/app/iknow
版本库 UUID: 94316f2c-c838-430d-ace4-078f12467ee1
版本: 7530
节点种类: 目录
调度: 正常
最后修改的作者: sunbing
最后修改的版本: 7525
最后修改的时间: 2010-07-14 13:53:39 +0800 (三, 2010-07-14)
10.status 查看工作副本的状态 svn st
查看文件的taglist svn命令不支持,可执行cs taglist
11.tag
新增tag
svn cp . (tag)URL
在本地工作副本完成修改并提交,此时,标记tag:apache_2-0-32-0_PD_BL,可执行命令:svn cp . https:/svn.server.com/app/news/tags/apache/apache_2-0-32-0_PD_BL/ -m"commit log"
删除tag
svn rm (tag)URL -m “commit log” 删除tag可直接对库进行操作,例如删除tag:apache_2-0-32-0_PD_BL,可执行命令:svn rm https:/svn.server.com/app/news/tags/apache/apache_2-0-32-0_PD_BL/ -m "commit log"
覆盖已经存在的tag
不支持
12.分支开发
创建branch
svn cp (基线版本)URL (分支)URL -m "commit log"
首先选择好创建分支的基线版本,例如要以apache模块的主干最新版本为基线创建分支,将主干代码co到本地后,可执行命令:
svn cp . https:/svn.server.com/app/news/branches/apache/news_2-23-33_BRANCH/ -m "commit log"
删除branch
svn rm (分支)URL -m "commit log"
删除tag可直接对库进行操作,例如删除分支:news_2-23-33_BRANCH,可执行命令:
svn rm https:/svn.server.com/app/news/branches/apache/news_2-23-33_BRANCH/ -m "commit log"
同步
svn co (主干)URL cd ~/wc svn merge (主干)URL (待同步tag)URL svn ci -m "commit log" svn cp (主干)URL (以_PD_BL_MAIN结尾的tag)URL -m"commit log"
当分支上的mp3_6-1-1-100_PD_BL版本上线后,目前主干上没有开发,则需要把分支上的内容同步到主干
svn co https:/svn.server.com/fe/trunk/template/mp3 #将主干最新版本检出到本地 cd mp3 #进入模块mp3的目录 svn merge https:/svn.server.com/fe/trunk/template/mp3 https:/svn.server.com/fe/tags/template/mp3/mp3_6-1-1-100_PD_BL #将mp3_6-1-1-100_PD_BL版本的内容完全覆盖到主干上 svn ci -m "commit log" #将修改提交到版本库中 svn cp https:/svn.server.com/fe/trunk/template/mp3 https:/svn.server.com/fe/tags/template/mp3/mp3_6-1-1-100_PD_BL_MAIN #同步完成后,在主干末端标记以“_PD_BL_MAIN”结尾的同步tag
合并
svn co (合并目标)URL cd ~/wc svn merge (基线版本tag)URL (上线tag)URL svn ci -m "commit log" svn cp (合并目标)URL (上线tag_MERGE_的tag对应)URL -m"commit log"
将已经上线的appac_1-0-48-4_PD_BL版本合并到正在开发中的image_5-0-18_BRANCH分支为例:
svn co https:/svn.server.com/app/image/branches/appac/image_5-0-18_BRANCH #将image_5-0-18_BRANCH分支的最新代码检出到本地工作副本 cd image_5-0-18_BRANCH #进入分支 svn merge https:/svn.server.com/app/image/tags/appac/appac_1-0-47-0_PD_BL https:/svn.server.com/app/image/tags/appac/appac_1-0-48-4_PD_BL #当前版本的基线为appac_1-0-47-0_PD_BL,将上线tag的URL内容合并进来 svn ci -m "commit log" svn cp https:/svn.server.com/app/image/trunk/appac/ https:/svn.server.com/app/image/tags/appac/appac_1-0-48-4_MERGE_image_5-0-18 -m "commit log" #合并完成后标记合并tag