Git 命令簡介

總結(jié) Git 版本管理 - 命令

代碼提交刪除及版本回退

  1. git add readme.txt

    添加修改的文件,把文件修改添加到暫存區(qū)

  2. git commit -m "append GPL"

    提交修改的文件 -m后接提交log,是把暫存區(qū)的所有內(nèi)容提交到當(dāng)前分支
    如果不用git add到暫存區(qū)蓄愁,那就不會(huì)加入到commit

  3. git log 拱燃、 git log --pretty=oneline

    查看歷史記錄

  4. HEAD

    當(dāng)前版本者疤,HEAD^上個(gè)版本,HEAD^^ 上上個(gè)版本春贸,HEAD~100往上100個(gè)版本

  5. git reset --hard HEAD^

    回退到上一個(gè)版本

  6. git reset --hard 1094a

    回退到指定版本,1094a指定版本的ID

  7. git reflog

    記錄每一次命令

  8. git diff HEAD -- 要查看的文件.m

    查看工作區(qū)和版本庫里面最新版本的區(qū)別:

  9. git checkout -- 要修改的文件.xx

    可以丟棄工作區(qū)的修改,讓這個(gè)文件回到最近一次git commitgit add時(shí)的狀態(tài)
    要修改的文件.xx自修改后還沒有被放到暫存區(qū)笤闯,現(xiàn)在望蜡,撤銷修改就回到和版本庫一模一樣的狀態(tài)绒窑;
    要修改的文件.xx已經(jīng)添加到暫存區(qū)后棕孙,又作了修改,現(xiàn)在些膨,撤銷修改就回到添加到暫存區(qū)后的狀態(tài)
    git checkout其實(shí)是用版本庫里的版本替換工作區(qū)的版本蟀俊,無論工作區(qū)是修改還是刪除,都可以“一鍵還原”订雾。前提是有被添加到版本庫

  1. git reset HEAD 暫存區(qū)要撤銷的文件.xx

    把暫存區(qū)的修改撤銷掉(unstage)肢预,重新放回工作區(qū)
    執(zhí)行完該命令后,暫存區(qū)是干凈的洼哎,工作區(qū)有修改烫映,如果需要丟棄工作區(qū)的修改沼本,參考第9點(diǎn)

又到了小結(jié)時(shí)間。

場(chǎng)景1:當(dāng)你改亂了工作區(qū)某個(gè)文件的內(nèi)容锭沟,想直接丟棄工作區(qū)的修改時(shí)抽兆,用命令git checkout -- file。

場(chǎng)景2:當(dāng)你不但改亂了工作區(qū)某個(gè)文件的內(nèi)容族淮,還添加到了暫存區(qū)時(shí)辫红,想丟棄修改,分兩步祝辣,第一步用命令git reset HEAD <file>贴妻,就回到了場(chǎng)景1,第二步按場(chǎng)景1操作蝙斜。

場(chǎng)景3:已經(jīng)提交了不合適的修改到版本庫時(shí)名惩,想要撤銷本次提交,參考版本回退乍炉,不過前提是沒有推送到遠(yuǎn)程庫绢片。
  1. rm test.txtgit rm

    在文件中刪除或者命令刪除時(shí)岛琼,需要從版本庫中刪除該文件底循,刪除后需要提交git commit

遠(yuǎn)程倉庫

  1. 創(chuàng)建SSH Key
    本地git倉庫和github倉庫之間的傳輸是通過ssh加密的,所以需要先創(chuàng)建SSH Hey槐瑞,在用戶主目錄下查看有沒有.ssh,如果有檢查有沒有id_rsaid_rsa.pub這兩個(gè)文件熙涤,如果有了,則可以跳過困檩,沒有則創(chuàng)建

    ssh-keygen -t rsa -C "youremail@example.com"

  2. 登錄GitHub,打開賬號(hào)設(shè)置SSH Keys頁面
    添加SSH Key祠挫,粘貼id_rsa.pub文件的內(nèi)容

添加遠(yuǎn)程倉庫

先有本地庫,后有遠(yuǎn)程庫悼沿,如何關(guān)聯(lián)遠(yuǎn)程庫

