濮阳杆衣贸易有限公司

主頁 > 知識(shí)庫 > 詳解版本控制利器Git,SVN的異同以及適用范圍

詳解版本控制利器Git,SVN的異同以及適用范圍

熱門標(biāo)簽:滄州智能外呼系統(tǒng)收費(fèi) 忻州外呼系統(tǒng)接口對(duì)接 電銷機(jī)器人怎么收費(fèi) 地圖標(biāo)注和圖片標(biāo)注 語音平臺(tái)系統(tǒng) 醫(yī)院地圖標(biāo)注 嘟聲的電銷機(jī)器人 湖北穩(wěn)定外呼系統(tǒng) 洛陽便宜外呼系統(tǒng)廠家

使用git不久,粗淺理解:

1)適用對(duì)象不同。Git適用于參與開源項(xiàng)目的開發(fā)者。他們由于水平高,更在乎的是效率而不是易用性。Svn則不同,它適合普通的公司開發(fā)團(tuán)隊(duì)。使用起來更加容易。

2)使用的場(chǎng)合不同。Git適用于通過Internet,有多個(gè)開發(fā)角色的單個(gè)項(xiàng)目開發(fā),Svn適合企業(yè)內(nèi)部由項(xiàng)目經(jīng)理統(tǒng)一協(xié)調(diào)的多個(gè)并行項(xiàng)目的開發(fā)。

3)權(quán)限管理策略不同。Git沒有嚴(yán)格的權(quán)限管理控制,只要有帳號(hào),就可以導(dǎo)出、導(dǎo)入代碼,甚至執(zhí)行回退操作。Svn則有嚴(yán)格的權(quán)限管理,可以按組、按個(gè)人進(jìn)行針對(duì)某個(gè)子目錄的權(quán)限控制。區(qū)分讀、寫權(quán)限。更嚴(yán)格的,不支持回退操作。保證代碼永遠(yuǎn)可以追蹤。

4)分支(branch)的使用范圍不一樣。Git中,你只能針對(duì)整個(gè)倉庫作branch,而且一旦刪除,便無法恢復(fù)。而svn中,branch可以針對(duì)任何子目錄,它本質(zhì)上是一個(gè)拷貝操作。所以,可以建立非常多、層次性的branch,并且,在不需要時(shí)將其刪除,而以后需要時(shí)只要checkout老的svn版本就可以了。

5)基于第三點(diǎn),Git適用于單純的軟件項(xiàng)目,典型的就是一些開源項(xiàng)目,比如Linux內(nèi)核、busybox等。相反,Svn擅長(zhǎng)多項(xiàng)目管理。比如,你可以在一個(gè)svn倉庫中存放一個(gè)手機(jī)項(xiàng)目的bsp/設(shè)計(jì)文檔/文件系統(tǒng)/應(yīng)用程序/自動(dòng)化編譯腳本,或者在一個(gè)svn中存放5款手機(jī)項(xiàng)目的文件系統(tǒng)。git中必須建立n(項(xiàng)目數(shù))*m(組件數(shù))個(gè)倉庫。Svn中只需要最多n或者m個(gè)就可以了。

6)Git使用128位ID作為版本號(hào),而且checkout時(shí)要注明是哪個(gè)branch,而svn使用一個(gè)遞增的序列號(hào)作為全局唯一的版本號(hào),更加簡(jiǎn)明易懂。雖然可以使用gittag來建立一些文字化的別名,但是畢竟那只是針對(duì)特殊版本。

7)可跟蹤性,git的典型開發(fā)過程為:建立分支,進(jìn)行開發(fā),提交到本地master,刪除分支。這樣做的后果是以前的修改細(xì)節(jié)會(huì)丟失。而在svn下做同樣的事情,不會(huì)丟失任何細(xì)節(jié)。這里是一個(gè)有趣的鏈接,表明了git下典型的工作方式:(以master為核心,不斷創(chuàng)建新branch,刪除舊branch):

http://www.kernel.org/pub/software/scm/git/docs/howto/separating-topic-branches.txt

8)局部更新,局部還原。SVN由于是在文件夾建立一個(gè).svn文件夾來實(shí)現(xiàn)管理,所以可以很簡(jiǎn)單實(shí)現(xiàn)局部更新或者還原。假如你只希望更新某些部分,則svn可以很好實(shí)現(xiàn)。同時(shí)代碼寫錯(cuò)了,同時(shí)可以很好實(shí)現(xiàn)局部還原,當(dāng)然git也可以通過歷史版本還原,但是無法簡(jiǎn)單地實(shí)現(xiàn)局部還原。

SVN屬于集中化的版本控制系統(tǒng)

這種做法帶來了許多好處,特別是相較于老式的本地VCS來說?,F(xiàn)在,每個(gè)人都可以一定程度上看到項(xiàng)目中的其他人正在做些什么。而管理員也可以輕松掌控每個(gè)開發(fā)者的權(quán)限。

事分兩面,有好有壞。這么做最顯而易見的缺點(diǎn)是中央服務(wù)器的單點(diǎn)故障。若是宕機(jī)一小時(shí),那么在這一小時(shí)內(nèi),誰都無法提交更新、還原、對(duì)比等,也就無法協(xié)同工作。如果中央服務(wù)器的磁盤發(fā)生故障,并且沒做過備份或者備份得不夠及時(shí)的話,還會(huì)有丟失數(shù)據(jù)的風(fēng)險(xiǎn)。最壞的情況是徹底丟失整個(gè)項(xiàng)目的所有歷史更改記錄,被客戶端提取出來的某些快照數(shù)據(jù)除外,但這樣的話依然是個(gè)問題,你不能保證所有的數(shù)據(jù)都已經(jīng)有人提取出來。
Subversion原理上只關(guān)心文件內(nèi)容的具體差異。每次記錄有哪些文件作了更新,以及都更新了哪些行的什么內(nèi)容。

