SVN-源代碼管理工具

目錄

一. 了解-源代碼管理工具概述
二. 掌握-SVN的基本介紹
三. 了解-SVN服務(wù)器配置
四. 掌握-UNIX基本命令
五. 掌握-SVN終端演練(個(gè)人開發(fā))
六. 掌握-SVN終端演練(多人開發(fā)引發(fā)的問題)
七. 了解-SVN終端演練-版本回退
八. 掌握-Xcode管理SVN
九. 了解-SVN目錄規(guī)范
十. 了解-SVN 托管平臺(tái)
補(bǔ)充:




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

1. 源代碼管理工具的作用?

  • 能追蹤一個(gè)項(xiàng)目從誕生一直到定案的過程
  • 一個(gè)項(xiàng)目的所有內(nèi)容變化,無限制返回
  • 查看特定版本的修訂情況

2. 常見的源代碼管理工具有哪些?

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

3. 集中式和分布式的區(qū)別?

你可以參考以下三個(gè)網(wǎng)站:




二. 掌握-SVN的基本介紹

1. 工作場(chǎng)景

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

2. 角色解釋

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

3. 項(xiàng)目開發(fā)中的基本操作

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

4. 以上操作對(duì)應(yīng)到SVN操作體現(xiàn)

  • 1.svn import (項(xiàng)目經(jīng)理做的)
  • 2.svn checkout : 將服務(wù)器所有代碼下載到本地
  • 3.svn commit : 提交本地最新代碼到服務(wù)器
  • 4.svn update : 從服務(wù)器更新最新被修改的代碼

5. 版本控制策略(補(bǔ)充)

  • svn : 更新-修改-合并
    • 弊端: 合并時(shí)容易產(chǎn)生沖突
  • 其他版本控制策略: 鎖定-修改-解鎖
    • 弊端: 不能并行開發(fā)



三. 了解-SVN服務(wù)器配置

1. 服務(wù)器作用

  • 用于存儲(chǔ)/備份各個(gè)版本的代碼
  • 供客戶端下載/上傳/刪除代碼

2. 服務(wù)器環(huán)境搭建

3. 安裝步驟

  • 全程”下一步”,傻瓜式安裝.

4. 控制區(qū)幾個(gè)選項(xiàng)的作用

  • Repository
    • 代碼倉(cāng)庫(kù):存放不同版本的代碼
  • Users
    • 用戶列表:創(chuàng)建或者刪除用戶,代碼倉(cāng)庫(kù)設(shè)置訪問權(quán)限時(shí)使用
  • Groups
    • 分組列表:將用戶分組,可以針對(duì)每組進(jìn)行代碼倉(cāng)庫(kù)訪問授權(quán)操作

5. 訪問測(cè)試

  • 可以通過瀏覽器,輸入代碼倉(cāng)庫(kù)地址進(jìn)行訪問
  • 注意:在客戶端瀏覽器訪問時(shí),注意地址需要使用對(duì)應(yīng)的IP地址,不能使用計(jì)算機(jī)名稱.
  • 在windows下面查看ip 地址

6. 操作補(bǔ)充

  • 開始 —> 運(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 :打開文件
  • cat filename :查看文件內(nèi)容
  • more filename :分頁(yè)查看文件內(nèi)容
  • mkdir 文件夾名稱 :創(chuàng)建一個(gè)文件夾
  • mv oldFilePath newFilePath :移動(dòng)文件(可借助此命令給文件重命名)

3. 補(bǔ)充

  • . 代表當(dāng)前文件路徑
  • .. 代表上級(jí)目錄
  • 以 .開頭的文件,代表隱藏文件
    • 顯示隱藏文件: 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è)人開發(fā))

1. 命令行格式:

  • svn <subcommand> [options] [args]
  • svn 子命令 [選項(xiàng)] [參數(shù)]
  • 其中中括號(hào)里面的內(nèi)容可以省略

2. 必學(xué)命令

  • svn [子命令] --help
  • svn help [子命令]

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

