Mac终端操控SVN

        提到源代码管理,大家多说都会想到两个东西git和svn,还有一个svn的祖宗cvs不过现在基本没人用了,相比较我还是比较喜欢git,国外已经用的相当普遍了,很多大企业也都是用git了(eg:阿里),确实是好用,但是很多企业来说觉得搭建git服务器太麻烦(确实),不搭建服务器也可以但是代码是交给github服务器托管了,也就是开源了,可能吗!公司是有多敞亮...... 当然,交钱就可以私有化的。

小白读概念:

01. 源代码管理工具概述

* 源代码管理工具的作用:

# 能追踪一个项目从诞生一直到定案的过程

# 记录一个项目的所有内容变化

# 方便地查阅特定版本的修订情况

* 如果是团队开发,使用源代码管理工具是强制性的!

* 如果是单人开发,也强烈建议现在就开始使用源代码管理工具

* 使用源代码管理工具

# 由于使用简单,不会增加工作量

# 不会对现有工作造成任何损害(坏的影响)

# 是一位合格的软件开发人员必须掌握的技术

02. SVN介绍

================================================================================

SVN 是集中式源代码管理工具

概念:

1> Repository  代码仓库,保存代码的仓库

2> Server      服务器,保存所有版本的代码仓库

3> Client      客户端,只保存当前用户的代码仓库

4> 用户名&密码  访问代码仓库需要使用自己的"用户名和密码",从而可以区分出不同的人对代码做的修改

操作:(主要的三步)

1> checkout    将服务器上最新的代码仓库下载到本地,"只需要做一次"

2> update      从服务器上将其他人所做的修改下载到本地,"每天上班必须要做的事情"

3> commit -m      将工作提交到服务器,"每天下班之前至少做一次"


详细步骤(一般都是项目经理弄)

# 切换工作目录

$ cd 经理的工作目录

# checkout服务器上的代码仓库

eg:$ svn co http://192.168.1.103/svn/weibo --username=manager --password=manager

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

02. 经理添加文件

================================================================================

* svn 常用命令

# 查看本地代码库状态

$ svn st

错误提示:"is not a working copy",必须在svn的工作目录下才能正确使用svn的命令

# 查看svn日志

$ svn log

# 查看某一个文件的日志

$ svn log filename

# 查看某一个文件某个版本的日志

$ svn log filename@1

--------------------------------------------------------------------------------

# 切换到工作目录

$ cd weibo

# 创建文件

$ touch main.c

# 打开并编写文件内容

$ open main.c

* 将文件提交到服务器

--------------------------------------------------------------------------------

# 查看工作目录状态

$ svn st

# 将文件添加到本地版本库中

$ svn add main.c

# 将文件提交到服务器的版本库中

$ svn ci -m "添加了main.c文件"

"小结" - 添加文件的两个步骤

--------------------------------------------------------------------------------

1>  将新建的文件添加到本地代码库

$ svn add main.c

2>  将刚刚添加的文件提交到服务器

$ svn ci -m "备注信息"

注意:一定要养成写注释的良好习惯

03. 团队成员加入

1>  张三

$ svn co http://10.0.1.15/svn/weibo --username=zhangsan --password=zhangsan

2>  李四

$ svn co http://10.0.1.15/svn/weibo --username=lisi --password=lisi

"小结" 至此,一个项目的搭建工作就告一段落了

1> 项目准备工作,通常由项目经理完成

2> 程序员只需要把项目 co 到本地即可

提示:新入职一家公司后,别忘记让经理分配 svn 的账号和密码

04. 张三添加文件

================================================================================

# 添加文件 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 ci -m "添加了Person类"

05. 删除文件

================================================================================

# 删除文件

$ svn rm Person.h

# 提交删除

$ svn ci -m "删除了文件"

注意:不要使用文件管理器直接删除文件

06. 撤销修改

================================================================================

$ svn revert Person.m

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

$ svn update -r 5

================================================================================

$ svn up

08. 冲突解决

(p) postpone            对比

(mc) mine-conflict      使用我的

(tc) theirs-conflict    使用对方的

svn  显示的文件状态

第1列状态说明:描述文件被添加、删除或其他修改

--------------------------------------------------------------------------------

' ' 没有修改

'A' 被添加到本地代码仓库

'C' 冲突

'D' 被删除

'I' 被忽略

'M' 被修改

'R' 被替换

'X' 外部定义创建的版本目录

'?' 文件没有被添加到本地版本库内

'!' 文件丢失或者不完整(不是通过svn命令删除的文件)

'~' 受控文件被其他文件阻隔

附录:UNIX常用命令

1.  cd      改变工作目录

2.  pwd    输出当前工作目录的绝对路径

在UNIX中要执行什么命令,一定要知道自己当前所在的工作目录

3.  ls      查看文件

$ ls        显示文件

$ ls -a    显示所有文件

$ ls -l    列表显示文件

$ ls -la    列表显示所有文件

4.  touch  用于更改文件访问和修改时间的标准UNIX程序,也被用于创建新文件

$ touch test.txt

注意:touch不修改test.txt内容,只更改它的访问、修改时间,如果test.txt不存在,它会被创建

5.  cat    连续查看文件内容

6.  more    分页查看文件内容

提示:

1>  命令和参数之间需要添加空格

2>  如果要使用当前目录中的文件名,输入到一半时,按TAB键能够补全

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

推荐阅读更多精彩内容

  • 命令的使用 1、检出 svn cohttp://路径(目录或文件的全路径)[本地目录全路径] --username...
    小李龍彪阅读 4,433评论 0 9
  • iOS 开发 SVN 版本控制器 更多技术交流请加群 iOS技术联盟 27512466 SVN是Subversio...
    Sunny_Fight阅读 8,753评论 7 63
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,637评论 18 139
  • 源代码管理工具的起源 为什么会出现源代码管理工具? 为了解决在软件开发过程中,由源代码引发的各种蛋疼繁琐问题 源代...
    小白文_Vincent阅读 3,159评论 2 8
  • 我准备出一趟远门 十天 二十天 或许更久 若是碰见一群大雁 我希望能搭上他们的航班 如果遇上一只蝴蝶 我想向她借来...
    钟政阅读 237评论 0 2