源代碼管理工具SVN是一款非常強大的源代碼管理工具,現在國內70%-90%的公司都在使用SVN來管理源代碼,下面就讓小編給大家着重介紹一下SVN的使用,SVN的使用主要分為下面幾塊。
- SVN的使用環境
- 服務器端的配置
- 客戶端軟件的使用
- 客戶端圖形界面工具的使用
- SVN的目錄規范及使用實例
1.SVN的使用環境。
要想使用SVN管理源代碼,必須得有兩套環境
- 服務器端
-
可以用於存儲客戶端上傳的源代碼
-
可以在Windows上安裝Visual SVN Server
-
大部分情況下,公司的開發人員不必親自搭建SVN服務器,基本上你進入公司之后公司會把SVN服務器的地址和你的用戶名和密碼告訴你的,當然他要是對你不放心的話,可能會考察你幾天,然后才決定是否給你。
- 客戶端
-
上傳本地的源代碼到服務器,或者更新服務器的代碼到本地,保持同步
-
可以在Mac上使用命令行、Versions、Cornerstone-圖形化操作軟件、Xcode
-
開發人員就屬於客戶端這個角色
2.服務器端的配置
服務器端在window電腦上安裝Visual SVN Server- 下載地址http://www.visualsvn.com/server/download/
- 安裝Visual SVN Server
- 創建代碼倉庫
- 點擊左側第一個黃色文件夾,然后點擊新建,輸入名字,下一步,這樣就創建好了一個空的倉庫。
- 添加用戶
- 點擊左側第二個黃色文件夾,點擊右鍵,新建用戶,然后設置用戶名和密碼。設置完之后點擊OK提交。
- 設置權限
- 點擊你建立的倉庫,右鍵點擊,選擇properties選項。
- 點擊properties之后會出來一個界面,選中你剛才創建的用戶,然后點擊ADD。
- 訪問倉庫地址。
- 選中你建立的倉庫,然后右鍵點擊copy URL,點擊之后在我們的剪貼板就可以得到倉庫的URL了,
- 打開你電腦的瀏覽器 ,輸入剛才得到的URL,然后需要輸入用戶名和密碼,輸入之后就可以進入倉庫了。
3.SVN客戶端的配置
- 在終端中輸入
svn checkout https://192.168.1.106/svn/Weibo/ /Users/Documents/workspace
https://192.168.1.106代表的是:代碼倉庫的遠程地址-這個地址就是你剛才那個電腦的IP地址
/svn/Weibo/ /Users/Documents/workspace代表的是:將代碼下載到本地的哪個路徑
- SVN客戶端命令
- svn info :查看文件的詳細信息
- svn diff :查看不同版本的區別
- svn log :查看日志信息
-
svn list :列出版本庫下的文件和目錄列表
- svn status :查看文件狀態(簡寫svn st)
- svn help :獲取幫助信息(比如svn help ci)
-
svn lock :加鎖
- svn unlock :解鎖
- 提交
- svn commit -m "注釋" [PATH]
- 添加
- 提交一個新建的文件到服務器,需要2個步驟
- 添加新建的文件到本地的版本控制庫中:svn add
-
提交剛才的添加操作到服務器:svn commit
-
如果直接提交一個沒有添加到本地版本控制庫中的文件,會報下面的錯誤lis not a working copy
- 刪除
- 刪除服務器上的某個文件,需要做2個步驟
-
將文件從本地的版本控制庫中移除:svn delete 、svn remove
-
提交剛才的刪除操作到服務器:svn commit
-
將文件從本地的版本控制庫中移除 svn delete PATH
- 更新
-
將服務器的最新代碼更新到本地 svn update [PATH]示例
svn update [所要更新的文件路徑]
n將文件恢復至某個版本svn update -r 版本號 [PATH]
4.圖形界面工具
- 在Mac上,也可以利用SVN圖形界面工具來管理源代碼,可以大大減小使用命令行的痛苦(有些操作使用命令行會比較繁瑣,比如解決沖突)Cornerstone / Versions / Xcode大部分工作在Xcode中都可以完成
- Xcode對SVN的支持並不是非常友好,尤其新建文件夾時,在Xcode中非常容易出問題
- 使用Xcode工作:先更新,再提交!
- Xcode中,最好不要多人同時修改一個Storyboard!
- MAC里下載Cornerstone添加管理倉庫
5.目錄規范
- 正規項目的SVN目錄結構一般有3個文件夾
- trunk:主干,當前開發項目的主目錄
- branches:分支目錄,添加非主線功能時使用,開發測試之后,可以合並到主干項目中
- tags:標記目錄,通常作為重大版本的備份
6.常見問題總結
- 去到公司的第一天,下載公司的代碼到電腦上 svn checkout
- 修改了某個早已存在的舊文件,然后提交到服務器 svn commit
- 提交一個自己新建的文件到服務器
- svn add à svn commit
- 刪除一個早已存在的舊文件,然后同步到服務器上 svn delete à svn commit
- 將其他同事提交的新代碼更新到自己電腦上 svn update
- 不小心寫錯了很多東西,想撤銷所寫的東西(還未把修改提交到服務器) svn revert
- 不小心刪錯了文件,想把文件恢復回來(還未把刪除提交到服務器) svn revert
- 不小心寫錯了很多東西,想撤銷所寫的東西(已經把修改提交到服務器)svn update -r 版本號
- 不小心刪錯了文件,想把文件恢復回來(已經把刪除提交到服務器)svn update -r 版本號
-
svn這個隱藏目錄記錄着非常關鍵的信息 千萬不要手工修改或刪除這個 .svn隱藏目錄和里面的文件! 否則將會導致本地的工作副本被破壞,無法再進行操作
7.使用SVN我們應該
- 經常更新:降低沖突的可能性
-
提交前需在本機測試通過:降低將問題代碼傳到版本庫
-
提交時一定寫備注(注釋):方便其他員工查看和自己以后回顧
- 對於不需要提交的文件不要提交到版本庫
- 每次修改之前最好先更新
- 每天下班前提交當天運行通過的代碼
-
每天上班第一件事情更新前一天的代碼