源代碼管理工具 SVN

基本操作

這裏寫圖片描述
1. Checkout只需要做一次!
2. 每天下班前:commit“可運行版本”
3. 每天上班前:update前一天所有代碼

使用環境

要想利用SVN管理源代碼,必須得有2套環境

服務器
1. 用於存儲客戶端上傳的源代碼
2. 可以在Windows上安裝Visual SVN Server
3. 大部分情況下,公司的開發人員不必親自搭建SVN服務器

客戶端
1. 上傳本地的源代碼到服務器,或者更新服務器的代碼到本地,保持同步
2. 可以在Mac上使用命令行、Versions、Cornerstone、Xcode
開發人員就屬於客戶端這個角色

1.Visual SVN Server下載地址:
http://www.visualsvn.com/server/download/

2.Visual SVN Server安裝:

這裏寫圖片描述

這裏寫圖片描述

這裏寫圖片描述

這裏寫圖片描述

這裏寫圖片描述

這裏寫圖片描述

3.創建代碼倉庫

這裏寫圖片描述

這裏寫圖片描述

這裏寫圖片描述

這裏寫圖片描述

4.添加用戶

這裏寫圖片描述

5.設置權限

這裏寫圖片描述

這裏寫圖片描述

6.網頁訪問服務器

這裏寫圖片描述

這裏寫圖片描述

SVN客戶端命令

  • svn checkout :下載服務器的代碼到本地 (簡寫svn co)
  • svn commit :將改動的文件提交到服務器(簡寫svn ci)
  • svn update :更新服務器的代碼到本地 (簡寫svn up)
  • svn add :向本地的版本控制庫中添加新文件
  • svn delete、svn remove :從本地的版本控制庫中刪除文件(簡寫svn del、svn rm)
  • svn move :移動文件或者目錄或文件更名
  • svn mkdir :創建納入版本控制下的新目錄
  • svn revert :撤銷之前的一切修改
  • svn merge :將兩個版本之間的差異合併到當前文件

  • svn info :查看文件的詳細信息

  • svn diff :查看不同版本的區別
  • svn log :查看日誌信息
  • svn list :列出版本庫下的文件和目錄列表
  • svn status :查看文件狀態(簡寫svn st)
  • svn help :獲取幫助信息(比如svn help ci)
  • svn lock :加鎖
  • svn unlock :解鎖

檢出

將項目檢出(下載) 至本地

  1. svn checkout URL [PATH]
  2. svn co URL [PATH]

注意:這裏的中括號[ ]代表可選(可以省略)

示例
svn checkout https://192.168.1.106/svn/Weibo/
/Users/Documents/workspace

  1. 藍色代表的是:代碼倉庫的遠程地址
  2. 橙色代表的是:將代碼下載到本地的哪個路徑

如果省略橙色的路徑,就下載到命令行當前所在的路徑

提交

將改動過的文件提交至服務器

  1. svn commit -m “註釋” [PATH]
  2. svn ci -m “註釋” [PATH]

注意:一定要養成寫註釋的良好習慣

示例
svn commit -m “修改了User.m文件”
/Users/Desktop/workspace/Weibo/branches/User.m
橙色代表的是:提交哪個文件到服務器
如果省略橙色的路徑,就將命令行所在路徑中所有改動過的文件提交到服務器

添加

提交一個新建的文件到服務器,需要2個步驟

  1. 添加新建的文件到本地的版本控制庫中:svn add
  2. 提交剛纔的添加操作到服務器:svn commit

如果直接提交一個沒有添加到本地版本控制庫中的文件,會報下面的錯誤
is not a working copy

向本地的版本控制庫中添加一個新文件
svn add PATH

示例
svn add /Users/Desktop/workspace/Weibo/branches/User.m
橙色代表的是:添加哪個文件到版本控制庫中

刪除

刪除服務器上的某個文件,需要做2個步驟

  1. 將文件從本地的版本控制庫中移除:svn delete 、svn remove
  2. 提交剛纔的刪除操作到服務器:svn commit

將文件從本地的版本控制庫中移除
svn delete PATH

示例
svn delete /Users/Desktop/workspace/Weibo/branches/User.m
橙色代表的是:將哪個文件從版本控制庫中移除

更新

將服務器的最新代碼更新到本地
svn update [PATH]

