寫(xiě)給自己看的Git使用指南

寫(xiě)這篇blog的初衷是否彩,在帶教新人使用sourcetree+gitlab管理腳本時(shí)讼昆,發(fā)現(xiàn)自己磕磕巴巴無(wú)力解釋清楚Git是個(gè)什么鬼蒙袍,因此決定系統(tǒng)學(xué)習(xí)并以文章的形式整理下助消化。

拜讀了廖雪峰的《Git教程》玄坦,非常淺顯易懂血筑,也可以按目錄檢索章節(jié)內(nèi)容,耗費(fèi)一小時(shí)左右閱讀時(shí)間就能把Git的使用安排得明明白白煎楣。所以這篇文章并不再搬運(yùn)或者是再詮釋其中的內(nèi)容豺总,而是按我個(gè)人的思考和閱讀習(xí)慣,寫(xiě)一個(gè)濃縮簡(jiǎn)短版的使用指南择懂。


Why Git

Git 至少解決了版本管理和多人協(xié)作兩個(gè)問(wèn)題园欣。

  • 版本管理:相當(dāng)于后悔藥了,在關(guān)鍵節(jié)點(diǎn)及時(shí)保存和提交版本休蟹,寫(xiě)好版本注釋沸枯,就能任意返回之前的某一個(gè)版本。不過(guò)分析師寫(xiě)的SQL一般都不復(fù)雜赂弓,所以不太需要多個(gè)版本绑榴。

How it Works

Git原理

工作區(qū) -> 暫存區(qū):通過(guò)git add <filename>提交工作區(qū)的文件修改到版本庫(kù)的暫存區(qū)。暫存區(qū)的目的就是跟蹤修改盈魁。

  • 如果要撤銷工作區(qū)的修改翔怎,通過(guò)git checkout -- <filename>使其退回到已添加到暫存區(qū)的狀態(tài),如果文件未添加到暫存區(qū),則撤銷退回到和版本庫(kù)一樣的狀態(tài)赤套。

暫存區(qū) -> 分支:通過(guò)git commit -m <message>提交到暫存區(qū)的所有修改到master或其他的分支上飘痛。

  • 如果未提交版本,要撤銷暫存區(qū)的提交容握,通過(guò)git reset Head <filename>把暫存區(qū)的修改返回到工作區(qū)宣脉。

  • 如果已提交版本,通過(guò)git reset --hard Head^返回上一個(gè)版本剔氏,或通過(guò)git reset --hard <commit id>返回之前的任一版本塑猖、或重回“未來(lái)”的版本。<commit id>可通過(guò)git loggit reflog來(lái)查詢提交歷史和命令歷史谈跛。emmmm傳說(shuō)這個(gè)命令不要輕易用...

Branch

創(chuàng)建分支:通過(guò)git checkout -b dev創(chuàng)建并切換到dev分支上羊苟。以上語(yǔ)句實(shí)際可拆分成兩句。

  • git branch <branchname> 創(chuàng)建一個(gè)分支
  • git checkout <branchname> 切換到一個(gè)分支上感憾,有別于撤銷工作區(qū)修改的語(yǔ)句`git checkout -- <filename>蜡励,注意區(qū)分

合并分支:通過(guò)git merge <branchname>合并某分支到當(dāng)前分支上

解決沖突:遇到版本沖突的無(wú)法自動(dòng)合并的,需要手動(dòng)解決沖突阻桅,重新提交修改凉倚。多人協(xié)作中,可按以下步驟嘗試:

  • 先使用git push origin <branchname>推送自己的修改
  • 如推送失敗鳍刷,說(shuō)明遠(yuǎn)程分支比本地分支更新占遥,需要用git pull拉取并合并
  • 如合并失敗俯抖,需要手動(dòng)解決沖突输瓜,再次使用git push origin <branchname>推送

Git CHEAT SHEET
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市芬萍,隨后出現(xiàn)的幾起案子尤揣,更是在濱河造成了極大的恐慌,老刑警劉巖柬祠,帶你破解...
    沈念sama閱讀 218,204評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件北戏,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡漫蛔,警方通過(guò)查閱死者的電腦和手機(jī)嗜愈,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,091評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)莽龟,“玉大人蠕嫁,你說(shuō)我怎么就攤上這事√河” “怎么了剃毒?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,548評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我赘阀,道長(zhǎng)益缠,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,657評(píng)論 1 293
  • 正文 為了忘掉前任基公,我火速辦了婚禮幅慌,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘酌媒。我一直安慰自己欠痴,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,689評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布秒咨。 她就那樣靜靜地躺著喇辽,像睡著了一般。 火紅的嫁衣襯著肌膚如雪雨席。 梳的紋絲不亂的頭發(fā)上菩咨,一...
    開(kāi)封第一講書(shū)人閱讀 51,554評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音陡厘,去河邊找鬼抽米。 笑死,一個(gè)胖子當(dāng)著我的面吹牛糙置,可吹牛的內(nèi)容都是我干的云茸。 我是一名探鬼主播,決...
    沈念sama閱讀 40,302評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼谤饭,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼标捺!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起揉抵,我...
    開(kāi)封第一講書(shū)人閱讀 39,216評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤亡容,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后冤今,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體闺兢,經(jīng)...
    沈念sama閱讀 45,661評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,851評(píng)論 3 336
  • 正文 我和宋清朗相戀三年戏罢,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了屋谭。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,977評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡龟糕,死狀恐怖桐磁,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情翩蘸,我是刑警寧澤所意,帶...
    沈念sama閱讀 35,697評(píng)論 5 347
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響扶踊,放射性物質(zhì)發(fā)生泄漏泄鹏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,306評(píng)論 3 330
  • 文/蒙蒙 一秧耗、第九天 我趴在偏房一處隱蔽的房頂上張望备籽。 院中可真熱鬧,春花似錦分井、人聲如沸车猬。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,898評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)珠闰。三九已至,卻和暖如春瘫辩,著一層夾襖步出監(jiān)牢的瞬間伏嗜,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,019評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工伐厌, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留承绸,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,138評(píng)論 3 370
  • 正文 我出身青樓挣轨,卻偏偏與公主長(zhǎng)得像军熏,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子卷扮,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,927評(píng)論 2 355

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

  • 1.git的安裝 1.1 在Windows上安裝Git msysgit是Windows版的Git荡澎,從https:/...
    落魂灬閱讀 12,663評(píng)論 4 54
  • 一、基本概念: 注:對(duì)于git的分布式概念及其優(yōu)點(diǎn)画饥,不重復(fù)說(shuō)明衔瓮,自己百度或谷歌浊猾。本文中涉及到指令前面有$的抖甘,在cm...
    大廠offer閱讀 1,425評(píng)論 0 3
  • (預(yù)警:因?yàn)樵敿?xì),所以行文有些長(zhǎng)葫慎,新手邊看邊操作效果出乎你的預(yù)料) 一:Git是什么衔彻? Git是目前世界上最先進(jìn)的...
    axiaochao閱讀 1,932評(píng)論 1 8
  • Git常用語(yǔ)法 [TOC] Git簡(jiǎn)介 描述 ? Git(讀音為/g?t/。)是一個(gè)開(kāi)源的分布式版本控制系統(tǒng)偷办,...
    君惜丶閱讀 3,517評(píng)論 0 13
  • Devin_a1bf閱讀 204評(píng)論 0 0