GIT理解總結(jié)

協(xié)作開發(fā)的質(zhì)量保證穆端?忠售?
協(xié)作開發(fā)的質(zhì)量保證.png
分布式管理控制系統(tǒng)---GIT
分布式管理控制系統(tǒng).png

客戶端并不只提取最新版本的快照传惠,而是把代碼倉(cāng)庫(kù)完整的鏡像下來(lái)。

GIT特點(diǎn)

1.多數(shù)操作只添加數(shù)據(jù)
2.直接記錄快照稻扬,而不用比較差異

圖片.png

比較差異:從文件A到A1卦方,不會(huì)記錄兩個(gè)文件,而是記錄A和A1的差異腐螟。好處是減少倉(cāng)庫(kù)體積愿汰;缺點(diǎn):想得到文件最新版本,需要訪問追溯到原始版本和后面所有版本的差異 乐纸。
3.所有操作在本地進(jìn)行(離線操作)
4.數(shù)據(jù)完整性(SHA-1哈希值)
5.文件流轉(zhuǎn)的三個(gè)區(qū)域(工作區(qū)衬廷、暫存區(qū)、本地倉(cāng)庫(kù))
流轉(zhuǎn)過(guò)程.png

工作目錄汽绢、暫存區(qū)吗跋、本地倉(cāng)庫(kù)
過(guò)程.png

工作區(qū):在當(dāng)前倉(cāng)庫(kù)中進(jìn)行的增刪改操作區(qū)

暫存區(qū):【index】(在版本庫(kù)的.git目錄下的index文件)--->是一個(gè) 包含文件索引的目錄樹(tree),虛擬的工作區(qū);記錄了文件名跌宛,狀態(tài)信息(時(shí)間戳/文件長(zhǎng)度等)酗宋;
文件內(nèi)容數(shù)據(jù)不存在此處,而在Git對(duì)象庫(kù)(.git/objects)中疆拘;
文件索引建立起文件和對(duì)象庫(kù)中對(duì)象實(shí)體之間的對(duì)應(yīng)蜕猫;如果本地倉(cāng)庫(kù) 使用命令git add ,更新就會(huì)出現(xiàn)在暫存區(qū)哎迄。

版本庫(kù):如果當(dāng)前倉(cāng)庫(kù)沒有任何提交回右,則版本庫(kù)還是上次提交后的內(nèi)容。

GIT工作流程
  1. 在工作目錄中修改某些文件
  2. 對(duì)修改后的文件進(jìn)行快照漱挚,保存到暫存區(qū)
  3. 提交更新翔烁,將暫存區(qū)中的文件快照永遠(yuǎn)轉(zhuǎn)存到Git目錄中
圖片.png

Git對(duì)象:內(nèi)容尋址文件系統(tǒng),以鍵值對(duì)(key-value)存儲(chǔ)旨涝,允許插入任意類型內(nèi)容蹬屹,并返回一個(gè)鍵值,通過(guò)該鍵值可在任何時(shí)候取白华。

配置GIT
  1. 配置用戶名和電子郵件地址---在commit log中可看到
    #git config --global user.name "guanguan"
    #git config --global user.email "guan.furong@eisoo.com"
  2. 查看已有的配置信息
    #git config --list
  3. 配置單個(gè)git項(xiàng)目
    #git config user.email "guan.furong@eisoo.com"
  4. 配置core.autocrlf
    #git config --global core.autocrlf true Windows系統(tǒng)
    #git config --global core.autocrlf input Linux系統(tǒng)
  5. 獲取幫助
    git help <veb>git <verb> --help
    $man git-<verb>
使用GIT倉(cāng)庫(kù)
  1. 工作目錄初始化新的git倉(cāng)庫(kù)
    #mkdir hello //創(chuàng)建工作目錄
    #cd hello
    #git init //當(dāng)前目錄生成.git文件夾
  2. 創(chuàng)建一個(gè)bare倉(cāng)庫(kù)(無(wú)工作目錄慨默,在服務(wù)器上)
    #mkdir hello.git
    #cd hello.git
    #git init --bare
  3. Clone一個(gè)倉(cāng)庫(kù)
    $git clone URL
  4. 提交
    $git add filename //將未跟蹤或已修改文件加入暫存區(qū)
    $git commit //將暫存區(qū)文件提交到版本庫(kù),選項(xiàng)(-a)將已跟蹤已修改未暫存的文件也會(huì)提交
    #git commit -m "msg xxxxxxxxxx" //提交信息
  5. 查看
    $git status //查看工作狀態(tài)
    三種文件狀態(tài):Changes to be commited <已暫存未提交>
    changes not staged for commit <以跟蹤的文件修改后未提交>
    Untracked files <尚未跟蹤的文件>
圖片.png
  1. 查看日志
    $git log //顯示提交的日志
    commit hash(SHA-1 校驗(yàn)和)
    作者的名字和電子郵件地址
    提交時(shí)間
    提交說(shuō)明
GIT分支

除了第一個(gè)提交衬鱼,每次提交(commit)有1個(gè)父親业筏,每個(gè)合并(merge)都有2個(gè)父親


圖片.png
分支操作
  1. 基于當(dāng)前分支憔杨,新建一個(gè)名為develop分支
    #git branch develop
  2. 切換至develop分支
    #git checkout develop
    1+2. 組合成一個(gè)命令
    #git checkout -b develop
  3. 從某個(gè)歷史提交創(chuàng)建分支
    #git checkout -b temp 8f7a493c
分支合并

執(zhí)行以下命令得到下圖:

#git checkout master //切換到主分支
#git merge dumbidea //合并dumbidea(git內(nèi)部把master快進(jìn)到C13)
#git merge iss91v2 //合并此分支鸟赫,此操作會(huì)自動(dòng)創(chuàng)建一個(gè)新提交c14
#git branch -D iss91 //強(qiáng)制刪除該分支(因?yàn)镃5 C6未合并,需使用選項(xiàng)-D強(qiáng)制刪除)


圖片.png

#git checkout master //轉(zhuǎn)到主分支
#git merge bugfix //合并一個(gè)bug修復(fù)分支
#git merge newfeature //合并1個(gè)新需求分支

遠(yuǎn)程倉(cāng)庫(kù)

與服務(wù)器同步


