PS:1.文中所有的截图都是以老版的cornerStone为参考,新版样式有出入!!
PS:2.本文所有$符号之后为在终端中执行的命令。
PS:3.基本都是总结他人的资料,自己整合修改的。感谢原作者(不知道是谁)!
版本控制系统
版本控制
版本控制(Version Control)的作用是追踪文件的变化。为什么需要版本控制?简单说,就是当你出错了,可以很容易地回到没出错时的状态。
你可能已经在不知不觉中,布置了自己的版本控制系统。比如,创建了类似下面这样的文件名:
论文_0510.doc
论文0514.doc
论文0521.doc
论文修改版.doc
论文最终不修改版.doc
这就是软件中为什么有"Save As"命令的原因。它使得你可以在不破坏源文件的基础上,得到一个类似的新文件。文件的多版本保存是一个常见问题,通常的解决办法是这样的:
- 做一个文件备份(比如Document.old.txt)。
- 在文件名中加入版本号或日期(比如Document_V1.txt,DocumentMarch2007.txt)。
- 在多人编辑的环境下,共享一个文件目录,并且要求每个人编辑完以后,在文件上做出标识。
什么是版本控制系统(VCS)?
大型的、频繁修改的、多人编写的软件项目,需要一个版本控制系统(简称VCS,行话叫做"文件数据库"),追踪文件的变化,避免出现混乱。
一次典型的使用过程是这样的:
爱丽丝add一个文件(list.txt)进入repo。然后,她又把这个文件check out,做了一次编辑(在文件中加入milk这个单词)。接着,她将修改后的文件check in,并附有一条checking message("加入了新的条目")。第二天早上,鲍勃update了他本地的working set,看到了list.txt的最新修订版,其中包含了单词"milk"。如果他使用changelog或diff,都可以发现前一天爱丽丝加入"milk"这个词。
网上有许多VCS软件可供选择,并且都有详细的教程或手册,比如SVN、CVS、RCS、Git、Perforce等等。
版本库
版本库又名仓库,英文名repository,你可以简单理解成一个目录,这个目录里面的所有文件都可以被版本控制系统管理起来,每个文件的修改、删除,都能跟踪,以便任何时刻都可以追踪历史,或者在将来某个时刻可以“还原”。
SVN
在Mac环境下,由于Mac自带了SVN的服务器端和客户端功能,所以我们可以在不装任何第三方软件的前提下使用SVN功能,不过还需做一下简单的配置。
为什么使用SVN
进行权限管理,针对不同的人,开放不同的权限。比如Alex是进行A项目的,Bob进行B项目的,那么SVN可以有效的管理每个人看到的项目,Alex不可能获得Bob的项目,同样Bob也不可能获得Alex的项目。
对于代码进行追踪,代码不会遗失。不如今天代码修改乱了,需要恢复到某一天的,那么我们只需要选择一下恢复的日期即可进行恢复。
搭建SVN服务器
1. 创建代码仓库,存储客户端上传的代码
先在~/Desktop
目录(这个目录可以是任意非中文路径)新建一个svn目录,以后可以在svn目录下创建多个仓库目录。
打开终端,切换到该目录cd ~/Desktop/svn
,创建一个learnsvn
仓库,输入命令:svnadmin create ./learnsvn
,执行成功后,会发现在该目录下多了一个LimitFree目录。
2. 配置SVN的用户权限
主要是修改./learnsvn/conf
目录下的三个文件
打开svnserve.conf,将下列配置项前面的#和空格都去掉
#anon-access = read
#auth-access = write
#password-db = passwd
#authz-db = authz
anon-access = read
代表匿名访问的时候是只读的,若改为anon-access = none
代表禁止匿名访问,需要帐号密码才能访问
打开passwd,在[users]下面添加帐号和密码
[users]
# harry = harryssecret
# sally = sallyssecret
wj = 123
student = 123456
帐号是wj,密码是123
打开authz,配置用户组和权限
我们可以将在passwd里添加的用户分配到不同的用户组里,以后的话,就可以对不同用户组设置不同的权限,没有必要对每个用户进行单独设置权限。
在[groups]下面添加组名和用户名,多个用户之间用逗号(,)隔开
[groups]
topgroup=wj,student
说明wj和student都是属于topgroup这个组的,接下来再进行权限配置。
使用[/]代表svn服务器中的所有资源库
[/]
@topgroup = rw
上面的配置说明topgroup这个组中的所有用户对所有资源库都有读写(rw)权限,组名前面要用@
如果是用户名,不用加@,比如wj这个用户有读写权限
[/]
wj = rw
3. 启动SVN服务器
在终端输入命令:svnserve -d -r ~/Desktop/svn
或svnserve -d -r ~/Desktop/svn/learnsvn
没有任何提示就说明启动成功了
4. 关闭SVN服务器
打开活动监视器,输入svnserve
,强制退出进程。
使用SVN客户端功能
SVN客户端有两种使用方式,命令行和GUI界面软件(CornerStone)
命令行工具
usage: svn <subcommand> [options] [args]
Subversion command-line client.
Type 'svn help <subcommand>' for help on a specific subcommand.
Type 'svn --version' to see the program version and RA modules
or 'svn --version --quiet' to see just the version number.
Most subcommands take file and/or directory arguments, recursing
on the directories. If no arguments are supplied to such a
command, it recurses on the current directory (inclusive) by default.
Available subcommands:
add
auth
blame (praise, annotate, ann)
cat
changelist (cl)
checkout (co)
cleanup
commit (ci)
copy (cp)
delete (del, remove, rm)
diff (di)
export
help (?, h)
import
info
list (ls)
lock
log
merge
mergeinfo
mkdir
move (mv, rename, ren)
patch
propdel (pdel, pd)
propedit (pedit, pe)
propget (pget, pg)
proplist (plist, pl)
propset (pset, ps)
relocate
resolve
resolved
revert
status (stat, st)
switch (sw)
unlock
update (up)
upgrade
Subversion is a tool for version control.
For additional information, see http://subversion.apache.org/
CornerStone
添加代码仓库
填写SVN仓库信息
基本操作
checkout(检出)
add(添加文件)
delete(删除文件)
modify (修改文件)
commit(提交)
update(更新)
resolve conflict(解决冲突)
revert(恢复初始状态)