Subversion的特點(diǎn)概括起來主要由以下幾條:

每個(gè)版本庫有唯一的URL(官方地址),每個(gè)用戶都從這個(gè)地址獲取代碼和數(shù)據(jù);
獲取代碼的更新,也只能連接到這個(gè)唯一的版本庫,同步以取得最新數(shù)據(jù);
提交必須有網(wǎng)絡(luò)連接(非本地版本庫);
提交需要授權(quán),如果沒有寫權(quán)限,提交會(huì)失敗;
提交并非每次都能夠成功。如果有其他人先于你提交,會(huì)提示“改動(dòng)基于過時(shí)的版本,先更新再提交”… 諸如此類;
沖突解決是一個(gè)提交速度的競(jìng)賽:手快者,先提交,平安無事;手慢者,后提交,可能遇到麻煩的沖突解決。
Git屬于分布式的版本控制系統(tǒng)
自2005年誕生于以來,Git日臻成熟完善,在高度易用的同時(shí),仍然保留著初期設(shè)定的目標(biāo)。它的速度飛快,極其適合管理大項(xiàng)目,它還有著令人難以置信的非線性分支管理系統(tǒng),可以應(yīng)付各種復(fù)雜的項(xiàng)目開發(fā)需求。
與SVN不同,Git記錄版本歷史只關(guān)心文件數(shù)據(jù)的整體是否發(fā)生變化。Git并不保存文件內(nèi)容前后變化的差異數(shù)據(jù)。實(shí)際上,Git更像是把變化的文件作快照后,記錄在一個(gè)微型的文件系統(tǒng)中。每次提交更新時(shí),它會(huì)縱覽一遍所有文件的指紋信息并對(duì)文件作一快照,然后保存一個(gè)指向這次快照的索引。為提高性能,若文件沒有變化,Git不會(huì)再次保存,而只對(duì)上次保存的快照作一連接。

簡(jiǎn)略的說,Git具有以下特點(diǎn):

Git中每個(gè)克隆(clone)的版本庫都是平等的。你可以從任何一個(gè)版本庫的克隆來創(chuàng)建屬于你自己的版本庫,同時(shí)你的版本庫也可以作為源提供給他人,只要你愿意。
Git的每一次提取操作,實(shí)際上都是一次對(duì)代碼倉庫的完整備份。提交完全在本地完成,無須別人給你授權(quán),你的版本庫你作主,并且提交總是會(huì)成功。
甚至基于舊版本的改動(dòng)也可以成功提交,提交會(huì)基于舊的版本創(chuàng)建一個(gè)新的分支。
Git的提交不會(huì)被打斷,直到你的工作完全滿意了,PUSH給他人或者他人PULL你的版本庫,合并會(huì)發(fā)生在PULL和PUSH過程中,不能自動(dòng)解決的沖突會(huì)提示您手工完成。
沖突解決不再像是SVN一樣的提交競(jìng)賽,而是在需要的時(shí)候才進(jìn)行合并和沖突解決。
總之,公司的開發(fā)團(tuán)隊(duì)在進(jìn)行的項(xiàng)目開發(fā)管理時(shí),svn是更好的選擇,團(tuán)隊(duì)成員共同維護(hù)公司的中心版本。

若是開源項(xiàng)目,則git更加適合,每個(gè)人都可以維護(hù)自己專屬的版本,同時(shí)有g(shù)ithub開源社區(qū)支持。

您可能感興趣的文章:
  • 如何巧用vimdiff來替代原始的svn diff和git diff(效率提升)
  • git和SVN的區(qū)別小結(jié)
  • vscode添加GIT和SVN的方法示例
  • IntelliJ IDEA 中g(shù)it的使用圖文教程
  • idea中g(shù)it從碼云克隆項(xiàng)目到本地的方法
  • IDEA 2020 設(shè)置項(xiàng)目集成git 及svn和git之間的切換問題

標(biāo)簽:防城港 定州 山南 宜賓 96 巴彥淖爾 日照 內(nèi)蒙古

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《詳解版本控制利器Git,SVN的異同以及適用范圍》,本文關(guān)鍵詞  詳解,版本,控制,利器,Git,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《詳解版本控制利器Git,SVN的異同以及適用范圍》相關(guān)的同類信息!
  • 本頁收集關(guān)于詳解版本控制利器Git,SVN的異同以及適用范圍的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    大安市| 于田县| 囊谦县| 醴陵市| 阿勒泰市| 宁城县| 无极县| 白水县| 白玉县| 蕲春县| 太谷县| 盐边县| 沈阳市| 紫金县| 太保市| 武平县| 陇西县| 会同县| 息烽县| 荔波县| 永登县| 朔州市| 张北县| 历史| 余干县| 咸宁市| 甘南县| 双辽市| 满洲里市| 宁国市| 普兰店市| 赞皇县| 长宁县| 双鸭山市| 博乐市| 光山县| 新乐市| 治县。| 蕉岭县| 蒲城县| 正定县|