SVN的基本使用

源代碼管理工具-SVN

一. 了解-源代碼管理工具概述

1. 源代碼管理工具的作用?> 能追蹤一個(gè)項(xiàng)目從誕生一直到定案的過(guò)程> 記錄一個(gè)項(xiàng)目的所有內(nèi)容變化,無(wú)限制返回> 查看特定版本的修訂情況

2. 常見(jiàn)的源代碼管理工具有哪些?> CVS? ? - 開(kāi)啟版本控制之門? ? - 1990年誕生堕阔,“遠(yuǎn)古時(shí)代”的主流源代碼管理工具> SVN? ? - 全稱是Subversion,集中式版本控制之王者? ? - 是CVS的接班人,速度比CVS快靶衍,功能比CVS多且強(qiáng)大? ? - 在國(guó)內(nèi)軟件企業(yè)中使用最為普遍(70%-90%)> GIT? ? - 一款偉大的分布式源代碼管理工具? ? - 目前被越來(lái)越多的開(kāi)源項(xiàng)目使用? ? - 不過(guò)在國(guó)內(nèi)企業(yè)尚未大范圍普及

3. 集中式和分布式的區(qū)別集中式和分布式資料鏈接集中式和分布式資料鏈接集中式和分布式資料鏈接

二. 掌握-SVN的基本介紹

1. 工作場(chǎng)景進(jìn)入公司需要做的關(guān)于開(kāi)發(fā)的第一件事, 就是向項(xiàng)目經(jīng)理索要SVN服務(wù)器地址+用戶名+密碼

2. 角色解釋> 服務(wù)器: 用于存放所有版本的代碼,供客戶端上傳下載更新> 客戶端: 通過(guò)客戶端下載上傳本地代碼> 用戶名/密碼: 驗(yàn)證人員身份,判斷是否有操作權(quán)限;

3. 項(xiàng)目開(kāi)發(fā)中的基本操作> 1. 項(xiàng)目經(jīng)理初始化項(xiàng)目結(jié)構(gòu)并上傳到服務(wù)器> 2. 苦逼程序猿根據(jù)地址+用戶名+密碼下載一份完整代碼到本地> 3. 開(kāi)始開(kāi)發(fā),任務(wù)完成后,提交任務(wù)代碼到服務(wù)器>

?4. 從服務(wù)器上更新其他同事的代碼到本地4. 以上操作對(duì)應(yīng)到SVN操作體現(xiàn)

> 4.1. svn import (項(xiàng)目經(jīng)理做的)

> 4.2. svn checkout : 將服務(wù)器所有代碼下載到本地

> 4.3. svn commit : 提交本地最新代碼到服務(wù)器

> 4.4. svn update : 從服務(wù)器更新最新被修改的代碼

>4.5. 版本控制策略(補(bǔ)充)> svn : 更新-修改-合并? ? * 弊端:合并時(shí)容易產(chǎn)生沖突> 其他版本控制策略: 鎖定-修改-解鎖? ? * 弊端:不能并行開(kāi)發(fā)

三. 了解-SVN服務(wù)器配置服務(wù)器作用 > 用于存儲(chǔ)/備份各個(gè)版本的代碼 > 供客戶端下載/上傳/刪除代碼服務(wù)器環(huán)境搭建Mac 下直接配置(Mac 下安裝SVN), (Mac下配置SVN 服務(wù)器)Windows下安裝Visual SVN Server(Visual SVN Server下載地址) 因?yàn)樽鳛樾氯诉M(jìn)到公司無(wú)法接觸服務(wù)器,而且大部分公司都是使用windows 作為服務(wù)器,所以此處只講第二種,作學(xué)習(xí)測(cè)試使用!安裝步驟 > 全程”下一步”,傻瓜式安裝.控制區(qū)幾個(gè)選項(xiàng)的作用 > Repository? ? - 代碼倉(cāng)庫(kù):存放不同版本的代碼 > Users? ? - 用戶列表:創(chuàng)建或者刪除用戶,代碼倉(cāng)庫(kù)設(shè)置訪問(wèn)權(quán)限時(shí)使用 > Groups? ? - 分組列表:將用戶分組,可以針對(duì)每組進(jìn)行代碼倉(cāng)庫(kù)訪問(wèn)授權(quán)操作訪問(wèn)測(cè)試 > 可以通過(guò)瀏覽器,輸入代碼倉(cāng)庫(kù)地址進(jìn)行訪問(wèn) - 注意:在客戶端瀏覽器訪問(wèn)時(shí),注意地址需要使用對(duì)應(yīng)的IP地址,不能使用計(jì)算機(jī)名稱.操作補(bǔ)充 在windows下面查看ip 地址 開(kāi)始 —> 運(yùn)行? cmd? 在命令行里面? 運(yùn)行 ipconfig

