基本操作
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 :解鎖
檢出
將項目檢出(下載) 至本地
- svn checkout URL [PATH]
- svn co URL [PATH]
注意:這裏的中括號[ ]代表可選(可以省略)
示例
svn checkout https://192.168.1.106/svn/Weibo/
/Users/Documents/workspace
- 藍色代表的是:代碼倉庫的遠程地址
- 橙色代表的是:將代碼下載到本地的哪個路徑
如果省略橙色的路徑,就下載到命令行當前所在的路徑
提交
將改動過的文件提交至服務器
- svn commit -m “註釋” [PATH]
- svn ci -m “註釋” [PATH]
注意:一定要養成寫註釋的良好習慣
示例
svn commit -m “修改了User.m文件”
/Users/Desktop/workspace/Weibo/branches/User.m
橙色代表的是:提交哪個文件到服務器
如果省略橙色的路徑,就將命令行所在路徑中所有改動過的文件提交到服務器
添加
提交一個新建的文件到服務器,需要2個步驟
- 添加新建的文件到本地的版本控制庫中:svn add
- 提交剛纔的添加操作到服務器:svn commit
如果直接提交一個沒有添加到本地版本控制庫中的文件,會報下面的錯誤
is not a working copy
向本地的版本控制庫中添加一個新文件
svn add PATH
示例
svn add /Users/Desktop/workspace/Weibo/branches/User.m
橙色代表的是:添加哪個文件到版本控制庫中
刪除
刪除服務器上的某個文件,需要做2個步驟
- 將文件從本地的版本控制庫中移除:svn delete 、svn remove
- 提交剛纔的刪除操作到服務器: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目錄使用-案例
- 某團隊計劃開發一款”陌陌”項目
- 此項目初期已經有部分基礎代碼
- 研發團隊在此基礎代碼上經過3個月的努力,開發了一個功能相對完備的V1.0版本上線推廣,並取得了良好的效果(備份到Tags)
- 由於市場反饋良好,團隊開始着手V2.0版本的開發工作
- 就在V2.0版本開發進行中,發現V1.0版本中有一個嚴重的BUG,如果不及時修改,將造成嚴重的後果
- 研發團隊收到BUG報告後,立刻安排人員對V1.0版本進行修復,但其他研發人員則繼續開發V2.0版本的新功能
- 修復BUG的人員很快就找到問題原因並對問題進行了修復,並且發佈了V1.1版本供用戶升級,因此沒有造成重大損失
- BUG修復後,研發人員將修復後的代碼整合到研發主線中來,這樣就可以保證今後發佈的後續版本中不會再出現此問題
就這樣,整個團隊在大家的共同努力下,有條不紊地進行着……
創建MoMo代碼倉庫
使用SVN我們應該
- 經常更新:降低衝突的可能性
- 提交前需在本機測試通過:降低將問題代碼傳到版本庫
- 提交時一定寫備註(註釋):方便其他員工查看和自己以後回顧
- 對於不需要提交的文件不要提交到版本庫
提示
- 每次修改之前最好先更新
- 每天下班前提交當天運行通過的代碼
- 每天上班第一件事情更新前一天的代碼