個(gè)人遠(yuǎn)端倉庫 origin.png
  • 本地Git倉庫等舔、GitHub創(chuàng)建倉庫,保持同步
  1. 登錄GitHub

  2. 找到Create a new repo按鈕糟趾,創(chuàng)建新倉庫

  3. Repository name處填入倉庫名稱(方便后面使用用learngit代替),點(diǎn)擊創(chuàng)建慌植,成功的創(chuàng)建一個(gè)新的Git倉庫

  4. learngit新建的倉庫為空倉庫,可以從改倉庫克隆出新的倉庫义郑,也可把一個(gè)已有的本地倉庫與之關(guān)聯(lián)蝶柿,然后把本地倉庫的內(nèi)容推送到GitHub倉庫,在本地learngit倉庫下運(yùn)行命令

    git remote add origin git@github.com:youGitHubAccountName/learngit.git
    * 添加成功后遠(yuǎn)程庫的名字就是origin

  5. 把本地庫的所有內(nèi)容推送到遠(yuǎn)程庫上

    git push -u origin master
    * 把本地庫的內(nèi)容推送到遠(yuǎn)程非驮,實(shí)際上是把當(dāng)前分支master推送到遠(yuǎn)程交汤,由于遠(yuǎn)程庫是空的,在第一次推送master分支時(shí)加上-u參數(shù)劫笙,git會(huì)把本地的master分支內(nèi)容推送到遠(yuǎn)程新的master分支芙扎,還會(huì)把本地的master分支和遠(yuǎn)程的master分支關(guān)聯(lián)起來星岗。
    > git push

  6. 推送成功后可以在GitHub頁面中看到遠(yuǎn)程庫的內(nèi)容已經(jīng)和本地一樣了

  7. 本地更改提交

    git push origin master

  • 小結(jié):

    • 關(guān)聯(lián)一個(gè)遠(yuǎn)程庫

    git remote add origin git@server-name:path/repo-name.git

    • 關(guān)聯(lián)后第一次推送master分支的所有內(nèi)容

    git push -u origin master

    • 每次本地提交后纵顾,推送最新修改

    git push origin master

從遠(yuǎn)程庫克隆

先創(chuàng)建遠(yuǎn)程庫伍茄,然后從遠(yuǎn)程庫克隆

git與本地建立聯(lián)系.png

  1. 登錄GitHub,創(chuàng)建新倉庫施逾,名字叫(以實(shí)際項(xiàng)目名字命名)gitsKills
  2. 勾選initialize this repository with a README敷矫,會(huì)自動(dòng)創(chuàng)建一個(gè)README.md文件
  3. 用命令克隆一個(gè)本地庫git clone(確定本地倉庫的路徑在輸入命令)

    git clone 創(chuàng)建的倉庫地址.git

  • 小結(jié)
    需要先知道倉庫地址,然后使用git clone命令克隆

分支管理

創(chuàng)建與合并

  1. 創(chuàng)建dev分支汉额,然后切換到dev分支

    git checkout -b dev
    -b表示創(chuàng)建并切換相當(dāng)于兩條語句
    git branch dev
    git checkout dev

  2. git branch查看當(dāng)前分支曹仗,當(dāng)前分支前面會(huì)有一個(gè)*號(hào)

  3. dev分支的工作完成即commit后,就可以切回master分支

    git checkout master

  4. dev上的工作成果合并到master分支上

    git merge dev
    用于合并指定分支到當(dāng)前分支(經(jīng)過第3步的操作后蠕搜,該出即將dev合并到master上)

  5. 合并完成后刪除dev分支

    git branch -d dev

  • 小結(jié)

    建議使用分支完成某個(gè)任務(wù)怎茫,合并后再刪掉該分支

    • 查看分支:git branch
    • 創(chuàng)建分支:git branch branchName
    • 切換分支:git checkout branchName
    • 創(chuàng)建+切換分支:git checkout -b branchName
    • 合并某分支到當(dāng)前分支:git merge branchName
    • 刪除分支:git branch -d branchName

解決沖突

使用git status也可以告訴我們沖突的文件
找到對(duì)應(yīng)的沖突文件后,手動(dòng)解決沖突妓灌,
重新添加commit
git log --graph --pretty==oneline --abbrev-commit查看分支合并情況

分支管理策略

  • master分支應(yīng)該是非常穩(wěn)定的轨蛤,也就是僅用來發(fā)布新版本,平時(shí)不能在上面干活虫埂;
  • 干活都在dev分支上祥山,也就是說,dev分支是不穩(wěn)定的掉伏,到某個(gè)時(shí)候缝呕,比如1.0版本發(fā)布時(shí),再把dev分支合并到master上斧散,在master分支發(fā)布1.0版本供常;

通常Git會(huì)用Fast forward模式,這種模式下刪除分支鸡捐,會(huì)丟掉分支信息栈暇。
如果強(qiáng)制禁用Fast forward模式,Git會(huì)在merge時(shí)生成一個(gè)新的commit箍镜,這樣從分支歷史上就可以看出分支信息瞻鹏。

  1. 創(chuàng)建并切換dev分支

    git checkout -b dev
    git add readme.txt
    git commit -m "add merge"

  2. 切回master

    git checkout master

  3. 準(zhǔn)合并dev分支,--no-ff參數(shù)為禁用Fast forward

    git merge --no-ff -m "merge with no-ff" dev
    因?yàn)?code>--no-ff會(huì)創(chuàng)建一個(gè)新的commit鹿寨,所以加上-m參數(shù),把commit描述寫進(jìn)去

  4. 合并后用git log查看分支歷史

    git log --graph --pretty=oneline --abbrev-commit

bug分支

stash薪夕,可以把當(dāng)前工作現(xiàn)場(chǎng)儲(chǔ)藏(暫存)起來脚草,等以后恢復(fù)現(xiàn)場(chǎng)后繼續(xù)工作

  • git stash 暫存工作區(qū)內(nèi)容
  • git stash list 查看工作區(qū)的內(nèi)容
  • git stash applygit stash drop 恢復(fù)工作去的內(nèi)容并刪除stash里的內(nèi)容
  • git stash pop 恢復(fù)工作去的內(nèi)容并刪除stash的內(nèi)容

修復(fù)bug時(shí)原献,我們會(huì)通過創(chuàng)建新的bug分支進(jìn)行修復(fù)馏慨,然后合并埂淮,最后刪除,
當(dāng)手頭工作沒有完成時(shí)写隶,先把工作現(xiàn)場(chǎng)git stash一下倔撞,然后去修復(fù)bug,修復(fù)后慕趴,再git stash pop痪蝇,回到工作現(xiàn)場(chǎng)

Feature分支

多功能開發(fā)
一個(gè)功能對(duì)應(yīng)一個(gè)feature分支

  • git branch -d feature-vulcan 刪除一個(gè)分支
  • git branch -D feature-vulcan 強(qiáng)行刪除一個(gè)分支

多人協(xié)作

  • 推送分支,把該分支推送到遠(yuǎn)程倉庫

    git push origin 要推送的分支名

  • master為主分支冕房,因此要時(shí)刻遠(yuǎn)程同步

  • dev分支是開發(fā)分支躏啰,所以也需要與遠(yuǎn)程保存同步

  • bug分支只用于本地修復(fù)bug,就沒必要推送到遠(yuǎn)程了

  • feature分支是否推送到遠(yuǎn)程取決與是否合作開發(fā)

抓取分支

  1. 先用git pull把最新的提交從origin/dev上抓取下來耙册,然后在本地合并给僵,解決沖突,在推送
  2. git pull失敗详拙,原因是沒有指定本地dev分支與遠(yuǎn)程分支的鏈接根據(jù)提示可設(shè)置后再pull

    git branch --set-upstream-to=origin/dev dev

  • 多人協(xié)作的工作模式:
    1. 首先試圖用git push origin branchName 推送自己的修改

    2. 推送失敗帝际,因?yàn)檫h(yuǎn)程分支比你的本地更新,需要先git pull合并

    3. 合并如有沖突則解決沖突饶辙,并在本地提交

    4. 在用git push origin branchName推送

    5. 本地分支和遠(yuǎn)程分支創(chuàng)建鏈接關(guān)系

      git branch --set-upstream-to branchName origin/branchName

Rebase

變基
rebase操作可以把本地未push的分叉提交歷史整理成直線蹲诀;

rebase的目的是使得我們?cè)诓榭礆v史提交的變化時(shí)更容易,因?yàn)榉植娴奶峤恍枰綄?duì)比畸悬。

標(biāo)簽管理

