svn_TeacherGao: 高

svn的使用

一、搭建服务器
在Windows环境中,我们一般使用TortoiseSVN来搭建svn环境。在Mac环境下,由于Mac自带了svn的服务器端和客户端功能,所以我们可以在不装任何第三方软件的前提下使用svn功能,不过还需做一下简单的配置。

1、创建代码仓库,用来存储客户端所上传的代码
先在桌面上面新建一个svn目录,以后可以在svn目录下面创建多个仓库目录
打开终端,创建一个code仓库
svnadmin  create  /Users/gaokunpeng/Desktop/svn/code

2、配置svn的用户权限
主要修改/svn/code/conf目录下的三个文件
1)打开svnserve.conf,将下列配置项前面的#和空格都去掉
    1.  # anon-access = read
    2.  # auth-access = write
    3.  
    4.  # password-db = passwd
    5.  
    6.  # authz-db = authz
anon-access = read代表匿名访问的时候是只读的,若改为anon-access = none代表禁止匿名访问,需要帐号密码才能访问

2)打开passwd,在[users]下面添加帐号和密码,比如:
    1.  [users]
    2.  gkp = 123
    3.  zs = 123
帐号是gkp,密码是123

3) 打开authz,配置用户组和权限
我们可以将在passwd里添加的用户分配到不同的用户组里,以后的话,就可以对不同用户组设置不同的权限,没有必要对每个用户进行单独设置权限。
在[groups]下面添加组名和用户名,多个用户之间用逗号(,)隔开
    1.  [groups]
    2.  topgroup=gkp,zs
    3.  说明gkp和zs都是属于topgroup这个组的,接下来再进行权限配置。
使用[/]代表svn服务器中的所有资源库
    1.  [/]
    2.  @topgroup = rw
上面的配置说明topgroup这个组中的所有用户对所有资源库都有读写(rw)权限,组名前面要用@
如果是用户名,不用加@,比如gkp这个用户有读写权限
    1.  [/]
    2.  gkp = rw
至于其他精细的权限控制,可以参考authz文件中的其他内容

4) 启动svn服务器
前面配置了这么多,最关键还是看能否正常启动服务器,若启动不来,前面做再多工作也是徒劳。
在终端输入下列指令:svnserve -d -r /Users/gaokunpeng/Desktop/svn
或者输入:svnserve  -d  -r  /Users/gaokunpeng/Desktop/svn/code
没有任何提示就说明启动成功了


5)关闭svn服务器
如果你想要关闭svn服务器,最有效的办法是打开实用工具里面的“活动监视器”
ps   aux | grep svn
sudo kill -9  进程号


综合上述,我们就可以轻松搭建svn服务器环境了


二、代码的管理

1、从本地导入代码到服务器(第一次初始化导入)
在终端中输入
svn  import   /Users/gaokunpeng/Desktop/limitFree   svn://localhost/code/LimitFree  --username=gkp  --password=123   -m   "初始化导入"
我解释下指令的意思:将/Users/gaokunpeng/Desktop/limitFree中的所有内容,上传到服务器code仓库的LimitFree目录下,后面双引号中的"初始化导入"是注释

2.从服务器端下载代码到客户端本地
在终端中输入svn checkout svn://localhost/code --username=gkp  --password=123  /Users/gaokunpeng/Desktop/manager/code
我解释下指令的意思:将服务器中code仓库的内容下载到 /Users/gaokunpeng/manager/code目录中

3. 提交更改过的代码到服务器
在步骤2中已经将服务器端的代码都下载到/Users/apple/Documents/code目录中,现在修改下里面的一些代码,然后提交这些修改到服务器
1> 打开终端,先定位到/Users/gaokunpeng/manager/code目录,输入:cd   /Users/gaokunpeng/manager/code
2)打开文件,修改文件的内容
vim  Person.swift创建一个文件,然后输入文字
svn status
?  -> 新建的文件
A->添加到本地
M ->修改
vim Student.swift

