源代碼管理工具之SVN


源代碼管理工具SVN是一款非常強大的源代碼管理工具,現在國內70%-90%的公司都在使用SVN來管理源代碼,下面就讓小編給大家着重介紹一下SVN的使用,SVN的使用主要分為下面幾塊。

  • SVN的使用環境
  • 服務器端的配置
  • 客戶端軟件的使用
  • 客戶端圖形界面工具的使用
  • SVN的目錄規范及使用實例

1.SVN的使用環境。

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

  • 服務器端
  1. 可以用於存儲客戶端上傳的源代碼
  2. 可以在Windows上安裝Visual SVN Server
  3. 大部分情況下,公司的開發人員不必親自搭建SVN服務器,基本上你進入公司之后公司會把SVN服務器的地址和你的用戶名和密碼告訴你的,當然他要是對你不放心的話,可能會考察你幾天,然后才決定是否給你。
  • 客戶端
  1. 上傳本地的源代碼到服務器,或者更新服務器的代碼到本地,保持同步
  2. 可以在Mac上使用命令行、Versions、Cornerstone-圖形化操作軟件、Xcode
  3. 開發人員就屬於客戶端這個角色

2.服務器端的配置

  服務器端在window電腦上安裝Visual SVN Server- 下載地址http://www.visualsvn.com/server/download/

  • 安裝Visual SVN Server
  • 創建代碼倉庫
  1. 點擊左側第一個黃色文件夾,然后點擊新建,輸入名字,下一步,這樣就創建好了一個空的倉庫。
  • 添加用戶
  1. 點擊左側第二個黃色文件夾,點擊右鍵,新建用戶,然后設置用戶名和密碼。設置完之后點擊OK提交。
  • 設置權限
  1. 點擊你建立的倉庫,右鍵點擊,選擇properties選項。
  2. 點擊properties之后會出來一個界面,選中你剛才創建的用戶,然后點擊ADD。
  • 訪問倉庫地址。
  1. 選中你建立的倉庫,然后右鍵點擊copy URL,點擊之后在我們的剪貼板就可以得到倉庫的URL了,
  2. 打開你電腦的瀏覽器 ,輸入剛才得到的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客戶端命令
  1. svn info :查看文件的詳細信息
  2. svn diff :查看不同版本的區別
  3. svn log :查看日志信息
  4. svn list :列出版本庫下的文件和目錄列表
  5. svn status :查看文件狀態(簡寫svn st)
  6. svn help :獲取幫助信息(比如svn help ci)
  7. svn lock :加鎖
  8. svn unlock :解鎖
  • 提交
  1. svn commit  -m "注釋"  [PATH]
  • 添加
  1. 提交一個新建的文件到服務器,需要2個步驟
  2. 添加新建的文件到本地的版本控制庫中:svn add
  3. 提交剛才的添加操作到服務器:svn commit
  4. 如果直接提交一個沒有添加到本地版本控制庫中的文件,會報下面的錯誤
    lis not a working copy
  • 刪除
  1. 刪除服務器上的某個文件,需要做2個步驟
  2. 將文件從本地的版本控制庫中移除:svn delete 、svn remove
  3. 提交剛才的刪除操作到服務器:svn commit
  4. 將文件從本地的版本控制庫中移除 svn delete PATH
  • 更新
  1. 將服務器的最新代碼更新到本地 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我們應該

  1. 經常更新:降低沖突的可能性
  2. 提交前需在本機測試通過:降低將問題代碼傳到版本庫
  3. 提交時一定寫備注(注釋):方便其他員工查看和自己以后回顧
  4. 對於不需要提交的文件不要提交到版本庫
  5. 每次修改之前最好先更新
  6. 每天下班前提交當天運行通過的代碼
  7. 每天上班第一件事情更新前一天的代碼


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM