您好,登錄后才能下訂單哦!
這期內容當中小編將會給大家帶來有關Git的實用技巧都有哪些,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。
在 定位到出錯的代碼行 以后,就可以通過 git blame
進一步找到誰動了相關代碼,或者找到這筆改動的歷史背景,舉例如下:
$ cd linux-stable$ git blame -L 50,50 init/main.c78634061 (Frederic Weisbecker 2017-10-27 04:42:28 +0200 50) #include
在分析衰退時,如果找到了某筆變更,然后,又想進一步確定這筆變更是在哪個版本(Tag)引入的,這個時候可以先找一下該 commit 的時間,然后再比對 Tag 的修訂時間。那么如何查看 commit 和 tag 的引入時間呢?以 HEAD
這筆 commit 舉例如下:
$ date -d @`git log -1 --format=%ct HEAD` +%Y%m%d-%H%M%S20190719-172216
把 HEAD
替換為具體的 commit 和 tag 號即可獲得對應時間。對于 Linux 而言,通常不需要這么復雜,在找到某個變更之后,用下面這個方法就可以確定該變更對應的內核主版本:
$ git show HEAD:Makefile
因為 Makefile 中記錄了內核的版本號。
某個系統,在開發過程中一直都沒測試出問題,突然有一天,發現 Bug。這種蠻多情況是衰退,如果這個 Bug 的復現幾率很大的話,就可以直接用二分法快速定位了。git bisect
就可以輔助進行自動二分法。
簡單的話,就是不停地告訴 git bisect
,哪一個是好的,哪一個是壞的,如果有固定的復現腳本,那么在獲得第一對 bad, good
的 commit 后,就可以直接讓 git bisect
自動二分法。舉例說明:
$ git bisect start$ git bisect bad efa5cf$ git bisect good b6fcf0$ git bisect run grep -q UCONFIG Makefile
說明:
efa5cf
:第一個發現有問題的版本b6fcf0
:某個確認沒問題的版本grep -q UCONFIG Makefile
:能找到 UCONFIG 就是好的,找不到就是有問題在設定完 bad, good
后,git bisect
會自動切出中間某個版本,然后針對這個版本,可以進行配置、編譯、運行,然后根據測試結果設定該版本為 bad or good
,例如:git bisect bad HEAD
,以此類推,git bisect
會不停地切出中間版本,直到可以判斷第一個 bad 的版本,這個版本就是引入衰退的變更。
這個完整的測試過程如果可以自動化,就可以寫成腳本,作為 git bisect run
的參數,這樣就可以避免手動跑測試。上面的 grep 命令是經過初步分析后,找出的簡化策略。如果都能這樣通過檢索代碼變更本身就可以判斷問題,那確實可以省去不少力氣。
前段我們把很多倉庫從 github 搬到了 gitee,搬完以后 Linux Lab 下的 .gitmodules
和 .git/config
都得更新 url 地址,但是更新完以后并不能直接用,還得用 git submodule sync
同步一下:
.gitmodules
和 .git/config
中的 url為優化下載效率,最近把 Linux Lab 遷移到了碼云,配置了不同的 ssh 私鑰/公鑰。為了避免在命令行每次都要額外指定不同的參數,可以添加一個配置文件。
例如,給碼云的私鑰文件命名為 gitee.id_rsa
,把它放到 ~/.ssh
目錄下并修改權限。
$ chmod 600 ~/.ssh/gitee.id_rsa$ chmod 700 ~/.ssh
之后,新增一個 ~/.ssh/config
,加入如下配置:
$ cat ~/.ssh/configHost giteeHostName gitee.comIdentityFile ~/.ssh/gitee.id_rsaUser git
這樣就可以直接類似下面下載和上傳,而無需每次輸入密碼或指定密鑰了,同時省掉了 git@
。
$ git clone gitee:aaaa/yyyy.git$ cd cloud-lab$ touch xxxx$ git add xxxx$ git commit -s -m "add xxxx"$ git push gitee:aaaa/yyyy.git master
用 git clone
下載大型代碼倉庫時,一旦網絡中斷,后果是哭爹喊娘,但是于事無補,叫天天不應。
因為 git clone
沒有實現斷點續傳,不知道開發者腦子“進了什么水”?Linus 求罵 ????
沒關系,用 git fetch
可以實現類似效果,而且極其簡單。
先用 git init 創建一個空目錄:
$ mkdir test-repo$ cd test-repo$ git init
再在里頭用 git fetch
要 clone 的倉庫:
$ git fetch https://gitee.com/tinylab/cloud-lab.git$ git checkout -b master FETCH_HEAD
git fetch
只能一個一個 branch fetch,fetch 完,把 FETCH_HEAD
checkout 出來新建對應的分支即可。如果 git fetch
中途中斷網絡,可以再次 git fetch
,git fetch
可以續傳,不至于一斷網就前功盡棄。
上述就是小編為大家分享的Git的實用技巧都有哪些了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。