四. 掌握-UNIX基本命令

1. 必學(xué)命令help [子命令] : 查看某一個(gè)具體的子命令的使用方法

2. 常用命令- cd path : 將當(dāng)前路徑切換到path路徑- pwd :查看當(dāng)前所在路徑- ls (-a / -l / -G) :? 查看當(dāng)前文件夾下所有文件及文件夾- touch filename1 filename2 : 創(chuàng)建一個(gè)或者多個(gè)文件 - rm filename : 刪除文件- open filename :打開(kāi)文件- cat filename :查看文件內(nèi)容- more filename :分頁(yè)查看文件內(nèi)容- mkdir 文件夾名稱 :創(chuàng)建一個(gè)文件夾- mv oldFilePath newFilePath :移動(dòng)文件(可借助此命令給文件重命名)

3. 補(bǔ)充.? 代表當(dāng)前文件路徑.. 代表上級(jí)目錄以 .開(kāi)頭的文件,代表隱藏文件? ? * 顯示隱藏文件? ? ? ? defaults write com.apple.finder AppleShowAllFiles Yes && killall Finder? ? * 不顯示隱藏文件? ? ? ? defaults write com.apple.finder AppleShowAllFiles No && killall Finder

4. 使用注意1>? 命令和參數(shù)之間需要添加空格2>? 如果要使用當(dāng)前目錄中的文件名恤溶,輸入到一半時(shí)柏腻,按TAB鍵能夠補(bǔ)全五. 掌握-SVN終端演練(個(gè)人開(kāi)發(fā))1. 命令格式命令行格式:? ? ? ? ? svn[options] [args]

svn 子命令 [選項(xiàng)] [參數(shù)]

其中中括號(hào)里面的內(nèi)容可以省略

2. 必學(xué)命令

svn [子命令] --help

svn help [子命令]

3. 實(shí)戰(zhàn)演練

項(xiàng)目經(jīng)理初始化項(xiàng)目,并上傳到SVN服務(wù)器

方案1:

(1) 創(chuàng)建臨時(shí)項(xiàng)目

(2) svn import [path] URL --username=用戶名 --password=密碼 -m "注釋"

方案2:

(1) svn checkout URL [path] --username=用戶名 --password=密碼 : 初始化本地倉(cāng)庫(kù)

(2) 創(chuàng)建項(xiàng)目

(3) 使用 svn add 命令將項(xiàng)目所有文件添加到本地版本控制

(4) 使用 svn commit 提交本地項(xiàng)目到遠(yuǎn)程服務(wù)器

程序猿從服務(wù)器下載一份完整代碼到本地開(kāi)始開(kāi)發(fā)

svn checkout URL [path] --username=用戶名 --password=密碼

修改文件提交

(1) 修改文件

(2) 使用svn commit -m "注釋" : 提交本地文件到服務(wù)器

新建文件提交

(1) 新建文件

(2) 使用 svn add 命令將項(xiàng)目所有文件添加到本地版本控制

(3) 使用 svn commit -m "注釋" : 提交本地項(xiàng)目到遠(yuǎn)程服務(wù)器

刪除文件提交

一定不要手動(dòng)刪除文件

(1) svn remove filename 或者 svn delete filename 從本地版本控制以及對(duì)應(yīng)文件刪除

(2) svn commit -m "注釋"? : 提交本地操作到服務(wù)器, 使服務(wù)器也刪除對(duì)應(yīng)的文件

常用命令補(bǔ)充

1. svn status

查看當(dāng)前工作空間內(nèi), 所有 有變化的文件 的狀態(tài)

如果執(zhí)行此命令什么都沒(méi)輸出, 代表本地沒(méi)有東西要提交

