什麼是「版本控制」?爲何要關心它呢? 版本控制是一種記錄一個或若干文件內容變化,以便未來查閱特定版本修訂狀況的系統。在本書所展現的例子中,咱們對保存着軟件源代碼的文件做版本控制,但實際上,能夠對任何類型的文件進行版本控制。git
版本控制軟件就是用來管理代碼的,他有如下優點:算法
許多人習慣用複製整個項目目錄的方式來保存不一樣的版本,或許還會更名加上備份時間以示區別。 這麼作惟一的好處就是簡單,可是特別容易犯錯。 有時候會混淆所在的工做目錄,一不當心會寫錯文件或者覆蓋意想外的文件。服務器
有了版本控制軟件以後,能夠將某個文件的新內容與舊內容進行對比,對比以後就知道這兩段代碼以後到底有哪些區別網絡
一個項目確定是由若干個開發人員一塊兒來開發的,不一樣的人員開發的不一樣代碼可能會發生衝突分佈式
版本控制軟件的分類:svn
能夠完成我的開發的目的,可是沒法進行團隊開發測試
適用於我的開發,也適用於團隊開發spa
原理:首先每個開發者要分配一個帳號(帳號是由svn的服務器管理員發放的),開發者利用該帳號開發,把功能開發好了以後,將該功能相關的代碼提交到服務器中版本控制
原理:首先每個開發者要分配一個帳號,開發者完成某個開發任務的時候可能會首先將代碼無數次的提交到本地倉庫(開發者所使用的電腦),最終完成該任務的時候將本地倉庫中的代碼一塊兒提交到服務器中開發
Git中文件的幾種狀態:
在git管理的目錄中,建立文件、修改文件、或者刪除文件這些操做都不會被記錄,要想文件被記錄必須經過某個命令
a、未標記、未追蹤
b、已提交:該文件已經被git管理起來,接下來對該文件進行相關操做就能夠實現版本控制的效果
c、已修改:某個文件已經被提交到暫存區過了,若是對該文件進行修改,該文件的狀態就是已修改
d、已暫存:某個文件已經被提交到暫存區了
1) 最核心的區別Git是分佈式的,而Svn不是分佈的。能理解這點,上手會很容易,聲明一點Git並非目前惟一的分佈式版本控制系統,還有好比Mercurial等,因此說它們差不準多。話說回來Git跟Svn同樣有本身的集中式版本庫和Server端,但Git更傾向於分佈式開發,由於每個開發人員的電腦上都有一個Local Repository,因此即便沒有網絡也同樣能夠Commit,查看歷史版本記錄,建立項 目分支等操做,等網絡再次鏈接上Push到Server端。
從上面看GIt真的很棒,可是GIt adds Complexity,剛開始使用會有些疑惑,由於須要建兩個Repositories(Local Repositories & Remote Repositories),指令不少,除此以外你須要知道哪些指令在Local Repository,哪些指令在Remote Repository。
2)Git把內容按元數據方式存儲,而SVN是按文件:由於,.git目錄是處於你的機器上的一個克隆版的版本庫,它擁有中心版本庫上全部的東西,例如標籤,分支,版本記錄等。.git目錄的體積大小跟.svn比較,你會發現它們差距很大。
3) Git沒有一個全局版本號,而SVN有:目前爲止這是跟SVN相比Git缺乏的最大的一個特徵。
4) Git的內容的完整性要優於SVN: GIT的內容存儲使用的是SHA-1哈希算法。這能確保代碼內容的完整性,確保在遇到磁盤故障和網絡問題時下降對版本庫的破壞。
5) Git下載下來後,在OffLine狀態下能夠看到全部的Log,SVN不能夠。
6) 剛開始用時很狗血的一點,SVN必須先Update才能Commit,忘記了合併時就會出現一些錯誤,git仍是比較少的出現這種狀況。
7) 克隆一份全新的目錄以一樣擁有五個分支來講,SVN是同時復製5個版本的文件,也就是說重複五次一樣的動做。而Git只是獲取文件的每一個版本的 元素,而後只載入主要的分支(master)在個人經驗,克隆一個擁有將近一萬個提交(commit),五個分支,每一個分支有大約1500個文件的 SVN,耗了將近一個小時!而Git只用了區區的1分鐘!
8) 版本庫(repository):SVN只能有一個指定中央版本庫。當這個中央版本庫有問題時,全部工做成員都一塊兒癱瘓直到版本庫維修完畢或者新的版本庫設立完成。而 Git能夠有無限個版本庫。或者,更正確的說法,每個Git都是一個版本庫,區別是它們是否擁有活躍目錄(Git Working Tree)。若是主要版本庫(例如:置於GitHub的版本庫)發生了什麼事,工做成員仍然能夠在本身的本地版本庫(local repository)提交,等待主要版本庫恢復便可。工做成員也能夠提交到其餘的版本庫!
9)分支(Branch)在SVN,分支是一個完整的目錄。且這個目錄擁有完整的實際文件。若是工做成員想要開啟新的分支,那將會影響「全世界」!每一個人都會擁有和你同樣的分支。若是你的分支是用來進行破壞工做(安檢測試),那將會像傳染病同樣,你改一個分支,還得讓其餘人從新切分支從新下載,十分狗血。而 Git,每一個工做成員能夠任意在本身的本地版本庫開啟無限個分支。舉例:當我想嘗試破壞本身的程序(安檢測試),而且想保留這些被修改的文件供往後使用, 我能夠開一個分支,作我喜歡的事。徹底不需擔憂妨礙其餘工做成員。只要我不合並及提交到主要版本庫,沒有一個工做成員會被影響。等到我不須要這個分支時, 我只要把它從個人本地版本庫刪除便可。無痛無癢。
Git的分支名是可使用不一樣名字的。例如:個人本地分支名爲OK,而在主要版本庫的名字實際上是master。
最值得一提,我能夠在Git的任意一個提交點(commit point)開啓分支!(其中一個方法是使用gitk –all 可觀察整個提交記錄,而後在任意點開啟分支。)
10)提交(Commit)在SVN,當你提交你的完成品時,它將直接記錄到中央版本庫。當你發現你的完成品存在嚴重問題時,你已經沒法阻止事情的發生了。若是網路中斷,你根本沒辦法提交!而Git的提交徹底屬於本地版本庫的活動。而你只需「推」(git push)到主要版本庫便可。Git的「推」實際上是在執行「同步」(Sync)。
最後總結一下:
SVN的特色是簡單,只是須要一個放代碼的地方時用是OK的。
Git的特色版本控制能夠不依賴網絡作任何事情,對分支和合並有更好的支持(固然這是開發者最關心的地方),不過想各位能更好使用它,須要花點時間嘗試下。