圖片.png
  1. 為遠(yuǎn)程倉(cāng)庫(kù)URL添加別名
    #git remote add origin user@server:/path/repo.git
    #git fetch origin //同步服務(wù)器上的數(shù)據(jù)至本地
    #git merge origin/master //合并
    #git pull merge master
    #git push origin [local_branch:remote_branch] //更新遠(yuǎn)程倉(cāng)庫(kù)
    #git push origin :serverfix //刪除遠(yuǎn)程的serverfix分支

  2. 比較差異(版本目錄消别、文件)
    #git diff //工作區(qū)和版本庫(kù)差異
    #git diff --cached //暫存區(qū)和版本庫(kù)差異
    #git diff HEAD // 工作區(qū)和版本庫(kù)差異
    每次commit后抛蚤,暫存區(qū)和版本區(qū)是沒有差異的

  3. 撤銷
    (1)用于重新整理提交
    #git reset -mixed <id> //將git的HEAD變了,并依據(jù)HEAD更新暫存區(qū)寻狂,但工作區(qū)的tree沒有改變
    #git reset -soft <id> //在上一個(gè)命令下岁经,由做了一次add操作
    (2)放棄id之后的修改
    #git reset -herd <id> //將HEAD變了,文件也變了=回到某個(gè)提交蛇券,id之后的改變?nèi)?/p>

  4. 過(guò)濾文件
    #git ignore //過(guò)濾臨時(shí)文件缀壤、中間文件、編輯器產(chǎn)生的文件等纠亚,使用塘慕!強(qiáng)制不過(guò)濾某些文件
    規(guī)則:
    a. 空行用于分割,#表示注釋
    b. *匹配文件或目錄名0或多個(gè)字符蒂胞,不包括表示文件目錄的反斜杠/ ; ?匹配單個(gè)字符图呢; [ ]匹配其中一個(gè)字符
    c. 反斜杠開頭的表示只匹配當(dāng)前目錄/abc,不匹配子目錄
    d. 反斜杠結(jié)尾的表示匹配整個(gè)目錄/abc
    e. !規(guī)則取反

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市蛤织,隨后出現(xiàn)的幾起案子赴叹,更是在濱河造成了極大的恐慌,老刑警劉巖指蚜,帶你破解...
    沈念sama閱讀 217,406評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件乞巧,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡摊鸡,警方通過(guò)查閱死者的電腦和手機(jī)摊欠,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,732評(píng)論 3 393
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)柱宦,“玉大人些椒,你說(shuō)我怎么就攤上這事〉Э” “怎么了免糕?”我有些...
    開封第一講書人閱讀 163,711評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)忧侧。 經(jīng)常有香客問我石窑,道長(zhǎng),這世上最難降的妖魔是什么蚓炬? 我笑而不...
    開封第一講書人閱讀 58,380評(píng)論 1 293
  • 正文 為了忘掉前任松逊,我火速辦了婚禮,結(jié)果婚禮上肯夏,老公的妹妹穿的比我還像新娘经宏。我一直安慰自己,他們只是感情好驯击,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,432評(píng)論 6 392
  • 文/花漫 我一把揭開白布烁兰。 她就那樣靜靜地躺著,像睡著了一般徊都。 火紅的嫁衣襯著肌膚如雪沪斟。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,301評(píng)論 1 301
  • 那天暇矫,我揣著相機(jī)與錄音主之,去河邊找鬼。 笑死李根,一個(gè)胖子當(dāng)著我的面吹牛槽奕,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播朱巨,決...
    沈念sama閱讀 40,145評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼史翘,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起琼讽,我...
    開封第一講書人閱讀 39,008評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤必峰,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后钻蹬,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體吼蚁,經(jīng)...
    沈念sama閱讀 45,443評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,649評(píng)論 3 334
  • 正文 我和宋清朗相戀三年问欠,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了肝匆。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,795評(píng)論 1 347
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡顺献,死狀恐怖旗国,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情注整,我是刑警寧澤能曾,帶...
    沈念sama閱讀 35,501評(píng)論 5 345
  • 正文 年R本政府宣布,位于F島的核電站肿轨,受9級(jí)特大地震影響寿冕,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜椒袍,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,119評(píng)論 3 328
  • 文/蒙蒙 一驼唱、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧驹暑,春花似錦玫恳、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,731評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)肖油。三九已至兼吓,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間森枪,已是汗流浹背视搏。 一陣腳步聲響...
    開封第一講書人閱讀 32,865評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留县袱,地道東北人浑娜。 一個(gè)月前我還...
    沈念sama閱讀 47,899評(píng)論 2 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像式散,于是被迫代替她去往敵國(guó)和親筋遭。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,724評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容

  • Git 基礎(chǔ) 基本原理 客戶端并不是只提取最新版本的文件快照,而是把代碼倉(cāng)庫(kù)完整的鏡像下來(lái)漓滔。這樣一來(lái)编饺,任何一處協(xié)同...
    __silhouette閱讀 15,880評(píng)論 5 147
  • Git 命令行學(xué)習(xí)筆記 Git 基礎(chǔ) 基本原理 客戶端并不是只提取最新版本的文件快照,而是把代碼倉(cāng)庫(kù)完整的鏡像下來(lái)...
    sunnyghx閱讀 3,915評(píng)論 0 11
  • Git常用語(yǔ)法 [TOC] Git簡(jiǎn)介 描述 ? Git(讀音為/g?t/响驴。)是一個(gè)開源的分布式版本控制系統(tǒng)透且,...
    君惜丶閱讀 3,511評(píng)論 0 13
  • 【浣溪沙.霜滿樓】雨中偶得 山遠(yuǎn)水長(zhǎng)明月樓,千年遺葬冷清秋豁鲤。 西風(fēng)零落幾多愁秽誊。 長(zhǎng)路不堪云雨夢(mèng),短程難奈雪霜眸琳骡。 ...
    寒山艸木閱讀 605評(píng)論 6 16
  • 睿智的人啊锅论,到底該怎么定義時(shí)間呢?定義了楣号,認(rèn)定了棍厌,某個(gè)深夜你還是會(huì)懷疑,翻來(lái)覆去竖席,何為對(duì)錯(cuò)耘纱,那些對(duì)的東西為何有時(shí)覺...
    黑色心臟閱讀 126評(píng)論 0 0