2. svn log

查看當(dāng)前版本的操作日志(什么人, 什么時(shí)間, 做了什么操作)

版本控制中,各個(gè)文件狀態(tài)參考

' ' 沒(méi)有修改

'A' 被添加到本地版本控制

'C' 沖突

'D' 被刪除(通過(guò)svn命令刪除的文件)

'I' 被忽略

'M' 被修改

'R' 被替換

‘G’ 被合并

‘U’ 已經(jīng)更新

‘E’ 已經(jīng)存在

'X' 外部定義創(chuàng)建的版本目錄

'?' 文件沒(méi)有被添加到本地版本控制

'!' 文件丟失或者不完整(不是通過(guò)svn命令刪除的文件)

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

注意事項(xiàng)

* 任何本地的操作, 如果想讓服務(wù)器也做同樣的操作, 就直接通過(guò) commit操作 提交到服務(wù)器

* 任何向服務(wù)器提交的操作,都要加注釋 添加 -m參數(shù)

六. 掌握-SVN終端演練(多人開(kāi)發(fā))

準(zhǔn)備工作

張三和李四,分別通過(guò)

svn checkout URL [path] --username=用戶名 --password=密碼

命令初始化本地版本控制庫(kù)

添加文件同步

1. 張三創(chuàng)建文件并提交到服務(wù)器

svn add fileName

svn commit -m "新增文件"

2. 李四從服務(wù)器更新文件

svn update

修改文件同步

1. 張三修改文件并提交到服務(wù)器

svn commit -m "修改文件"

2. 李四從服務(wù)器更新文件

svn update

刪除文件同步

1. 張三刪除文件并提交到服務(wù)器

svn delete fileName

svn commit -m "刪除文件"

2. 李四從服務(wù)器更新文件

svn update

多人合作開(kāi)發(fā)中的常見(jiàn)問(wèn)題

* 問(wèn)題一 : 超時(shí)

問(wèn)題描述:

當(dāng)本地文件版本小于服務(wù)器文件版本時(shí), 如果要提交本地文件,就會(huì)報(bào) out of date 超時(shí)錯(cuò)誤

產(chǎn)生原因:

SVN通過(guò)版本號(hào)管理每一個(gè)文件,如果一個(gè)文件被修改并提交到服務(wù)器,那么服務(wù)器上的對(duì)應(yīng)文件版本號(hào)就會(huì)加1, 如果你的版本號(hào)小于服務(wù)器版本號(hào),就說(shuō)明,肯定有別人在后來(lái)又修改了那個(gè)文件

解決方案:

針對(duì)于超時(shí)問(wèn)題,對(duì)應(yīng)的解決方案,就是先從服務(wù)器更新下最新版本, 保證本地版本號(hào)與服務(wù)器版本號(hào)一致,這是文件可以提交的前提

* 問(wèn)題二 : 沖突

問(wèn)題描述:

為了解決超時(shí)問(wèn)題,只能更新.而在更新過(guò)程中,如果幾個(gè)人修改了同一文件的同一行代碼,此時(shí)就會(huì)產(chǎn)生沖突

產(chǎn)生原因:

版本控制器不會(huì)那么智能, 去決定應(yīng)該使用誰(shuí)的代碼作為最終代碼,只能將選擇權(quán)拋給用戶,讓用戶解決

解決方案:

系統(tǒng)提供三種解決方案:

(p) postpone,

延遲處理(待會(huì)我自己處理), 如果選擇這一種, 會(huì)自動(dòng)生成三個(gè)文件供用戶參考決策. 并將沖突部分代碼塊合并到一起. 而一旦解決完畢, 需要執(zhí)行 svn resolved fileName 來(lái)告訴版本控制器已經(jīng)解決, 然后版本控制器就會(huì)自動(dòng)刪除三個(gè)參考文件

(mc) mine-conflict

使用我的(本地的), 如果代碼產(chǎn)生沖突, 則以本地代碼為準(zhǔn)

(tc) theirs-conflict

使用他人的(服務(wù)器), 如果代碼產(chǎn)生沖突, 則以服務(wù)器代碼為準(zhǔn)

<<<<<<< .mine

此處代表是我的代碼

=======

此處代表服務(wù)器代碼

>>>>>>> .r7