1. 項(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) 創(chuàng)建項(xiàng)目
    • (2) 使用 svn add 命令將項(xiàng)目所有文件添加到本地版本控制
    • (3) 使用 svn commit 提交本地項(xiàng)目到遠(yuǎn)程服務(wù)器
2. 程序猿從服務(wù)器下載一份完整代碼到本地開始開發(fā)
  • svn checkout URL [path] --username=用戶名 --password=密碼
  • 注意: 此時(shí)本地文件夾會(huì)生成一個(gè) .svn 的隱藏文件夾, 稱作"本地版本控制庫(kù)". 專門用來記錄各個(gè)文件或文件夾的狀態(tài), 千萬不要手動(dòng)刪除; 手動(dòng)刪除后, 將無法再對(duì)項(xiàng)目進(jìn)行管理. 即使從其他地方拷貝也沒有用.
3. 修改文件提交
  • (1) 修改文件
  • (2) 使用svn commit -m "注釋" : 提交本地文件到服務(wù)器
4. 新建文件提交
  • (1) 新建文件
  • (2) 使用 svn add 命令將項(xiàng)目所有文件添加到本地版本控制
  • (3) 使用 svn commit -m "注釋" : 提交本地項(xiàng)目到遠(yuǎn)程服務(wù)器
5. 刪除文件提交
  • 一定不要手動(dòng)刪除文件*
  • (1) svn remove filename 或者 svn delete filename 從本地版本控制以及對(duì)應(yīng)文件刪除
  • (2) svn commit -m "注釋" : 提交本地操作到服務(wù)器, 使服務(wù)器也刪除對(duì)應(yīng)的文件
6. 常用命令補(bǔ)充
  • 1.svn status
    • 查看當(dāng)前工作空間內(nèi), 所有 有變化的文件 的狀態(tài)
    • 如果執(zhí)行此命令什么都沒輸出, 代表本地沒有東西要提交
  • 2.svn log
    • 查看當(dāng)前版本的操作日志(什么人, 什么時(shí)間, 做了什么操作)
7. 版本控制中,各個(gè)文件狀態(tài)參考

' ' 沒有修改
'A' 被添加到本地版本控制
'C' 沖突
'D' 被刪除(通過svn命令刪除的文件)
'I' 被忽略
'M' 被修改
'R' 被替換
‘G’ 被合并
‘U’ 已經(jīng)更新
‘E’ 已經(jīng)存在
'X' 外部定義創(chuàng)建的版本目錄
'?' 文件沒有被添加到本地版本控制
'!' 文件丟失或者不完整(不是通過svn命令刪除的文件)
'' 受控文件被其他文件阻隔

8. 注意事項(xiàng)
  • 任何本地的操作, 如果想讓服務(wù)器也做同樣的操作, 就直接通過 commit操作 提交到服務(wù)器
  • 任何向服務(wù)器提交的操作,都要加注釋 添加 -m參數(shù)



六. 掌握-SVN終端演練(多人開發(fā)引發(fā)的問題)

多人合作開發(fā)中的常見問題

問題一 : 超時(shí)
  • 問題描述: 當(dāng)本地文件版本小于服務(wù)器文件版本時(shí), 如果要提交本地文件,就會(huì)報(bào) out of date 超時(shí)錯(cuò)誤
  • 產(chǎn)生原因: SVN通過版本號(hào)管理每一個(gè)文件,如果一個(gè)文件被修改并提交到服務(wù)器,那么服務(wù)器上的對(duì)應(yīng)文件版本號(hào)就會(huì)加1, 如果你的版本號(hào)小于服務(wù)器版本號(hào),就說明,肯定有別人在后來又修改了那個(gè)文件
  • 解決方案: 針對(duì)于超時(shí)問題,對(duì)應(yīng)的解決方案,就是先從服務(wù)器更新下最新版本, 保證本地版本號(hào)與服務(wù)器版本號(hào)一致,這是文件可以提交的前提
