總結(jié) Git 版本管理 - 命令
代碼提交刪除及版本回退
-
git add readme.txt
添加修改的文件,把文件修改添加到暫存區(qū)
-
git commit -m "append GPL"
提交修改的文件
-m
后接提交log
,是把暫存區(qū)的所有內(nèi)容提交到當(dāng)前分支
如果不用git add
到暫存區(qū)蓄愁,那就不會(huì)加入到commit
-
git log
拱燃、git log --pretty=oneline
查看歷史記錄
-
HEAD
當(dāng)前版本者疤,
HEAD^
上個(gè)版本,HEAD^^
上上個(gè)版本春贸,HEAD~100
往上100個(gè)版本 -
git reset --hard HEAD^
回退到上一個(gè)版本
-
git reset --hard 1094a
回退到指定版本,
1094a
指定版本的ID
-
git reflog
記錄每一次命令
-
git diff HEAD -- 要查看的文件.m
查看工作區(qū)和版本庫里面最新版本的區(qū)別:
-
git checkout -- 要修改的文件.xx
可以丟棄工作區(qū)的修改,讓這個(gè)文件回到最近一次
git commit
或git add
時(shí)的狀態(tài)
要修改的文件.xx自修改后還沒有被放到暫存區(qū)笤闯,現(xiàn)在望蜡,撤銷修改就回到和版本庫一模一樣的狀態(tài)绒窑;
要修改的文件.xx已經(jīng)添加到暫存區(qū)后棕孙,又作了修改,現(xiàn)在些膨,撤銷修改就回到添加到暫存區(qū)后的狀態(tài)
git checkout
其實(shí)是用版本庫里的版本替換工作區(qū)的版本蟀俊,無論工作區(qū)是修改還是刪除,都可以“一鍵還原”订雾。前提是有被添加到版本庫
-
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)程庫绢片。
-
rm test.txt
、git rm
在文件中刪除或者命令刪除時(shí)岛琼,需要從版本庫中刪除該文件底循,刪除后需要提交
git commit
遠(yuǎn)程倉庫
-
創(chuàng)建
SSH Key
本地git
倉庫和github
倉庫之間的傳輸是通過ssh
加密的,所以需要先創(chuàng)建SSH Hey
槐瑞,在用戶主目錄下查看有沒有.ssh
,如果有檢查有沒有id_rsa
和id_rsa.pub
這兩個(gè)文件熙涤,如果有了,則可以跳過困檩,沒有則創(chuàng)建ssh-keygen -t rsa -C "youremail@example.com"
登錄
GitHub
,打開賬號(hào)設(shè)置SSH Keys
頁面
添加SSH Key
祠挫,粘貼id_rsa.pub
文件的內(nèi)容
添加遠(yuǎn)程倉庫
先有本地庫,后有遠(yuǎn)程庫悼沿,如何關(guān)聯(lián)遠(yuǎn)程庫
- 本地Git倉庫等舔、GitHub創(chuàng)建倉庫,保持同步
登錄
GitHub
找到
Create a new repo
按鈕糟趾,創(chuàng)建新倉庫在
Repository name
處填入倉庫名稱(方便后面使用用learngit
代替),點(diǎn)擊創(chuàng)建慌植,成功的創(chuàng)建一個(gè)新的Git
倉庫-
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
-
把本地庫的所有內(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 推送成功后可以在
GitHub
頁面中看到遠(yuǎn)程庫的內(nèi)容已經(jīng)和本地一樣了-
本地更改提交
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)程庫克隆
- 登錄
GitHub
,創(chuàng)建新倉庫施逾,名字叫(以實(shí)際項(xiàng)目名字命名)gitsKills
- 勾選initialize this repository with a README敷矫,會(huì)自動(dòng)創(chuàng)建一個(gè)
README.md
文件 - 用命令克隆一個(gè)本地庫
git clone
(確定本地倉庫的路徑在輸入命令)git clone 創(chuàng)建的倉庫地址.git
- 小結(jié)
需要先知道倉庫地址,然后使用git clone命令克隆
分支管理
創(chuàng)建與合并
-
創(chuàng)建
dev
分支汉额,然后切換到dev
分支git checkout -b dev
-b
表示創(chuàng)建并切換相當(dāng)于兩條語句
git branch dev
git checkout dev git branch
查看當(dāng)前分支曹仗,當(dāng)前分支前面會(huì)有一個(gè)*
號(hào)-
dev
分支的工作完成即commit
后,就可以切回master
分支git checkout master
-
dev
上的工作成果合并到master
分支上git merge dev
用于合并指定分支到當(dāng)前分支(經(jīng)過第3步的操作后蠕搜,該出即將dev
合并到master
上) -
合并完成后刪除
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
箍镜,這樣從分支歷史上就可以看出分支信息瞻鹏。
-
創(chuàng)建并切換
dev
分支git checkout -b dev
git add readme.txt
git commit -m "add merge" -
切回master
git checkout master
-
準(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)去 -
合并后用
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 apply
、git 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ā)
抓取分支
- 先用
git pull
把最新的提交從origin/dev
上抓取下來耙册,然后在本地合并给僵,解決沖突,在推送 -
git pull
失敗详拙,原因是沒有指定本地dev
分支與遠(yuǎn)程分支的鏈接根據(jù)提示可設(shè)置后再pull
git branch --set-upstream-to=origin/dev dev
- 多人協(xié)作的工作模式:
首先試圖用
git push origin branchName
推送自己的修改推送失敗帝际,因?yàn)檫h(yuǎn)程分支比你的本地更新,需要先
git pull
合并合并如有沖突則解決沖突饶辙,并在本地提交
在用
git push origin branchName
推送-
本地分支和遠(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 apply
、git 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
mkdir learngit
創(chuàng)建一個(gè)空目錄cd learngit
切換到該目錄下pwd
查看該目錄路徑git init
ls -ah
查看.git
的目錄,.git
用來跟蹤管理版本庫的cat ~/.ssh/id_rsa.pub
查看ssh
是否是自己的(與git
管理臺(tái)自己賬戶設(shè)置中對(duì)應(yīng))-
移除之前的倉庫對(duì)應(yīng)關(guān)系
git remote remove origin
git remote remove upstream -
創(chuàng)建新的自己的倉庫思灌,在建立主倉庫upstream
git remote add origin 地址xxx
git remote add upstream http://遠(yuǎn)端地址.git (輸入要要遠(yuǎn)程連接的主倉庫) -
再拉取本地倉庫的分支和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