創(chuàng)建標(biāo)簽:

  • git branch 切到需要打標(biāo)簽的分支上
  • git tag v1.0 打一個(gè)新的標(biāo)簽
  • git tag 查看所有標(biāo)簽 標(biāo)簽是按字母排序的侧甫,不是按時(shí)間順序列出的
  • git log --pretty=oneline --abbrev-commit 查找commit id
  • git tag v0.9 commit id 指定提交的地方打標(biāo)簽
  • git tag show v0.9 查看標(biāo)簽信息
  • git tag -a v0.1 -m “version 0.1 released” 1094adb-a指定標(biāo)簽名蹋宦,-m指定說明文字
  • git tag -d v0.1 刪除本地標(biāo)簽
  • git push origin <tagname> 推送到遠(yuǎn)端
  • git push origin --tags 推送全部標(biāo)簽到遠(yuǎn)端
  • git push origin :refs/tags/v0.9披粟,刪除遠(yuǎn)程標(biāo)簽,已經(jīng)推送到遠(yuǎn)端的刪除需要先刪除本地的標(biāo)簽冷冗,然后在刪除遠(yuǎn)端的

常用命令

  • git push origin branch-name 從本地推送分支守屉,使用

  • git pull抓取遠(yuǎn)程的新提交

  • git checkout -b branch-name origin/branch-name建立本地分支和本地遠(yuǎn)程分支的關(guān)聯(lián)

  • git branch --set-upstream branch-name origin/branch-name 本地分支和遠(yuǎn)程分支創(chuàng)建鏈接關(guān)系

  • git remote -v 顯示本地所有的遠(yuǎn)程倉庫地址

  • git remote remove origin/upstream 刪除本地代碼與遠(yuǎn)端GitLab分支之間的關(guān)系

  • git remote add origin git@gitlab.go-goal.cn:albert/xxx-bottom.git 本地代碼與新的GitLab服務(wù)器關(guān)聯(lián)起來

  • git remote add upstream git@gitlab.go-goal.cn:albert/xxx-bottom.git 本地代碼與新的GitLab服務(wù)器關(guān)聯(lián)起來

  • git pull 線上線下分支同步

  • git pull upstream 線上線下分支同步

  • git push origin --all 將本地的所有分支都推送到新的GitLab服務(wù)器遠(yuǎn)程分支

  • git stash 暫存工作區(qū)內(nèi)容

  • git stash list 查看工作區(qū)的內(nèi)容

  • git stash applygit stash drop 恢復(fù)工作去的內(nèi)容并刪除stash里的內(nèi)容

  • git stash pop 恢復(fù)工作去的內(nèi)容并刪除stash的內(nèi)容

  • git log --graph --pretty==oneline --abbrev-commit

    查看分支合并情況

  • git status

    查看當(dāng)前倉庫的狀態(tài)

  • git diff

    查看difference修改內(nèi)容

  • git add 蒿辙、git commit

    添加需要提交的文件拇泛,然后commit

  1. mkdir learngit 創(chuàng)建一個(gè)空目錄

  2. cd learngit 切換到該目錄下

  3. pwd 查看該目錄路徑

  4. git init

  5. ls -ah 查看.git的目錄,.git用來跟蹤管理版本庫的

  6. cat ~/.ssh/id_rsa.pub 查看ssh是否是自己的(與git管理臺(tái)自己賬戶設(shè)置中對(duì)應(yīng))

  7. 移除之前的倉庫對(duì)應(yīng)關(guān)系

    git remote remove origin
    git remote remove upstream

  8. 創(chuàng)建新的自己的倉庫思灌,在建立主倉庫upstream

    git remote add origin 地址xxx
    git remote add upstream http://遠(yuǎn)端地址.git (輸入要要遠(yuǎn)程連接的主倉庫)

  9. 再拉取本地倉庫的分支和upstream分支

    git pull upstream

多需求開發(fā)時(shí)俺叭,有未完成的任務(wù),又需要切換分支的情況:
先暫存泰偿,然后切換分支熄守,處理完后切回,然后找回暫存內(nèi)容,繼續(xù)開發(fā)

  • git stash 暫存工作區(qū)內(nèi)容
  • git stash list 查看工作區(qū)的內(nèi)容
  • git stash apply裕照、git stash drop 恢復(fù)工作去的內(nèi)容并刪除stash里的內(nèi)容
  • git stash pop 恢復(fù)工作去的內(nèi)容并刪除stash的內(nèi)容

參考:Git教程
https://www.liaoxuefeng.com/wiki/896043488029600/896954848507552

Git Document
https://git-scm.com/book/zh/v2

Git cheat sheet
https://gitee.com/liaoxuefeng/learn-java/raw/master/teach/git-cheatsheet.pdf

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末攒发,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子晋南,更是在濱河造成了極大的恐慌惠猿,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,378評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件负间,死亡現(xiàn)場(chǎng)離奇詭異偶妖,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)唉擂,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,356評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門餐屎,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人玩祟,你說我怎么就攤上這事腹缩。” “怎么了空扎?”我有些...
    開封第一講書人閱讀 152,702評(píng)論 0 342
  • 文/不壞的土叔 我叫張陵藏鹊,是天一觀的道長。 經(jīng)常有香客問我转锈,道長盘寡,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,259評(píng)論 1 279
  • 正文 為了忘掉前任撮慨,我火速辦了婚禮竿痰,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘砌溺。我一直安慰自己影涉,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,263評(píng)論 5 371
  • 文/花漫 我一把揭開白布规伐。 她就那樣靜靜地躺著蟹倾,像睡著了一般。 火紅的嫁衣襯著肌膚如雪猖闪。 梳的紋絲不亂的頭發(fā)上鲜棠,一...
    開封第一講書人閱讀 49,036評(píng)論 1 285
  • 那天,我揣著相機(jī)與錄音培慌,去河邊找鬼豁陆。 笑死,一個(gè)胖子當(dāng)著我的面吹牛吵护,可吹牛的內(nèi)容都是我干的盒音。 我是一名探鬼主播竖配,決...
    沈念sama閱讀 38,349評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼里逆!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起用爪,我...
    開封第一講書人閱讀 36,979評(píng)論 0 259
  • 序言:老撾萬榮一對(duì)情侶失蹤原押,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后偎血,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體诸衔,經(jīng)...
    沈念sama閱讀 43,469評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,938評(píng)論 2 323
  • 正文 我和宋清朗相戀三年颇玷,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了笨农。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,059評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡帖渠,死狀恐怖谒亦,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情空郊,我是刑警寧澤份招,帶...
    沈念sama閱讀 33,703評(píng)論 4 323
  • 正文 年R本政府宣布,位于F島的核電站狞甚,受9級(jí)特大地震影響锁摔,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜哼审,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,257評(píng)論 3 307
  • 文/蒙蒙 一谐腰、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧涩盾,春花似錦十气、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,262評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至终畅,卻和暖如春籍胯,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背离福。 一陣腳步聲響...
    開封第一講書人閱讀 31,485評(píng)論 1 262
  • 我被黑心中介騙來泰國打工杖狼, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人妖爷。 一個(gè)月前我還...
    沈念sama閱讀 45,501評(píng)論 2 354
  • 正文 我出身青樓蝶涩,卻偏偏與公主長得像理朋,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子绿聘,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,792評(píng)論 2 345

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

  • 聲明:這篇文章來源于廖雪峰老師的官方網(wǎng)站嗽上,我僅僅是作為學(xué)習(xí)之用 Git簡介 Git是什么? Git是目前世界上最先...
    橫渡閱讀 3,943評(píng)論 3 27
  • (預(yù)警:因?yàn)樵敿?xì)熄攘,所以行文有些長兽愤,新手邊看邊操作效果出乎你的預(yù)料) 一:Git是什么? Git是目前世界上最先進(jìn)的...
    axiaochao閱讀 1,923評(píng)論 1 8
  • 創(chuàng)建版本庫 通過git init命令把這個(gè)目錄變成Git可以管理的倉庫 把文件添加到版本庫 git add把文件提...
    九命丿相柳閱讀 136評(píng)論 0 0
  • Git 是目前最流行的分布式版本控制系統(tǒng)之一挪圾。 版本控制指的是浅萧,記錄每次版本變更的內(nèi)容和時(shí)間等細(xì)節(jié),保留各版本之間...
    神齊閱讀 1,400評(píng)論 0 7
  • 一:Git是什么哲思? Git是目前世界上最先進(jìn)的分布式版本控制系統(tǒng)洼畅。 二:SVN與Git的最主要的區(qū)別? SVN是集...
    Splendid飛羽閱讀 314評(píng)論 0 0