問題二 : 沖突
  • 問題描述: 為了解決超時(shí)問題,只能更新.而在更新過程中,如果幾個(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 來告訴版本控制器已經(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終端演練-版本回退

1.版本回退概念以及原因?
  • 概念: 是指將代碼(本地代碼或者服務(wù)器代碼), 回退到之前記錄的某一特定版本
  • 原因: 如果代碼做錯(cuò)了, 想返回之前某個(gè)狀態(tài)重做;
2.修改了,但未提交的情況下, 回退代碼
  • 方案1: (大力推薦)
    • svn revert (作用:返回到上次提交后版本對(duì)應(yīng)的最原始的狀態(tài))
  • 方案2: (不推薦)
    • 刪除整個(gè)項(xiàng)目,重新checkout
3. 修改了,并且提交了的情況反悔
  • 方案1: 大力推薦

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

  • svn merge 文件名 -r 版本1:版本2:(作用: 把版本1 -> 版本2 的 diff 作用在當(dāng)前版本)

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

  • 方案2: (推薦)

    • svn update -r 指定版本號(hào)(此時(shí)本地代碼已經(jīng)變化,但是服務(wù)器沒有改變)
      --------以下步驟是為了讓服務(wù)器代碼也回滾到以前的版本----------
    • 修改部分文件
    • svn update (此時(shí)會(huì)產(chǎn)生沖突, 選擇使用自己的代碼即可)
    • 再次提交代碼
  • 方案3:忘記這個(gè)方案

    • 手動(dòng)保存需要回退的文件內(nèi)容
    • 刪除文件,提交到服務(wù)器
    • 重新添加文件,上傳到服務(wù)器



八. 掌握-Xcode管理SVN

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


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

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


checkout.png

初始化本地版本控制庫(kù).png

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


怎樣新建文件提.png

修改文件提交.png

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

  • 日志查看


    日志查看.png
  • 版本回退

    • 修改了沒有提交


      Snip20160422_13.png
    • 修改了并且已經(jīng)提交


      修改了并且已經(jīng)提交1.png

      修改了并且已經(jīng)提交2.png

5.掌握多人開發(fā)中的超時(shí)問題和沖突問題的解決

Snip20160422_16.png

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




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

1.文件目錄作用?

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

    • 我們之前更新代碼帮哈,提交代碼都是在這個(gè)文件夾進(jìn)行操作
  • brannches:分支目錄

    • 添加非主線功能時(shí)使用项郊,開發(fā)測(cè)試之后馅扣,可以合并到主干項(xiàng)目中。修復(fù)Bug着降,研發(fā)不確定的新功能都在這里做
  • tags:標(biāo)記目錄差油,通常作為重大版本的備份;

    • 如果有發(fā)布版本出現(xiàn)Bug任洞,可以快速的找到對(duì)應(yīng)版本的項(xiàng)目備份蓄喇,然后開一個(gè)分支,進(jìn)行Bug修復(fù)交掏,用于與主干區(qū)分

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

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


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

4.了解研發(fā)不確定功能模塊的流程


了解研發(fā)不確定功能模塊的流程.png



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

  1. svnspot:http://code.svnspot.com
  2. svnchina:http://www.svnchina.com
    備注賬號(hào):ming



補(bǔ)充:

  • 1.XCode對(duì)靜態(tài)庫(kù)支持不好, 有時(shí)候會(huì)無法添加到本地版本控制庫(kù); 所以進(jìn)到公司, checkout項(xiàng)目下來發(fā)現(xiàn)缺少文件, 不要著急, 直接跟人溝通.
  • 2.其實(shí)多人合作開發(fā)中, 最蛋疼的問題就是解決沖突. 此處我們演練的都是簡(jiǎn)單沖突的解決. 進(jìn)到公司后會(huì)更復(fù)雜
    • 解決方案1: 靠項(xiàng)目經(jīng)理對(duì)項(xiàng)目結(jié)構(gòu)的劃分, 把各個(gè)功能模塊間的耦合性降到最低. 盡量大家開發(fā)沒有公共文件
    • 解決方案2: 一定要多溝通, 修改某些公共文件之前說一聲
    • 解決方案3: 有點(diǎn)不要臉....不說了妆偏,自己悟去。O(∩_∩)O哈哈哈~
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末盅弛,一起剝皮案震驚了整個(gè)濱河市钱骂,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌挪鹏,老刑警劉巖见秽,帶你破解...
    沈念sama閱讀 218,858評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異讨盒,居然都是意外死亡解取,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,372評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門返顺,熙熙樓的掌柜王于貴愁眉苦臉地迎上來禀苦,“玉大人,你說我怎么就攤上這事遂鹊≌穹Γ” “怎么了?”我有些...
    開封第一講書人閱讀 165,282評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵稿辙,是天一觀的道長(zhǎng)昆码。 經(jīng)常有香客問我,道長(zhǎng)邻储,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,842評(píng)論 1 295
  • 正文 為了忘掉前任旧噪,我火速辦了婚禮吨娜,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘淘钟。我一直安慰自己宦赠,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,857評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著勾扭,像睡著了一般毡琉。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上妙色,一...
    開封第一講書人閱讀 51,679評(píng)論 1 305
  • 那天桅滋,我揣著相機(jī)與錄音,去河邊找鬼身辨。 笑死丐谋,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的煌珊。 我是一名探鬼主播号俐,決...
    沈念sama閱讀 40,406評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼定庵!你這毒婦竟也來了吏饿?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,311評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤蔬浙,失蹤者是張志新(化名)和其女友劉穎找岖,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體敛滋,經(jīng)...
    沈念sama閱讀 45,767評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡许布,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,945評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了绎晃。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片蜜唾。...
    茶點(diǎn)故事閱讀 40,090評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖庶艾,靈堂內(nèi)的尸體忽然破棺而出袁余,到底是詐尸還是另有隱情,我是刑警寧澤咱揍,帶...
    沈念sama閱讀 35,785評(píng)論 5 346
  • 正文 年R本政府宣布颖榜,位于F島的核電站,受9級(jí)特大地震影響煤裙,放射性物質(zhì)發(fā)生泄漏掩完。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,420評(píng)論 3 331
  • 文/蒙蒙 一硼砰、第九天 我趴在偏房一處隱蔽的房頂上張望且蓬。 院中可真熱鬧,春花似錦题翰、人聲如沸恶阴。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,988評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)冯事。三九已至焦匈,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間昵仅,已是汗流浹背缓熟。 一陣腳步聲響...
    開封第一講書人閱讀 33,101評(píng)論 1 271
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留岩饼,地道東北人荚虚。 一個(gè)月前我還...
    沈念sama閱讀 48,298評(píng)論 3 372
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像籍茧,于是被迫代替她去往敵國(guó)和親版述。 傳聞我的和親對(duì)象是個(gè)殘疾皇子踢代,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,033評(píng)論 2 355

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

  • 1悴务、安裝VisualSVN軟件 用于搭建服務(wù)器,添加倉(cāng)庫(kù)和配置用戶信息權(quán)限等操作(項(xiàng)目經(jīng)理需要做的位隶,員工一般不用)...
    木頭Lee閱讀 8,709評(píng)論 6 47
  • 源代碼管理工具-SVN 一. 了解-源代碼管理工具概述 1. 源代碼管理工具的作用? 能追蹤一個(gè)項(xiàng)目從誕生一直到定...
    牧馬人_hlc閱讀 1,072評(píng)論 0 11
  • 源代碼管理工具的起源 為什么會(huì)出現(xiàn)源代碼管理工具吮龄? 為了解決在軟件開發(fā)過程中俭茧,由源代碼引發(fā)的各種蛋疼繁瑣問題 源代...
    小白文_Vincent閱讀 3,172評(píng)論 2 8
  • 源代碼管理工具-SVN 一. 了解 - 源代碼管理工具概述 1. 源代碼管理工具的作用? 2. 常見的源代碼管理工...
    iYeso閱讀 450評(píng)論 0 3
  • 一. 了解 - 源代碼管理工具概述 1. 源代碼管理工具的作用? 2. 常見的源代碼管理工具有哪些? 3. 集中式...
    走道牙的人閱讀 543評(píng)論 1 3