引言
为什么使用 SVN?在企业工作时,经常需要团队配合,这时一份工程需要多个人共同维护,业内称之为多人联编。联编的方式有很多种,最原始的方式就是 A 写完代码 a,B 写完代码 b….M 写完代码 m,然后由 N 负责把 a 到 m 的所有代码进行整合,而且 N 需要和所有人沟通,对所有代码都很清晰,整合时不能够出现差错,否则代码就有可能达不到预期效果。很显然这个工作是非常繁重而且效率非常低的。作为地球上最智慧的一群人,我们怎么能容忍这种低效率的工作呢。所以诞生了很多联编工具,帮助我们自己解决各种问题。其中应用最广泛的莫过于 SVN 了,当然目前 git 以其先进敏捷的特点,得到越来越多人的认可和使用,著名程序猿交友网站
Github就是提供 git 服务的网站。git 和 SVN 的区别
定义
百度百科给出 SVN 的定义:
SVN 是 Subversion 的简称,是一个开放源代码的版本控制系统,相较于 RCS、CVS,它采用了分支管理系统,它的设计目标就是取代 CVS。互联网上很多版本控制服务已从 CVS 迁移到 Subversion。说得简单一点 SVN 就是用于多个人共同开发同一个项目,共用资源的目的。
搭建 SVN 服务器
服务器的作用就如同引言中所说的工程师 N 的作用,负责整合代码,并且还能记录版本信息。
服务器的搭建过程非常简单,我们以 Windows 为例,使用基于 Apache 构建的 VisualSVN,可以
快速简单地搭建出 SVN 服务器。
- windows 环境请参考:使用 VisualSVN Server 搭建服务器
任何一台连接在局域网中的 windows 电脑都可以变成 SVN 服务器,如果把 SVN 托管到公网中,
那么在世界任何角落你都可以开心的提交你的代码了,常见于跨国、跨地区合作。 - Mac 环境请参考:Mac 环境下 svn 的使用
使用 SVN
在 Mac OS X 中,使用 SVN 可以使用命令行工具,也可以使用各种软件。我们先从命令行讲起,介绍几个简单的 SVN 命令。
SVN 基本命令:
1. 启动 svn 服务器
svnserve -d -r /Users/apple/svn
或者输入:svnserve -d -r /Users/apple/svn/mycode
2. 结束服务
killall -9 svnserve
3. CheckOut:将文件 checkout 到本地目录
svn checkout path(path是服务器上的目录)
例如:svn checkout svn://192.168.1.1/pro/domain
简写:svn co
4. Add:往版本库中添加新的文件
svn add file
例如:svn add test.php(添加test.php)
svn add *.php(添加当前..目录下所有的php.文件)
5. Commit:将改动的文件提交到版本库
svn commit -m “LogMessage“ [-N] [--no-unlock] PATH(如果选择了保持锁,就
使⽤用–no-unlock开关)
例如:svn commit -m “add test file for my test“ test.php
简写:svn ci
日常提交更改过的代码到服务器:
1. 打开终端,先定位到/Users/apple/Documents/code目录,输入:
cd /Users/apple/Documents/code
2. 输入提交指令:svn commit -m "修改日志说明"
6. Lock:unLock:加锁 / 解锁
svn lock -m "LockMessage" [--force] PATH
例如:svn lock -m "lock test file" test.php
svn unlock PATH
7. Update: 更新到某个版本
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
日常更新服务器端的代码到客户端
1. 打开终端,先定位到/Users/apple/Documents/code目录,输入:
cd /Users/apple/Documents/code
2. 输入指令:svn update
8. Status: 查看文件或者目录状态
1. svn status path(目录下的文件和子目录的状态,正常状态不显示)
【?:不在svn的控制中;M:内容被修改;C:发生冲突;A:预定加入到版本库;K:被锁定】
2. svn status -v path(显示文件和子目录状态)
第一列保持相同,第二列显示工作版本号,第三和第四列显示最后一次修改的版本号和修改人。
注:svn status、svn diff和 svn revert这三条命令在没有网络的情况下也可以执行的,原因是svn在本地的.svn中保留了本地版本的原始拷贝。
简写:svn st
9. Delete: 删除文件
svn delete path -m "delete test file"
例如:
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)
10. Log: 查看日志
svn log path
例如:svn log test.php 显示这个文件的所有修改记录,及其版本号的变化
提示:此处如果报错 Item is not readable,则需要在
svnserve.conf 文件中,设置 anon-access = none。
11. Info: 查看文件详细信息
svn info path
例如:svn info test.php
12. Diff: 比较差异
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 图形界面工具软件
SVN 图形界面工具软件有很多,在 Mac 环境下可以使用 Versions、Cornerstone 等等,这里我们只介绍一下 Cornerstone 的使用。
- Checkout
- Add
- Delete
- Revert
- Commit
- Update Update 的重点在于如何解决冲突
遇到的问题
在 Xcode 8.1 上使用 source control —> commit 时报错:
The working copy “XXX” failed to commit files.Couldn’t communicate with a helper application.* 解决方法::这里的提示可能只是 svn 帮助工具的一般处理,真正原因提示的并不是很明确,可以打开终端 **(command-line tool)使用命令行查看具体原因,然后再具体解决。代码如下:
$ cd [path] //cd到项目根目录里 $ svn commit -m "这里写提交日志说明"
如果没问题的话会显示上传信息,有问题的话会输出错误原因,我这里提示的是:
svn: E155010: Commit failed (details follow):
svn: E155010: ‘/Users/apple/Desktop//APP/Demo/Demo/Assets.xcassets/Others/appicon.imageset/appicon.png’ is scheduled for addition, but is missing大概意思是之前在 Assets.xcassets 里计划增加的图片消失产生了错误,我找到了名称为:appicon 的 Image Set,键盘 Del 删除之后再重新添加,再去 commit 就可以提交了。
总结::日常最好是通过 Xcode 添加和删除文件,以便正确更新 svn 状态(使用 Finder 操作文件可能会导致 svn 没法更新)。 如果发生提交错误,请转到命令行并使用 svn status 获取提示,出现错误,并从命令行进行修复。
# On OSX using sourcetree / git-svn getting “Can’t locate SVN/Core.pm in @INC ”
解决方法,实测有效:
sudo ln -s /Library/Developer/CommandLineTools/Library/Perl/5.18/darwin-thread-multi-2level/SVN /Applications/SourceTree.app/Contents/Resources/git_local/lib/perl5/site_perl/5.18.2/darwin-thread-multi-2level/SVN
sudo ln -s /Library/Developer/CommandLineTools/Library/Perl/5.18/darwin-thread-multi-2level/auto/SVN /Applications/SourceTree.app/Contents/Resources/git_local/lib/perl5/site_perl/5.18.2/darwin-thread-multi-2level/auto/SVN
参考文献
- Mac 环境下 svn 的使用(阅读难度:★)
在 Mac OS X 下架设和使用 Xcode 的 SVN 版本管理环境(阅读难度:★)- iOS 版本控制_ SVN / Mac 环境下 svn 的使用 (阅读难度:★★)
- GIT 和 SVN 之间的五个基本区别(阅读难度:★★★★)
- iOS 开发中 SVN 管理工具的使用
[图片上传失败…(image-28238b-1517827465013)]