git存儲
❶ 用git blame獲取的數據怎麼存儲到本地
git blame默認是向終端顯示的,你重定向到本地文件就好了
git blame xxx.c >blame.log
另外,一般git不都是把代碼clone本地,然後跟遠程伺服器不定期同步嗎?
❷ git的工作原理
git的工作總共分四層,其中三層是在自己本地也就是說git倉庫,包括了工作目錄、暫存區和本地倉庫。工作目錄就是我們執行命令git init時所在的地方,也就是我們執行一切文件操作的地方;暫存區和本地倉庫都是在.git目錄下,因為它們只是用來存數據的。遠程倉庫在中心伺服器,也就是我們做好工作之後推送到遠程倉庫,或者從遠程倉庫更新下來最新代碼到本地。Git所存儲的都是一系列的文件快照,然後git 來跟蹤這些文件快照,發現哪個文件快照有變化他就會提示你需要添加到暫存區或是提交到本地倉庫來保證你的工作目錄是干凈的。
這個要怎麼理解呢?git中的文件有兩種狀態,一種是被跟蹤的,也就是提交到本地倉庫的文件,因為本地倉庫要保管它們當然要跟蹤他們,對他們負責,還有一種就是未被跟蹤的。那麼當我們添加新的文件時,他不是被跟蹤的,因為本地倉庫裡面沒有這個文件,他是外來的,本地倉庫目前還不需要對他們負責。但是如果是對倉庫已經存在的文件進行修改,那麼這些文件就是被跟蹤的文件,就可以通過git status查看他們的狀態來進行相應的操作。當然我們也可以生成一個.gitignore文件,裡面指定要忽略的文件類型,然後這些文件就不會被跟蹤,不管怎麼改變他們,git status都不會提示你需要做什麼操作。
所以當我們在工作目錄中進行文件操作後,要先添加到暫存區,然後再將暫存區中剛添加的文件快照提交到本地倉庫,然後再將本地倉庫的最新狀態文件快照推送到遠程倉庫。這個文件快照其實就是各個文件在被添加到暫存區時的狀態,就和照相的一樣,留下每個不同時刻的快照,方便以後查詢,而git存儲的就是這些一系列的快照。說到這個快照就要說說git的對象了。
Git對象
在.git-》Objects文件夾是一個個的git對象,是38位的哈希值,這樣就意味著沒有兩個相同的對象名。
從根本上講,git是一套內容定址的文件系統,它存儲的也是key-value鍵值對,然後根據key值來查找value的,說到定址就會想到指針吧,不錯,git也是根據指針來定址的,這些指針就存儲在git的對象中。Git一共有四種對象,commit對象,tree對象和blob對象和tag對象,這里可以理解tag是commit的別名,下面便是這三個對象:
每個目錄都創建了「tree」對象, 每個文件都創建了一個對應的「blob」對象。最後有一個「commit」對象來指向根「tree」對象,這樣我們就可以追蹤項目每一項提交內容。
這個blob對象對應的就是文件快照中那些發生變化的文件內容,而
tree對象則記錄了文件快照中各個目錄和文件的結構關系,它指向了被跟蹤的快照,
commit對象則記錄了每次提交到本地倉庫的文件快照,
從在開發過程中,我們會提交很多次文件快照,那麼第一次提交的內容會用一個commit來記錄,這個commit 沒有指針指向上一個commit對象,因為沒有上一個commit,他是第一個,當第二次提交時,又會有另外一個commit對象來記錄,那麼這次commit對象中就會有一個指針指向上一次提交後的commit對象,經過很多次提交後就會有很多的commit對象,它們組成了一個鏈表,當我們要恢復哪個版本的時候,只要找到這個commit對象就能恢復那個版本的文件。而我們所謂的HEAD對象其實就是指向最近一個提交的commit對象,也就是最後一個commit對象。
❸ git和svn的區別和優缺點
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的特點版本控制可以不依賴網路做任何事情,對分支和合並有更好的支持(當然這是開發者最關心的地方),不過想各位能更好使用它,需要花點時間嘗試下。
❹ git上面可以存儲其他文件嗎我可不可以拿git當網盤用裡面存入個人好多文件,而且在哪都可以同步
這個當然可以的,只是不適合用git來操作的
❺ 如何將一個空目錄添加到Git存儲庫中
1. 關於 _netrc
machine github.com
login myid
password mypassword
machine bitbucket.org
login myid
password mypassword
2. 進入路徑 d: , 然後直接 clone , 會在 d: 下創建一個文件夾,內部是git的庫內容
3. 把文件丟入這個文件夾
4.在 git中輸入: git add .
5. 提交: git commit
(進入 VIM , 去除 add file 之前的各個#號,然後輸入 :wq)
6.上傳:git push origin master
❻ git和SVN的區別,有必要學習
GIT是分布式的,SVN不是分布式的。
這是GIT和其它非分布式的版本控制系統,例如SVN,CVS等,最核心的區別。
2.GIT把內容按元數據方式存儲,而SVN是按文件。
3.GIT分支和SVN的分支不同:
分支在SVN中一點不特別,就是版本庫中的另外的一個目錄。
GIT的分支卻是相當的簡單和有趣。你可以從同一個工作目錄下快速的在幾個分支間切換。
4.GIT沒有一個全局的版本號,而SVN有。
目前為止這是跟SVN相比GIT缺少的最大的一個特徵。
5.GIT的內容完整性要優於SVN。
GIT的內容存儲使用的是SHA-1哈希演算法。這能確保代碼內容的完整性,確保在遇到磁碟故障和網路問題時降低對版本庫的破壞。
❼ 為什麼我使用git存儲版本時一直出錯
fork就是clone。
只是,這個clone動作在github的伺服器上執行而已。
如果你需要提交代碼,應該使用fork,然後clone到你自己的機器上來。
如果不要提交代碼,使用從原來的地址clone到本地就好了。
我不需要提交代碼
追答
你clone的是別人的版本庫么?你在那個對應的github界面上有一個fork的按鈕,點一下就能把這個開源的版本庫復制一份副本在你自己的github賬戶下,然後你再從你自己的github