网站设计建设公司教程,网站改版代码,网站开发协议百度,wordpress粘贴媒体库缘由
商业用途的规则#xff0c;数据与谨慎便成了不可替代的王道#xff0c;我今天也说svn#xff0c;在客户端批量备份数据。
前提
考虑跨平台与易用性#xff0c;选择批处理#xff08;.bat#xff09;#xff0c;既然是批处理#xff0c;少不了的便是命令和执行命…缘由
商业用途的规则数据与谨慎便成了不可替代的王道我今天也说svn在客户端批量备份数据。
前提
考虑跨平台与易用性选择批处理.bat既然是批处理少不了的便是命令和执行命令的平台这个执行平台的命令为svn.exe默认只有svn的服务器端用命令下面会有介绍。
解决方案
既然svn.exe是服务器端的那么客户端有没有办法安装此环境呢答案是肯定的。独立执行svn命令的安装包下载址各种操作系统都有http://subversion.apache.org/packages.html以win 7 x64的操作系统为例我下载的是如图 安装之后就会有svn.exe 这样的话用svn命令变可以搞定一切。
svn常用命令
svn add [path]
别名无
描述添加文件或目录到你的wc打上新增标记。这些文件会在下一次你提交wc的时候提交到svn服务器。
在提交前你也可以用svn revert撤销新增的文件。
访问库否
eg: svn add file.cpp svn blame Target[REV]
别名praise,annotate,ann
描述显示某个已受控文件的每一行的最后修改版本和作者
访问库是
eg: svn blame file.cpp
eg: svn blame --xml file.cpp ##加上xml参数可以以xml格式显示每一行的属性。 svn cat TARGET[REV]
别名无
描述输出指定目标的内容这里的目标一般是文件。
访问库是
eg:svn cat file.cpp
eg:svn cat file.cpp -r 2 ##显示版本号为二的file.cpp内容。
eg:svn cat file.cpp --revision HEAD ##显示最新版本的file.cpp内容。 svn changelist CLNAME TARGET...
svn changelist --remove TARGET
别名cl
描述可以将wc中的文件从逻辑上分组.
访问库否
eg:svn cl clName file.cpp file2.cpp file3.cpp ##将file.cpp等三个文件加入名叫clName的changelist
eg:svn commit --changelist clName -m ci ##将clName下的所有文件提交 svn checkout URL[REV]... [PATH]
别名co
描述检出
访问库否
eg:svn checkout file:///var/svn/repos/test file:///var/svn/repos/quiz working-copies
eg:svn checkout -r 2 file:///var/svn/repos/test mine ##check out 版本号为2的项目 svn cleanup [PATH...]
别名无
描述递归的清理WC中过期的锁和未完成的操作。
访问库否
egsvn cleanup svn commit [PATH...]
别名ci
描述把你WC的更改提交到仓库
访问库是
egsvn commit -m 日志信息 path svn copy SRC[REV]... DST
别名cp
描述:copy操作可以从WC到WCWC到URLURL到WCURL到URL。现在SVN只支持同一个仓库内文件的拷贝不允许跨仓库操作。
访问库是
egsvn copy -r 11 file:///var/svn/repos/test/trunk \ file:///var/svn/repos/test/tags/0.6.32-prerelease \ -m Forgot to tag at rev 11
##copy命令是创建分支和标记的常用方式。copy到url的操作隐含了提交动作所以需要提供log messages。 svn delete PATH...
别名delremoverm
描述删除
访问库如果PATH是库地址时会删除WC内的文件不会。
egsvn del localfile.cpp ##删除WC里的文件在下一次提交WC的时候才会真正在仓库里将对应文件删除。
eg: svn del file:///var/svn/repos/test/yourfile ##删除仓库里的文件 svn diff
别名di
描述用来比较并显示修改点。
访问库
egsvn diff ##最常用的方式用来显示WC基于最近一次更新以后的所有的本地修改点。
egsvn diff -r 301 bin ## 比较WC和版本301中的bin目录的修改点
egsvn diff -r 3000:3500 file:///var/svn/repos/myProject/trunk ##比较库里主干3000版和3500版的差异。
egsvn diff --summarize --xml http://svn.red-bean.com/repos/testr2 http://svn.red-bean.com/repos/test ##--summarize --xml 参数将差异情况以xml文档的方式显示出来。 svn export [-r REV] URL[PEGREV] [PATH]
svn export [-r REV] PATH1[PEGREV] [PATH2]
别名无
描述导出一个干净的目录树不包含所有的受控信息。可以选择从URL或WC中导出。
访问库如果访问的是URL则会。
egsvn export file:///var/svn/repos my-export ##导出到my-export目录。 svn help — Help!
别名?,h
描述不用解释了
访问库否。 svn import [PATH] URL
别名无
描述导入本地一个目录到库中。但是导入后本地的目录并不会处于受控状态。
访问库是。
egsvn import -m New import myproj http://svn.myProject.com/repos/trunk/misc svn info [TARGET[REV]...]
别名无
描述显示指定WC和URL信息。
访问库仅当访问的是库路径时。
egsvn info --xml http://svn.myProject.com/repos/test ##将信息以xml格式显示。 svn list [TARGET[REV]...]
别名ls
描述显示目标下的文件和目录列表。
访问库如果访问的是库地址就会。
egsvn list --verbose file:///var/svn/repos ##--verbose参数表示显示详细信息。 svn lock TARGET...
别名无
描述对目标获得修改锁。如果目标已被其他用户锁定则会抛出警告信息。用--force参数强制从其他用户那里获得锁。
访问库是
egsvn lock --force tree.jpg svn log [PATH]
svn log URL[REV] [PATH...]
别名无
描述从库中显示log消息。log消息代码 A added Ddeleted Mmodified Rreplaced
访问库是
egsvn log -v http://svn.myProject.com/repos/test/ foo.c bar.c ##详细显示指定URL的库中foo.c和bar.c所有版本的log信息。
egsvn log -r 14:15 ##显示当前WC的14和15版本log信息。
eg##如果版本号不连续只能采用如下方式。
$ svn log -r 14 mylog
$ svn log -r 19 mylog
$ svn log -r 27 mylog svn merge sourceURL1[N] sourceURL2[M] [WCPATH]
svn merge sourceWCPATH1N sourceWCPATH2M [WCPATH]
svn merge [[-c M]... | [-r N:M]...] [SOURCE[REV] [WCPATH]]
别名无
描述合并两个受控源的不同之处存放到一个WC里。
访问库只有当访问库地址时。
egsvn merge --reintegrate http://svn.example.com/repos/calc/branches/my-calc-branch ##合并分支上的改变项到WC往往用于分支合并到主干。
egsvn merge -r 156:157 http://svn.example.com/repos/calc/branches/my-calc-branch ##将制定URL版本156到157的所有更新合并到WC。 svn mkdir PATH...
svn mkdir URL...
别名无
描述在WC或库路径创建目录
访问库只有当访问库地址时。
egsvn mkdir newdir svn move SRC... DST
别名mv, rename, ren
描述等同于svn copy命令跟个svn delete命令。WC到URL的重命名是不被允许的。
访问库只有当访问库地址时。
egsvn move foo.c bar.c ##将foo.c改名成bar.c。 svn propdel PROPNAME [PATH...]
svn propdel PROPNAME --revprop -r REV [TARGET]
别名pdel, pd
描述从受控文件目录等删除属性。第二种是删除某个指定版本上的附加属性。
访问库只有当访问库地址时。
egsvn propdel svn:mime-type someFile ##从someFile上移除svn:mime-type这个属性。 svn propedit PROPNAME TARGET...
svn propedit PROPNAME --revprop -r REV [TARGET]
别名pedit, pe
描述编辑属性
访问库只有当访问库地址时。
egsvn propedit svn:keywords file.c ##修改file.c上的svn:keywords属性。 svn propget PROPNAME [TARGET[REV]...]
svn propget PROPNAME --revprop -r REV [URL]
别名pget,pg
描述从文件目录或版本取得指定属性的值。
访问库只有当访问库地址时。
egsvn propget svn:keywords file.c ##从file.c中取得svn:keywords属性的值 svn proplist [TARGET[REV]...]
svn proplist --revprop -r REV [TARGET]
别名plist, pl
描述列出文件、目录或版本上的所有附加属性
访问库只有当访问库地址时。
egsvn proplist --verbose file.c svn propset PROPNAME [PROPVAL | -F VALFILE] PATH...
svn propset PROPNAME --revprop -r REV [PROPVAL | -F VALFILE] [TARGET]
别名pset,ps
描述给文件、目录或版本附加属性并赋值
访问库只有当访问库地址时。
egsvn propset svn:mime-type image/jpeg file.jpg ##给file.jpg附加属性svn:mime-type 其值为image/jpeg
eg:svn propset --revprop -r 25 svn:log Journaled about trip to New York.
##给版本25补上log message
eg:svn propset svn:ignore .classpath .
##在本地忽略掉.classpath文件 svn resolve PATH...
别名无
描述将冲突的文件标记为已解决并且删掉冲突产生的临时文件。注意这个命令并不是能把冲突解决解决冲突还是得靠人工。
访问库否
egsvn resolve --accept mine-full foo.c ##1.5版本后加上--accept参数尝试自动处理冲突。 svn resolved PATH...
别名无
描述已过时被resolve --accept取代。去除冲突的状态和冲突临时文件。
访问库否 svn revert PATH...
别名无
描述还原WC中所有的本地更改。
访问库否
egsvn revert --depthinfinity . ##将整个目录所有文件还原 svn status [PATH...]
别名stat, st
描述输出WC中文件和目录的状态。如果WC提交这些状态就会同步到库里。
一般状态有 没有修改
A 新增
D 删除
M 修改
R 替代
C 冲突
I 忽略
? 未受控
! 丢失一般是将受控文件直接删除导致
访问库加上--show-updates参数时会
egsvn status wc svn switch URL[PEGREV] [PATH]
svn switch --relocate FROM TO [PATH...]
别名sw
描述将WC转向一个其他的库地址同步
访问库是
egsvn sw http://svn.myProject.com/repos/trunk/vendors . ##将当前WC切换到另一个URL svn unlock TARGET...
别名无
描述解锁
访问库是
egsvn unlock somefile svn update [PATH...]
别名up
描述更新WC更新反馈有如下几种分类。 A 新增
B 锁破坏
D 删除
U 更新
C 冲突
G 合并
E 存在的
访问库是
egsvn up -r22 ##更新到一个指定版本 我的批量svn代码 《完》