淺析git server“丟失”commit問(wèn)題
1 背景
gitlab某倉(cāng)庫(kù)有同事發(fā)現(xiàn)部分代碼文件內(nèi)容丟失,具體表現(xiàn)
A. dev分支commit信息是連續(xù)的,看不出明顯的大時(shí)間范圍批量丟失
B. 以SuncardCashier/control/CSymbolEdit.h為例,在1c88f613下只能看到2個(gè)歷史相關(guān)提交
但是1天前提交的bfff1f51,也有此文件的修改提交,意味著bfff1f51這個(gè)提交“丟失”了
2 追查過(guò)程
2.1 gitlab server側(cè)尋找線索
表面上像是gitlab server出現(xiàn)了某些問(wèn)題導(dǎo)致“丟失”,所以查看/var/log/gitlab/gitlab-rails/下的production.log日志(production.log是當(dāng)天的,production.log.31.gz是更早日期壓縮后的,需要解壓查看)。
但是通過(guò)查看日志只有一些查看上述commit的api access log,并無(wú)有效線索。并且同時(shí)段的其他倉(cāng)庫(kù)可以看到commit信息
2.2 gitlab network graph尋找線索
此時(shí)懷疑是有人在本地誤使用rebase等命令再force push導(dǎo)致server的commit丟失,通過(guò)gitlab的network graph是一個(gè)高效的梳理手段
首先在network grapsh搜索bfff1f51(灰色箭頭指向),這也說(shuō)明gitlab server其實(shí)有此commit數(shù)據(jù)
這里不同顏色線相當(dāng)于是dev分支不同的提交人,最右側(cè)紅線為主分支,其中線之間的箭頭是merge。查看圖中bfff1f51之后各線最鄰近的merge,基本都還可以看到bfff1f51這個(gè)提交,說(shuō)明正常。除了紅色箭頭標(biāo)識(shí)的左側(cè)綠線!
此提交為d5049b0,可以看到該文件已經(jīng)沒(méi)有bfff1f51提交了
繼續(xù)到綠線分支更后的操作追查,之后它merge到了粉線(左起第二),粉線再merge到了蘭線(左起第三),粉線再merge到了紅線(左起第四)。而“丟失”情況如下圖示,即被綠線merge前都正常,merge后都丟失了
3 結(jié)論
至此,可以基本確定是d5049b0進(jìn)行了類似rebase回滾到之前提交的行為(其commit message也填寫(xiě)的是“沖突”),另外可以看到該倉(cāng)庫(kù)設(shè)置的protected branch只有master,無(wú)dev,所以是具備force push條件的
4 建議的改進(jìn)措施:
A. 將dev等需重點(diǎn)分支禁止force push
B. 開(kāi)發(fā)人員對(duì)于git回滾等操作需謹(jǐn)慎對(duì)待
“用來(lái)記錄生命的演進(jìn),故事的迭代。期望做一個(gè)給大家?guī)?lái)幫助和思考的平臺(tái)” ——深邃老夏
到此這篇關(guān)于淺析git server“丟失”commit問(wèn)題的文章就介紹到這了,更多相關(guān)git server“丟失”commit內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- 解決使用commit提交大文件無(wú)法推送到遠(yuǎn)程庫(kù)問(wèn)題及git rebase使用詳解
- git如何撤銷commit的方法(未push)
- Git回退代碼到某次commit的實(shí)現(xiàn)方法
- git修改已commit的注釋信息實(shí)現(xiàn)
- Git發(fā)現(xiàn)git push origin master 報(bào)錯(cuò)的解決方法
- 解決fatal:remote error:You can''t push to git://github.com/username/*.git問(wèn)題的辦法
- 解決git誤commit大文件導(dǎo)致不能push問(wèn)題
相關(guān)文章
idea配置Tomcat時(shí)沒(méi)有Artifacts選項(xiàng)的解決方法
本文主要介紹了idea配置Tomcat時(shí)沒(méi)有Artifacts選項(xiàng)的解決方法,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-05-05Spark學(xué)習(xí)筆記Spark Streaming的使用
這篇文章主要介紹了Spark學(xué)習(xí)筆記Spark Streaming的使用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-06-06Java將word文件轉(zhuǎn)成pdf文件的操作方法
這篇文章主要介紹了Java將word文件轉(zhuǎn)成pdf文件的操作方法,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-09-09springboot+idea熱部署的實(shí)現(xiàn)方法(自動(dòng)刷新)
這篇文章主要介紹了springboot+idea熱部署的實(shí)現(xiàn)方法(自動(dòng)刷新),本文分步驟通過(guò)實(shí)例代碼截圖相結(jié)合給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-05-05spring boot整合redis實(shí)現(xiàn)shiro的分布式session共享的方法
本篇文章主要介紹了spring boot整合redis實(shí)現(xiàn)shiro的分布式session共享的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-01-01Java實(shí)現(xiàn)年獸大作戰(zhàn)游戲詳解
春節(jié)要到了,看慣了前端各種小游戲,確實(shí)做得很好,很精致。本文將為大家介紹一款java版本的年獸大作戰(zhàn)游戲,感興趣的小伙伴可以試一試2022-01-01