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或者有新需求时



你可能感兴趣的:(svn_TeacherGao: 高)