成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

10個節(jié)省時間和改善工作流的Git技巧

新聞 前端
這 10 個 Git 小技巧,不僅可以節(jié)省時間,而且能改善你的工作流程。

 [[316431]]

這 10 個 Git 小技巧,不僅可以節(jié)省時間,而且能改善你的工作流程。

根據(jù)手冊,Git 被定義為傻瓜式內容追蹤器,它功能豐富,但有些功能卻讓人望而生畏。因此,我們只是重復使用那幾個被記住的命令,而沒有充分使用。

https://manpages.debian.org/stretch/git-man/git.1.en.html

技巧 1:優(yōu)化配置

Git 在全局、用戶和本地級別上都是高度可配置的。

https://git-scm.com/docs/git-config

查找順序

每個設置都可以被覆蓋:

  1. $CWD/.git/config 
  2.     ▼ ▼ ▼ 
  3. $HOME/.gitconfig` 
  4.     ▼ ▼ ▼ 
  5. $HOME/.config/git/config 
  6.     ▼ ▼ ▼ 
  7. /etc/gitconfig 

修改設置

用你喜歡的編輯器或者 CLI 編輯任何配置文件:

  1. # 全局設置 
  2. git config --global <keypath> <value> 
  3. # 本地設置 
  4. git config <keypath> <value> 

如果值包含空格字符,則需要用引號引起來。

顯示當前設置

  1. # 顯示當前設置及其來源 
  2. git config --list --show-origin 

一些有用的配置

  1. # 設定身份 
  2. git config --global user.name "<your name>" 
  3. git config --global user.email <your email> 
  4. # 首選編輯器 
  5. git config --global core.editor vim 
  6. # 證書緩存 
  7. # WINDOWS 
  8. git config --global credential.helper manager 
  9. # LINUX (超時時間——以秒為單位) 
  10. git config --global credential.helper "cache --timeout=3600" 
  11. # MACOS 
  12. git config --global credential.helper osxkeychain 

https://git-scm.com/docs/gitcredentials

技巧 2:別名(alias)

創(chuàng)建一個別名來保存常用的 git 命令:

  1. # 創(chuàng)建別名 
  2. git config --global alias.<alias-name> "<git command>" 
  3. # 使用別名 
  4. git <alias-name> <more optional arguments> 

一些有用的別名

  1. # 撤銷上次提交 
  2. git config --global alias.undo "reset --soft HEAD^" 
  3. # 將暫存區(qū)更新修訂到上次提交 (不改變提交信息) 
  4. git config --global alias.amend "commit --amend --no-edit" 
  5. # 壓縮的狀態(tài)輸出 
  6. git config --global alias.st "status -sb" 
  7. # 用 GRAPH 為日志著色 
  8. git config --global alias.lg "log --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset'" 
  9. # 刪除所有已合并的分支 
  10. git config --global alias.rmb "!git branch --merged | grep -v '*' | xargs -n 1 git branch -d" 
  11. # 貢獻排行 
  12. git config --global alias.rank "shortlog -n -s --no-merges" 

技巧 3:查找 Commits 和更改

通過 Commits 信息查找

  1. # 通過 commit 信息查找 (所有分支) 
  2. git log --all --grep='<search term>' 
  3. # 通過 commit 信息查找 (包含 reflog) 
  4. git log -g --grep='<search term>' 

通過更改查找

  1. # 通過更新的內容查找 
  2. git log -S '<search term>' 

通過日期查找

  1. # 通過日期范圍查找 
  2. git log --after='DEC 15 2019' --until='JAN 10 2020' 

技巧 4:添加 hunk

git add <filepath>不僅能添加文件的所有變更,--path / -p參數(shù)還可以交互式暫存區(qū)塊。

  1. # 補丁命令 
  2. y = 暫存區(qū)塊 
  3. n = 不暫存這個區(qū)塊 
  4. q = 退出 
  5. a = 暫存當前文件的此區(qū)塊以及所有剩余區(qū)塊 
  6. d = 不暫存當前文件的此區(qū)塊以及所有剩余區(qū)塊 
  7. / = 查找區(qū)塊 (正則表達式) 
  8. s = 劃分成更小的區(qū)塊 
  9. e = 手動編輯區(qū)塊 
  10. ? = 打印幫助說明 
  11. g = 選擇要前往的區(qū)塊 
  12. j = 將區(qū)塊設為未定,查看下一個未定區(qū)塊 
  13. J = 將區(qū)塊設為未定,查看下一個區(qū)塊 
  14. k = 將區(qū)塊設為未定,查看上一個未定區(qū)塊 
  15. J = 將區(qū)塊設為未定,查看下一個區(qū)塊 

https://git-scm.com/docs/git-add#Documentation/git-add.txt--i

技巧 5:儲藏(stash)更改而不提交

stash 將當前的更改臨時擱置起來。在它的幫助下,可以返回當前狀態(tài)的索引,并能在稍后應用已儲藏的更改。

默認情況下,僅儲藏當前跟蹤文件中的更改,新文件將被忽略。

我們可以獨立地創(chuàng)建和應用多個 stash。

https://git-scm.com/docs/git-stash

創(chuàng)建

  1. # 創(chuàng)建新的 STASH 
  2. git stash 
  3. # 創(chuàng)建新的 STASH (包含未追蹤的更改) 
  4. git stash -u/--include-untracked 
  5. # 創(chuàng)建新的 STASH 并命名 
  6. git stash save "<stash name>" 
  7. # 交互式儲藏 
  8. git stash -p 

羅列

  1. # 列出所有的 STASH (為其他命令提供"n"
  2. git stash list 

瀏覽

  1. # 瀏覽 STASH 內容 
  2. git stash show 
  3. # 瀏覽 STASH 差異 
  4. git stash show -p 

應用

  1. # 應用上一個 STASH (刪除 stash) 
  2. git stash pop 
  3. # 應用上一個 STASH (保留 stash) 
  4. git stash apply 
  5. # 應用特定的 STASH (n = stash 列表序號) 
  6. git stash pop/apply stash@{n} 
  7. # 從 STASH 創(chuàng)建新的分支 (n = stash 列表序號) 
  8. git stash branch <new branch name> stash@{n} 
  9. # 從 STASH 應用單個文件 (n = stash 列表序號) 
  10. git checkout stash@{n} -- <filepath> 

清理

  1. # 刪除特定的 STASH (n = stash 列表序號) 
  2. git stash drop stash@{n} 
  3. # 刪除所有的 STASH 
  4. git stash clear 

技巧 6:空運行(Dry Run)

許多 git 操作可能具有破壞性,例如,git clean -f將刪除所有未跟蹤的文件,而且無法恢復。

要避免出現(xiàn)這種災難性的結果,許多命令都支持dry-run,可以在實際產(chǎn)生結果前對其進行檢查。不過遺憾的是,使用的選項不完全一致:

  1. git clean -n/--dry-run 
  2. git add -n/--dry-run 
  3. git rm -n/--dry-run 
  4. # GIT MERGE 模擬 DRY-RUN 
  5. git merge --no-commit --no-ff <branch> 
  6. git diff --cached 
  7. git merge --abort 

請注意,git commit -n根本不是dry-run!它實際上是--no-verify,作用是忽略所有pre-commit/commit-msg githooks。

技巧 7:安全強制推送

在處理舊的 commit、創(chuàng)建新的 head 等情況時時很容易弄亂分支。git push --force可以覆蓋遠程變更,但不應該這樣做!

git push --force是一種具有破壞性且危險的操作,因為它無條件生效,并且會破壞其他提交者已經(jīng)推送的所有 commit。這對于其他人的代碼倉庫來說不一定是致命的,但是改變歷史記錄并影響其他人并不是一個好主意。

更好的選擇是使用git push --force-with-lease。

git 不會無條件地覆蓋上游的遠程倉庫,而是檢查是否有本地不可用的遠程更改。如果有,它會失敗并顯示一條“stale info”消息,并告訴我們需要先運行git fetch。

https://git-scm.com/docs/git-push#Documentation/git-push.txt---force-with-leaseltrefnamegt

技巧 8:修改 commit 信息

Commit 是不可變的,且不能更改。不過可以用一條新的 commit 信息修訂現(xiàn)有的 commit,這會覆蓋原始 commit,因此請勿在已推送的 commit 中使用它。

  1. git commit --amend -m "<new commit message>" 

https://git-scm.com/docs/git-commit#Documentation/git-commit.txt---amend

技巧 9:修改歷史

修改代碼倉庫的歷史不僅限于修改上次提交信息,使用git rebase可以修改多個提交:

  1. # 提交的范圍 
  2. git rebase -i/--interactive HEAD~<number of commits> 
  3. # 該 hash 之后的所有提交 
  4. git rebase -i/--interactive <commit hash> 

在配置的編輯器中倒序列出所有的 commit,像這樣:

  1. # <command> <commit hash> <commit message> 
  2. pick 5df8fbc revamped logic 
  3. pick ca5154e README typos fixed 
  4. pick a104aff added awesome new feature 

通過更改編輯器中的實際內容,可以為 git 提供一個方案,來說明如何進行 rebase:

  1. # p, pick   = 使用提交而不更改 
  2. # r, reword = 修改提交信息 
  3. # e, edit   = 編輯提交 
  4. # s, squash = 匯合提交 
  5. # f, fixup  = 類似"squash",但是會丟棄提交信息 
  6. # x, exec   = 運行命令 (其余行) 
  7. # d, drop   = 移除提交 

保存編輯器后,git 將運行該方案以重寫歷史記錄。e, edit會暫停 rebase,就可以編輯代碼倉庫的當前狀態(tài)。完成編輯后,運行git rebase --continue。

如果過程中出現(xiàn)問題(例如合并沖突),我們需要重新開始,可以使用git rebase --abort。

https://git-scm.com/docs/git-rebase

技巧 10:存檔跟蹤文件

可以使用不同格式(zip或tar)來壓縮特定引用的跟蹤文件:

  1. git archive --format <format> --output <filename> <ref> 

<ref>可以是一個分支、commit hash 或者一個標簽。

https://git-scm.com/docs/git-archive

額外提醒:單破折號

有一個快捷方式可以表示剛用過的分支:一個單破折號-

  1. git checkout my-branch 
  2. # 當前分支:my-branch 
  3. <do some git operations, e.g. adding/commiting> 
  4. git checkout develop 
  5. # 當前分支:develop 
  6. git merge - 
  7. # 將 my-branch 合并到 develop 

單破折號等同于@{-1}。

https://git-scm.com/docs/git-checkout#Documentation/git-checkout.txt-ltbranchgt

總結

Git 還有很多話題可談,這里只涉及一些皮毛。在另一篇文章中,我想展示如何用git bisect有效查找損壞的 commit,或者如何通過git reflog來運用任意git操作的完整歷史記錄。

 

責任編輯:張燕妮 來源: 架構頭條
相關推薦

2022-12-26 17:33:43

Jupyterpython

2022-05-02 17:52:53

Python編程語言

2011-02-23 16:07:44

MySQL

2022-04-13 13:51:12

DevSecOps工具開發(fā)管道

2020-04-27 11:11:54

數(shù)據(jù)湖數(shù)據(jù)人工智能

2024-05-13 12:36:51

Python代碼

2020-01-16 10:20:45

piwheels樹莓派Linux

2011-09-29 11:33:35

Linux

2023-09-18 11:32:37

Python計算

2020-06-04 15:55:54

GitHub代碼開發(fā)者

2020-03-10 10:12:14

CIO自動化人力資源

2022-12-19 15:25:22

Linux命令

2018-07-09 09:00:00

開源網(wǎng)絡管理操作系統(tǒng)

2009-08-24 08:59:10

IT白領網(wǎng)絡應用

2018-07-03 10:33:51

服務器運維Linux

2011-07-29 10:32:09

Linux管理員命令行

2011-08-01 09:36:53

Linux管理員

2023-08-13 16:46:36

2023-12-06 18:06:37

Git開發(fā)

2021-06-11 08:00:00

人工智能航空工具
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 精品国产乱码久久久久久影片 | 91网站视频在线观看 | 偷拍第一页 | 香蕉久久久久久 | 亚洲精品国产综合区久久久久久久 | 亚洲一二三区免费 | 日韩精品久久久久 | 成人精品鲁一区一区二区 | 久久精品视频在线播放 | 国产精品999 | 亚洲欧美激情四射 | 免费a网站| 久热国产精品视频 | 色爱综合网| 国产一级一级国产 | 国产一区二区三区视频 | 久久久久久亚洲欧洲 | 国产精久久久久久久妇剪断 | 一区二区在线不卡 | 久久国产成人 | 免费av电影网站 | 国产一区二区黑人欧美xxxx | 欧美日韩久 | 一级黄色毛片免费 | 国产伦一区二区三区久久 | 国产精品一区二区免费 | 亚洲免费在线 | 中文字幕亚洲欧美 | 中文字幕亚洲一区 | 日本精品视频 | 九九热视频这里只有精品 | 日本不卡一区 | 中文字幕不卡在线88 | 欧美三级在线 | 国产一区二区三区免费 | 日韩一区二 | 日韩精品在线看 | 青青久久 | 欧美在线视频网 | 免费一区二区三区在线视频 | 久久久青草婷婷精品综合日韩 |