七. 了解-SVN終端演練-版本回退

版本回退概念以及原因?

概念: 是指將代碼(本地代碼或者服務(wù)器代碼), 回退到之前記錄的某一特定版本

原因: 如果代碼做錯(cuò)了, 想返回之前某個(gè)狀態(tài)重做;

修改了,但未提交的情況下, 回退代碼

方案1: (大力推薦)

svn revert (作用:返回到上次提交后版本對(duì)應(yīng)的最原始的狀態(tài))

方案2: (不推薦)

刪除整個(gè)項(xiàng)目,重新checkout

修改了,并且提交了的情況反悔

方案1: 大力推薦

- svn update

(作用: 將本地代碼更新到與服務(wù)器相同的版本)

- svn merge 文件名 -r 版本1:版本2

(作用: 把版本1 -> 版本2 的 diff 作用在當(dāng)前版本)

- svn commit -m “本地和服務(wù)器都回退到某一指定版本”

(作用: 讓服務(wù)器代碼也退回到之前某個(gè)版本狀態(tài))

方案2:

- svn update -r 指定版本號(hào)(此時(shí)本地代碼已經(jīng)變化,但是服務(wù)器沒(méi)有改變)

*--------以下步驟是為了讓服務(wù)器代碼也回滾到以前的版本----------*

- 修改部分文件

- svn update (此時(shí)會(huì)產(chǎn)生沖突, 選擇使用自己的代碼即可)

- 再次提交代碼

方案3:

- 手動(dòng)保存需要回退的文件內(nèi)容

- 刪除文件,提交到服務(wù)器

- 重新添加文件,上傳到服務(wù)器

八. 掌握-Cornerstone基本使用

掌握如何添加遠(yuǎn)程代碼倉(cāng)庫(kù)的關(guān)聯(lián)

掌握如何checkout, 下載服務(wù)器代碼, 以及初始化本地版本控制庫(kù)

掌握如何新建文件提交, 修改文件提交, 刪除文件提交

掌握版本日志查看, 以及了解版本回退

掌握多人開(kāi)發(fā)中的超時(shí)問(wèn)題和沖突問(wèn)題的解決

九. 掌握-Xcode管理SVN

掌握怎樣添加遠(yuǎn)程代碼倉(cāng)庫(kù)的關(guān)聯(lián)

掌握怎樣checkout, 下載服務(wù)器代碼, 以及初始化本地版本控制庫(kù)

掌握怎樣新建文件提交, 修改文件提交, 刪除文件提交

掌握版本日志查看, 以及了解版本回退

掌握多人開(kāi)發(fā)中的超時(shí)問(wèn)題和沖突問(wèn)題的解決

開(kāi)發(fā)經(jīng)驗(yàn): 最好忽略沒(méi)必要提交的文件

** 過(guò)濾不需要上傳的文件, 忽略文件(xcuserdata文件夾)**

> 文件打開(kāi)狀態(tài)

> 斷點(diǎn)信息

> 文件夾關(guān)閉打開(kāi)狀態(tài)

** 注意:projct setting文件不要忽略 **

> 存放一些文件順序和文件夾結(jié)構(gòu),文件引用等信息

十. 了解-SVN目錄規(guī)范

文件目錄作用?

trunk : 主干冯挎,當(dāng)前開(kāi)發(fā)項(xiàng)目的主目錄;

我們之前更新代碼杀饵,提交代碼都是在這個(gè)文件夾進(jìn)行操作

brannches:分支目錄

添加非主線功能時(shí)使用莽囤,開(kāi)發(fā)測(cè)試之后,可以合并到主干項(xiàng)目中切距。修復(fù)Bug朽缎,研發(fā)不確定的新功能都在這里做

tags:標(biāo)記目錄,通常作為重大版本的備份谜悟;

如果有發(fā)布版本出現(xiàn)Bug话肖,可以快速的找到對(duì)應(yīng)版本的項(xiàng)目備份,然后開(kāi)一個(gè)分支葡幸,進(jìn)行Bug修復(fù)最筒,用于與主干區(qū)分

掌握利用圖形客戶端版本備份流程

了解已發(fā)布版本bug解決流程

十一. 了解-SVN 托管平臺(tái)

1. svnspot