示例
svn update /Users/lnj/Desktop/workspace/Weibo/branches/User.m
橙色代表的是:更新哪個文件的內容
如果省略橙色的路徑,就更新命令行所在路徑的所有內容

將文件恢復至某個版本
svn update -r 版本號 [PATH]

常見問題總結

1.去到公司的第一天,下載公司的代碼到電腦上
svn checkout

2.修改了某個早已存在的舊文件,然後提交到服務器
svn commit

3.提交一個自己新建的文件到服務器
svn add -> svn commit

4.刪除一個早已存在的舊文件,然後同步到服務器上
svn delete -> svn commit

5.將其他同事提交的新代碼更新到自己電腦上
svn update

6.不小心寫錯了很多東西,想撤銷所寫的東西(還未把修改提交到服務器)
svn revert

7.不小心刪錯了文件,想把文件恢復回來(還未把刪除提交到服務器)
svn revert

8.不小心寫錯了很多東西,想撤銷所寫的東西(已經把修改提交到服務器)
svn update -r 版本號

9.不小心刪錯了文件,想把文件恢復回來(已經把刪除提交到服務器)
svn update -r 版本號

注意
.svn這個隱藏目錄記錄着非常關鍵的信息
千萬不要手工修改或刪除這個 .svn隱藏目錄和裏面的文件! 否則將會導致本地的工作副本被破壞,無法再進行操作

圖形界面工具

在Mac上,也可以利用SVN圖形界面工具來管理源代碼,可以大大減小使用命令行的痛苦(有些操作使用命令行會比較繁瑣,比如解決衝突)
Cornerstone / Versions / Xcode

大部分工作在Xcode中都可以完成
Xcode對SVN的支持並不是非常友好,尤其新建文件夾時,在Xcode中非常容易出問題

使用Xcode工作:先更新,再提交!
Xcode中,最好不要多人同時修改一個Storyboard!

Cornerstone添加管理倉庫

這裏寫圖片描述

Xcode5-SVN配置
1. 添加SVN地址
2. Xcode 6 is in Xcode > Preferences > Accounts > Repositories (menu on the left) > (+) Add Repository

這裏寫圖片描述

Xcode5-SVN配置-添加SVN地址

這裏寫圖片描述

Xcode5-SVN配置-設置SVN賬號

這裏寫圖片描述

Xcode5-下載服務器代碼

這裏寫圖片描述

這裏寫圖片描述

目錄規範

正規項目的SVN目錄結構一般有3個文件夾

trunk:主幹,當前開發項目的主目錄
branches:分支目錄,添加非主線功能時使用,開發測試之後,可以合併到主幹項目中
tags:標記目錄,通常作爲重大版本的備份

SVN目錄使用-案例

  1. 某團隊計劃開發一款”陌陌”項目
  2. 此項目初期已經有部分基礎代碼
  3. 研發團隊在此基礎代碼上經過3個月的努力,開發了一個功能相對完備的V1.0版本上線推廣,並取得了良好的效果(備份到Tags)
  4. 由於市場反饋良好,團隊開始着手V2.0版本的開發工作
  5. 就在V2.0版本開發進行中,發現V1.0版本中有一個嚴重的BUG,如果不及時修改,將造成嚴重的後果
  6. 研發團隊收到BUG報告後,立刻安排人員對V1.0版本進行修復,但其他研發人員則繼續開發V2.0版本的新功能
  7. 修復BUG的人員很快就找到問題原因並對問題進行了修復,並且發佈了V1.1版本供用戶升級,因此沒有造成重大損失
  8. BUG修復後,研發人員將修復後的代碼整合到研發主線中來,這樣就可以保證今後發佈的後續版本中不會再出現此問題
    就這樣,整個團隊在大家的共同努力下,有條不紊地進行着……

創建MoMo代碼倉庫
這裏寫圖片描述

這裏寫圖片描述

這裏寫圖片描述

這裏寫圖片描述

使用SVN我們應該

  1. 經常更新:降低衝突的可能性
  2. 提交前需在本機測試通過:降低將問題代碼傳到版本庫
  3. 提交時一定寫備註(註釋):方便其他員工查看和自己以後回顧
  4. 對於不需要提交的文件不要提交到版本庫

提示

  1. 每次修改之前最好先更新
  2. 每天下班前提交當天運行通過的代碼
  3. 每天上班第一件事情更新前一天的代碼
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章