首頁 >後端開發 >Python教學 >使用git bisect快速定位引入錯誤的版本

使用git bisect快速定位引入錯誤的版本

高洛峰
高洛峰原創
2016-12-14 15:57:541082瀏覽

現在有個項目,在一天的開發中,被某個工程師引入了一個bug,取系統並發上不去,直接鎖死資料庫連線。專案使用java平台,在svn上進行版本管理。我不想一個個版本code review排查,就想到了最暴力折半版本查找法,當然,在svn上做意味著要一個個版本checkout出來,這麼大的項目,也是很費時的,這時,git-bisect是我唯一的選擇了。

首先,把svn庫匯出為git庫: 
  $ git svn clone -s http://svn.xxx.com/svn/xxxxx 
然後,開始git bisect: 
$git xxx 
然後,開始git bisect: 
$git xxx 
然後,開始git bisect: 
: 
  $ git bisect bad 
找到前一天的版本,做了一個tag(tag20090106),測試為正確的,標記一下: 
  $ git bisect good  tag20090106 
  $ git bisect good  tag20090106 
這版本就開始編譯,測試,如果不通過,執行: 
  $ git bisect bad 
git會用折半方法再向前找一個中間版本,開始編譯,測試,如果通過,執行: 

  $ git bisect good 🎜git將繼續定位revision,直到最後定位到一個引入錯誤的版本,這時再分析原因,再找惹麻煩的工程師PK,PK完了回來收工執行: 🎜  $ git bisect reset 🎜git將回到目前的HEAD.🎜
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn