如果不穩(wěn)定分支有沖突無法合并,可以考慮切到 master 刪除 test 分支(僅用于不需要在乎提交的不穩(wěn)定分支) ,再在 master 分支輸入 git pull --rebase,它會(huì) 同步所有遠(yuǎn)程分支到本地
git pull :拉取遠(yuǎn)程倉庫代碼
--rebase 將遠(yuǎn)程倉庫的代碼期間修改的代碼全部合并到當(dāng)前分支的結(jié)尾,這樣 commit 會(huì)變成一條線,不會(huì)分叉(同時(shí)創(chuàng)建一個(gè) commit 記錄合并的記錄),如果有沖突會(huì)停止 rebase,等解決沖突后調(diào)用 git add 將最終結(jié)果放入暫存區(qū),再 git rebase --continue 繼續(xù)合并
git pull --rebase = git fetch + git rebase
git pull = git fetch + git merge
git status:查看文件狀態(tài)(詳細(xì))
-s 簡(jiǎn)單狀態(tài)
git branch : 查看本地分支
-u origin/<遠(yuǎn)程分支> 關(guān)聯(lián)當(dāng)前本地分支到某個(gè)遠(yuǎn)程分支
-a 查看本地和遠(yuǎn)程的所有分支
-vv 查看本地分支對(duì)應(yīng)的遠(yuǎn)程分支
-d <本地分支名> 刪除某個(gè)本地分支
git log:查看當(dāng)前分支的歷史提交 (簡(jiǎn)略版)
-p 詳細(xì)查看每個(gè)提交都修改了哪些代碼
--stat 顯示每次提交時(shí),修改文件的簡(jiǎn)要修改信息(常用)
--grep=“xxx” 根據(jù)關(guān)鍵字搜索指定提交
--graph 顯示圖形界面
--author 指定作者
--all 顯示所有分支的提交歷史
gloga
所有分支提交的圖形界面
glods
顯示當(dāng)前分支所有提交的圖形界面
glods <文件名/分支名>
顯示(涉及到目標(biāo)文件/目標(biāo)分支)的所有提交
git diff 比對(duì)并檢查當(dāng)前代碼改動(dòng),默認(rèn)為工作區(qū)和暫存區(qū)進(jìn)行比較
--cached 暫存區(qū)和 git 倉庫比較
git checkout <本地分支名>: 切換分支
-b <本地分支名> <origin/遠(yuǎn)程分支名> 本地沒有分支則創(chuàng)建分支并切換
-- <文件名> 恢復(fù)被刪除的文件,默認(rèn)恢復(fù)成最新的遠(yuǎn)程分支中的當(dāng)前文件
git merge <目標(biāo)分支>: 合并目標(biāo)分支到當(dāng)前分支
--no-ff 不使用fast-forward方式合并,即使刪除分支也可以保留分支的commit歷史(推薦)
git remote -v :查看遠(yuǎn)程倉庫地址
git stash clear: 清除所有 stash
git stash drop stashxxxxx: 刪除第 xxx 的 stash
git stash show -p stash@{1}: 顯示 stash@{1} 中詳細(xì)改動(dòng)
git stash save 'xxx" 將儲(chǔ)藏命名為 xxx
git ls-files:查看暫存區(qū)文件信息(取消暫存直接點(diǎn)到指定文件然后回退即可)
--cached (簡(jiǎn)寫 -c) 默認(rèn)參數(shù),顯示所有暫存區(qū)文件
--deleted (簡(jiǎn)寫 -d) 顯示刪除文件
--modified (簡(jiǎn)寫 -m)顯示修改過的文件
git rm: 刪除文件
-r 遞歸刪除
git remote prune origin :清除遠(yuǎn)程已經(jīng)不存在但是本地還存在的分支
git push --force-with-lease: 較為安全的 git push --force,如果發(fā)現(xiàn)本地分支和此時(shí)的遠(yuǎn)程分支有不同則會(huì)先阻止推送,防止你沖掉其他人的代碼
merge 和 rebase 的區(qū)別
rebase 類似與 merge ,它和 merge 不同的是
- merge 會(huì)一次性的往當(dāng)前分支合并目標(biāo)分支的提交記錄,此時(shí)如果有沖突,會(huì)一次性全部解決
- rebase 會(huì)對(duì)提交進(jìn)行一個(gè)個(gè)的合并,如果有沖突先解決沖突,然后調(diào)用 git rebase --continue 進(jìn)行下一個(gè)分支的
同時(shí) rebase 會(huì)將分支變成一條整齊的線,取消了 merge commit
實(shí)際上是把解決分支補(bǔ)丁同最新主干代碼之間沖突的責(zé)任,化轉(zhuǎn)為由提交補(bǔ)丁的人來解決
,合并到 master 時(shí)不需要管理者解決沖突了
reset 相關(guān)
重置本地分支到目標(biāo) commit 上,reset 包含三個(gè)參數(shù)
- soft:回退版本,同時(shí) head ~目標(biāo) commit 的提交放入暫存區(qū)
- mixed(默認(rèn)): 回退版本,同時(shí) head ~目標(biāo) commit 的提交不放入暫存區(qū),但保留
- hard:回退版本,不保留任何提交
rebase 相關(guān)
由于 rebase 的源分支(執(zhí)行 git rebase 命令的當(dāng)前分支,并非 rebase 的目標(biāo)分支)會(huì)基于目標(biāo)分支進(jìn)行重建,和當(dāng)前的源分支不一樣,所以必須使用 git push --force 才能提交到遠(yuǎn)程倉庫
所以如果源分支是一個(gè)合作分支(其他開發(fā)者會(huì)在這個(gè)分支開發(fā)),不能進(jìn)行 rebase,否則會(huì)將其他人的代碼給覆蓋掉(保險(xiǎn)起見可以使用 git push --force-with-lease)
https://segmentfault.com/a/1190000005937408
使用 git rebase 時(shí)需要經(jīng)常 rebase 即將合并到的那個(gè)分支,否則堆積很多 commit 再合并容易發(fā)生錯(cuò)誤
merge 相關(guān)
如果 merge 含有沖突,需要手動(dòng)解決沖突,其中 HEAD 表示當(dāng)前分支,xxx 表示合并到當(dāng)前分支到目標(biāo)分支
<<<<<<< HEAD
<div id="footer">contact : email.support@github.com</div>
=======
<div id="footer">
please contact us at support@github.com
</div>
>>>>>>> iss53
git merge 和 git cherr-pick 的區(qū)別
merge 不僅是改動(dòng)的代碼,沒有改動(dòng)的代碼也會(huì)一起合并到當(dāng)前分支
而 cherry-pick 只會(huì)將目標(biāo) commit 的改動(dòng)合并到當(dāng)前分支
git --rebase 和 git merge --no-ff 博客
合并多個(gè) commit
輸入 git rebase -i <hash>
,hash 應(yīng)該是需要合并的 commit 之前的一個(gè) commit
然后會(huì)彈出 vim 編輯器,里面會(huì)顯示 ( hash ~ HEAD ] 之間的 commit 記錄,并且 commit 記錄的時(shí)間線是從上到下的(最下面的是最近的 commit)
將第一個(gè)單詞 pick 改成 squash,就可以將 squash 后面的 commit 合并到上一個(gè) commit 中
squash 的意思是當(dāng)前這個(gè) commit 會(huì)被合并到前一個(gè)commit
撤銷指定提交
git revert <hash>: 撤銷指定的提交
git revert -m <hash>: 撤銷一個(gè)合并的提交(merge requeset),即撤銷關(guān)于這個(gè) merge 的所有提交
憑證存儲(chǔ)(http 免密操作)
運(yùn)行以下命令創(chuàng)建一個(gè)存儲(chǔ)密碼的文件
git config --global credential.helper store
接著會(huì)在 home(~)目錄下生成一個(gè) .gitconfig 的文件,保存密碼
gitlab webhook
當(dāng) gitlab 觸發(fā)些事件時(shí),會(huì)向第一行中填入的 url 發(fā)送一個(gè)請(qǐng)求,請(qǐng)求可以指向你的服務(wù)器,可以為此添加一些額外功能,例如 LGFM ,自動(dòng)合并,自動(dòng)部署等
第二行的 token 可以自定義,可以添加鑒權(quán)功能