svn add Person.swift

3) 输入提交指令:svn   commit   -m   "修改了main.m文件"
这个指令会将/Users/gaokunpeng/manager/code下的所有修改都同步到服务器端,假如这次我只修改了main.文件
可以看到终端的打印信息:
       1.   Adding         Person.swift
    2.  Transmitting file data .
    3.  Committed revision 2.

4.更新服务器端的代码到客户端
这个应该是最简单的指令了,在终端中定位到客户端代码目录后,比如上面的/Users/gaokunpeng/manager/code目录,然后再输入指令:svn update
 
5.至于svn的其他用法,可以在终端输入:svn help


三、多人开发
$ cd 经理的工作目录
# checkout服务器上的代码仓库
$ svn co http://192.168.1.103/svn/TestLimit --username=manager --password=manager

提示:checkout(co)之后,命令行会记录用户名和密码,后续操作不用再另行指定

# 查看本地代码库状态
$ svn st
错误提示:"is not a working copy",必须在svn的工作目录下才能正确使用svn的命令
# 查看svn日志
$ svn log
# 查看某一个文件的日志
$ svn log filename
# 查看某一个文件某个版本的日志
$ svn log filename@1

# 切换到工作目录
$ cd TestLimit
# 创建文件
$ touch main.c
# 打开并编写文件内容
$ open main.c

* 将文件提交到服务器
# 查看工作目录状态
$ svn st
# 将文件添加到本地版本库中
$ svn add main.c
# 将文件提交到服务器的版本库中
$ svn commit -m "添加了main.c文件"


# 添加文件 Person.h Person.m
$ touch Person.h Person.m
# 修改 Person.h Person.m
$ open Person.h
$ open Person.m
# 将 Person.h Person.m 添加到本地代码库
$ svn add Person.*
# 将内容提交到服务器
$ svn commit -m "添加了Person类"

# 删除文件
$ svn rm Person.h
# 提交删除
$ svn commit -m "删除了文件"


06. 撤销修改
$ svn revert Person.m

07. 恢复到之前的某个版本
$ svn log


第一种解决方式
//回退到某个版本5
$ svn update -r 5

$ svn update 
然后使用自己的代码覆盖电脑代码

第二种解决方法
注意将svnserve.conf文件里面的
anon-access值read改成none,然后重启一下svn服务器

//从11版本到5版本
$ svn merge -r  11:5  Person.swift

$ svn commit -m “回退到第五个版本”

08. 冲突解决
//如果碰到代码冲突
先svn update

(p) postpone            对比
然后修改Person文件
然后输入svn resolved  Person.swift

(mc) mine-conflict      使用我的
(tc) theirs-conflict    使用对方的


(p) postpone, (df) diff-full, (e) edit,
(mc) mine-conflict, (tc) theirs-conflict,
(s) show all options:


四、CoreStone结合Xcode的使用
01. 安装CornerStone软件

02. 具体操作

1). 添加远程代码仓库
2). 导出代码库到本地
3).  在本地目录下使用Xcode新建项目
注意:不要勾选 git,两套源代码管理同时存在会发生冲突
4).  提交到代码仓库
5).  其他用户操作

03. 忽略一些不需要上传的文件


04. SVN演练

1)  修改viewcontroller,提交
2)  添加Person类,提交
3)  代码冲突演示
4)  storyboard冲突演示
5)  利用storyboard查看历史版本,回退
6)  利用xcode checkout 项目

05. 目录规范

1)  Trunk
目前项目正在开发的版本
通常进入公司之后在该目录下开发
2)  Tags
存放已经上线的重大版本
3)  Branches
当发生重大bug或者有新需求时



最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,378评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,356评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,702评论 0 342
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,259评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,263评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,036评论 1 285
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,349评论 3 400
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,979评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,469评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,938评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,059评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,703评论 4 323
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,257评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,262评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,485评论 1 262
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,501评论 2 354
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,792评论 2 345

推荐阅读更多精彩内容