http://code.svnspot.com

2. svnchina

http://www.svnchina.com

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市蔚叨,隨后出現(xiàn)的幾起案子床蜘,更是在濱河造成了極大的恐慌辙培,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,214評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件邢锯,死亡現(xiàn)場(chǎng)離奇詭異虏冻,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)弹囚,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,307評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)领曼,“玉大人鸥鹉,你說(shuō)我怎么就攤上這事∈荆” “怎么了毁渗?”我有些...
    開(kāi)封第一講書人閱讀 152,543評(píng)論 0 341
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)单刁。 經(jīng)常有香客問(wèn)我灸异,道長(zhǎng),這世上最難降的妖魔是什么羔飞? 我笑而不...
    開(kāi)封第一講書人閱讀 55,221評(píng)論 1 279
  • 正文 為了忘掉前任肺樟,我火速辦了婚禮,結(jié)果婚禮上逻淌,老公的妹妹穿的比我還像新娘么伯。我一直安慰自己,他們只是感情好卡儒,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,224評(píng)論 5 371
  • 文/花漫 我一把揭開(kāi)白布田柔。 她就那樣靜靜地躺著,像睡著了一般骨望。 火紅的嫁衣襯著肌膚如雪硬爆。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書人閱讀 49,007評(píng)論 1 284
  • 那天擎鸠,我揣著相機(jī)與錄音缀磕,去河邊找鬼。 笑死劣光,一個(gè)胖子當(dāng)著我的面吹牛虐骑,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播赎线,決...
    沈念sama閱讀 38,313評(píng)論 3 399
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼廷没,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了垂寥?” 一聲冷哼從身側(cè)響起颠黎,我...
    開(kāi)封第一講書人閱讀 36,956評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤另锋,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后狭归,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體夭坪,經(jīng)...
    沈念sama閱讀 43,441評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,925評(píng)論 2 323
  • 正文 我和宋清朗相戀三年过椎,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了室梅。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,018評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡疚宇,死狀恐怖亡鼠,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情敷待,我是刑警寧澤间涵,帶...
    沈念sama閱讀 33,685評(píng)論 4 322
  • 正文 年R本政府宣布,位于F島的核電站榜揖,受9級(jí)特大地震影響勾哩,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜举哟,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,234評(píng)論 3 307
  • 文/蒙蒙 一思劳、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧妨猩,春花似錦敢艰、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 30,240評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至森瘪,卻和暖如春牡属,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背扼睬。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 31,464評(píng)論 1 261
  • 我被黑心中介騙來(lái)泰國(guó)打工逮栅, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人窗宇。 一個(gè)月前我還...
    沈念sama閱讀 45,467評(píng)論 2 352
  • 正文 我出身青樓措伐,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親军俊。 傳聞我的和親對(duì)象是個(gè)殘疾皇子侥加,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,762評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容

  • SVN(Subversion)是集中式管理的版本控制器。它只有一個(gè)單一的集中管理的服務(wù)器粪躬,保存所有文件的修訂版本,...
    mysimplebook閱讀 226評(píng)論 0 0
  • 搭建SVN服務(wù)器 配置倉(cāng)庫(kù) 配置目錄配置倉(cāng)庫(kù)-1 配置用戶 在本地創(chuàng)建存放文件的文件夾 利用命令行工具使用SVN ...
    YotrolZ閱讀 7,107評(píng)論 0 4
  • @(〓〓 iOS-實(shí)用技術(shù))[代碼管理 Git/SVN] 作者: Liwx 郵箱: 1032282633@qq....
    Liwx閱讀 46,338評(píng)論 5 84
  • 0.假設(shè)有三個(gè)用戶mgr(項(xiàng)目經(jīng)理),zs,ls同在一個(gè)項(xiàng)目組 1.新建項(xiàng)目weibo,將新項(xiàng)目的代碼導(dǎo)入到SVN...
    星空夢(mèng)想閱讀 1,177評(píng)論 1 2
  • SVN是一種集中式的版本控制工具丁存。 所有的客戶端將自己的代碼上傳到中央服務(wù)器,中央服務(wù)器的版本數(shù)據(jù)庫(kù)會(huì)保存上傳的各...
    懶懶DE鱷魚閱讀 2,894評(píng)論 0 0