源代碼管理工具SVN是一款非常強大的源代碼管理工具,現在國內70%-90%的公司都在使用SVN來管理源代碼,下麵就讓小編給大家著重介紹一下SVN的使用,SVN的使用主要分為下麵幾塊。 SVN的使用環境 伺服器端的配置 客戶端軟體的使用 客戶端圖形界面工具的使用 SVN的目錄規範及使用實例 1.SVN ...
源代碼管理工具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我們應該
- 經常更新:降低衝突的可能性
- 提交前需在本機測試通過:降低將問題代碼傳到版本庫
- 提交時一定寫備註(註釋):方便其他員工查看和自己以後回顧
- 對於不需要提交的文件不要提交到版本庫
- 每次修改之前最好先更新
- 每天下班前提交當天運行通過的代碼
- 每天上班第一件事情更新前一天的代碼