您好,登錄后才能下訂單哦!
這篇文章主要介紹“svn與cvs的區別有哪些”,在日常操作中,相信很多人在svn與cvs的區別有哪些問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”svn與cvs的區別有哪些”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
區別:1、CVS的版本號是基于文件的自增序列號,而SVN的是基于全局的自增序列號,不僅針對文件,還包括目錄;2、CVS是基于RCS文件的,而SVN是基于關系數據庫或一系列二進制文件的;3、CVS允許任意的滾回,而SVN不允許遞交后滾回;4、SVN支持“零或一”事務原則,而CVS不支持;5、CVS不支持本地文件重命名提交,而SVN支持;6、CVS有四種權限,而SVN只有三種權限。
本教程操作環境:windows7系統、Subversion 1.14版、Dell G3電腦。
CVS(Concurrent Versions System):
是開發源碼的并發版本系統 。它可用于各種平臺,包括 Linux 、Unix和 Windows NT/2000/XP等。CVS免費開源,對項目進行版本管理。
功能介紹:
1、 代碼統一管理,保存所有代碼文件更改的歷史記錄。對代碼進行集中統一管理,可以方便查看新增或刪除的文件,能夠跟蹤所有代碼改動痕跡。可以隨意恢復到以前任意一個歷史版本。并避免了因為版本不同引入的深層BUG。
2、 完善的沖突解決方案,可以方便的解決文件沖突問題,而不需要借助其它的文件比較工具和手工的粘貼復制。
3、 代碼權限的管理。可以為不同的用戶設置不同的權限。可以設置訪問用戶的密碼、只讀、修改等權限,而且通過CVS ROOT目錄下的腳本,提供了相應功能擴充的接口,不但可以完成精細的權限控制,還能完成更加個性化的功能。
4、 支持方便的版本發布和分支功能。
SVN(Subversion):
SVN全名Subversion,即版本控制系統。SVN是Subversion的簡稱,是一個開放源代碼的版本控制系統,相較于RCS、CVS,它采用了分支管理系統,它的設計目標就是取代CVS。互聯網上很多版本控制服務已從CVS遷移到Subversion。
SVN是一種集中式文件版本管理系統。
集中式代碼管理的核心是服務器,所有開發者在開始新一天的工作之前必須從服務器獲取代碼,然后開發,最后解決沖突,提交。所有的版本信息都放在服務器上。如果脫離了服務器,開發者基本上是不可以工作。
(SVN)集中式管理的工作流程:
集中式代碼管理的核心是服務器,所有開發者在開始新一天的工作之前必須從服務器獲取代碼,然后開發,最后解決沖突,提交。所有的版本信息都放在服務器上。如果脫離了服務器,開發者基本上是不可以工作。
管理流程如下圖:
svn與cvs的區別
CVS | SVN | |
關于版本號 | 基于文件的自增序列號。 | 基于全局的自增序列號,而不僅僅針對文件,還包括目錄等。 |
存儲類型格式 | CVS是個基于RCS文件的版本控制系統。每個CVS文件都不過是普通的文件,加上一些額外信息。這些文件會簡單的重復本地文件的樹結構。因此,不必擔心有什么數據損失,如果必要的話你可以手工修改RCS文件。 | SVN是基于關系數據庫的(BerkleyDB)或一系列二進制文件的(FS_FS)。一方面這解決了許多問題 (例如,并行讀寫共享文件)以及添加了許多新功能(例如運行時的事務特性。)。然而另一方面,數據存儲由此變得不透明,或是說并不那么用戶友好了。那就是為什么工具軟件,對倉庫 (數據庫)變得那么重要了。 |
訪問速度 | 比較慢;因為他基于單向(服務端-->客戶端)差異化文件傳輸 | 整體而言,由于架構實現的不同, SVN的確比CVS快很多;因為采用雙向差異化文件傳輸。 在網絡上它只傳輸很少的信息并支持更多的離線模式的功能。但這也是有代價的。速度的代價就是巨大的存儲(完全備份所有的工作文件)。 |
元數據 | 只允許存儲文件 | 允許一個文件有任意都的可命名屬性。功能十分完全,但不知到底有什么用 |
文件類型 | 最初是為文本文件存儲而設計的。因此其他文件類型(二進制,統一碼)文件的支持幾乎沒有如需要的話則要有其他信息,并且客戶端服務器端都要調整。 | SVN會關心所有的文件類型,不需要你來手工操作;因為他的存儲是基于二進制的 |
滾回 | CVS允許任意的滾回,在任意一個已遞交的版本上,盡管著要華些時間(所有的文件都要分別處理)。 | SVN不允許遞交后滾回。我們建議把倉庫里好的狀態版本加到末尾,覆蓋掉損壞的版本。而損壞的版本無論如何也是會存在數據庫里的。 |
事務 | CVS中的 “零或一”事務原則根本沒有實現。如果檢入幾個文件的話(加到服務器上),很有可能部分文件完成了,而另幾個沒有。最為一個潛規則,手工糾正這些并且對余下的文件 (而不是所有文件)一一重復檢入。這樣這些文件將在兩階段中被檢入。但至今為止,因為這個功能缺少而導致的數據倉庫損壞的案例還沒有出現過。 | 支持“零或一”事務原則,這是SVN的一大優勢 |
架構、代碼、可擴展性 | CVS是個古老的系統。起初CVS只是一些運用RCS的腳本文件。后來這些腳本被組成一個單個應用程序,但內部結構仍然有待改進。直到今天,仍有人企圖從頭開始,重寫一遍CVS,但都不成功。我們曾經嘗試國重寫客戶端代碼以期更好的集成效果,但是,不成功。現在我們都不認為CVS在功能上能走到多遠了。 | Subversion的開發員的確花了許多時間在內部架構上。我們仍然不知道這些決策有多大的正確性等等。但有一點可以肯定,代碼有良好的可擴展性,增強工作也在進行著。 |
重命名、刪除操作 | 不支持本地文件重命名提交; 刪除分remove和erase兩種前者把本地和庫中文件都刪除,后者只是刪除本地文件; 不能刪除文件夾 | 支持文件重命名提交系統會提示刪除舊文件,創建新文件 刪除本地文件提交 庫中文件也被刪除 |
用戶訪問權限 | 有read、write、creat、none這四種權限,任何人不能刪除文件夾(admin也只能跑到服務器上把相應文件夾殘忍刪除?我暫時只知道這個方法……) | 只有read、write、none三種權限 creat和delete權限好象和write是捆綁在一起的 |
創建分支與基線 | CVS 在創建分支的時候,需要對所有進行分支的文件進行依次的操作,因此分支的建立成本(主要是建立分支所需的時間,或消耗的計算資源)與參與分支的文件數量成比例,項目越大,版本庫越大,文件越多,分支的建立成本越高;基線(tag)的建立與此類似。 | SVN 的分支和基線是通過執行“拷貝”來建立的:回想一下在沒有引入版本管理工具的時候我們是如何進行所謂的“分支”和“基線”管理的?答案顯然是“拷貝” — 我們通過“拷貝”或“備份”來建立基線;同樣,為支持多個開發人員可以同時進行開發,我們為每個開發人員創建一份“拷貝”。 |
到此,關于“svn與cvs的區別有哪些”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。