git worktree與分支依賴隔離的使用場景分析
git worktree介紹
git worktree
是 Git 命令,用于管理多分支工作區(qū)。
使用場景:
- 同時維護不同分支,隔離分支依賴差異:從原有項目開辟一個分支作為另一個新項目,當兩個項目依賴差距越來越大時,每次切換分支后都需要重新安裝依賴。通過
git worktree
可以隔離兩個分支的依賴,并且兩個分支可以互相merge、cherry-pick。 - 多個分支同步開發(fā):允許在同一存儲庫中的不同分支上同時進行工作,而不需要頻繁切換分支,這對于需要同時處理多個功能或修復(fù)多個 bug 的情況非常有用。
- 進行實驗性更改:在不影響主工作目錄的情況下,嘗試進行實驗性的更改或調(diào)試。
- 同時進行長期和短期任務(wù):有助于同時處理長期開發(fā)任務(wù)和短期修復(fù)任務(wù),而無需相互影響或混淆。
以下是 git worktree
的子命令:
add
:在當前分支下創(chuàng)建一個新工作區(qū)。remove
:刪除一個已添加的工作區(qū)。list
:顯示所有已添加的工作區(qū)。lock
:鎖定工作區(qū)以防止在合并或其他操作時被意外刪除。unlock
:手動取消工作區(qū)的鎖定。
git worktree add <path> [(-b | -B) <new-branch>]
在當前分支下創(chuàng)建一個新工作區(qū),效果類似于git clone
,但新舊工作區(qū)屬于同一個倉庫,可以正常add、commit、merge
等操作。
<path>
:要創(chuàng)建的新工作區(qū)的路徑,一般建立在當前目錄的上一層,如../newpath
。<new-branch>
:要在哪個分支上創(chuàng)建工作區(qū)。如果未指定<new-branch>
,則表示基于當前分支HEAD創(chuàng)建新分支<path>
。-b
表示基于當前分支HEAD創(chuàng)建新分支<new-branch>
,-B
表示強制創(chuàng)建。
注意:
- 原始倉庫默認是一個工作區(qū),關(guān)聯(lián)當前
checkout
的分支! - 只能創(chuàng)建未被關(guān)聯(lián)的分支,或者通過
-b
指令創(chuàng)建新分支! - 可以理解為一個工作區(qū)一個HEAD,但是不能多個HEAD指向同一個分支。
# 基于HEAD創(chuàng)建工作區(qū)../brance1,分支為brance1 # 相當于 git worktree add ../brance1 -b brance1 git worktree add ../brance1
# 關(guān)聯(lián)branch2創(chuàng)建工作區(qū)../brance1,分支為brance2 git worktree add ../brance1 branch2
# 基于HEAD創(chuàng)建工作區(qū)../brance1,分支為brance2 git worktree add ../brance1 -b brance2
git worktree remove <worktree>
移除worktree有兩種方式。
- 方式一:
# 移除指定工作區(qū)<worktree> git worktree remove <worktree>
- 方式二:直接刪除工作區(qū)對應(yīng)的文件夾,然后執(zhí)行
# 清除worktree記錄 git worktree prune
注意:刪除工作區(qū),關(guān)聯(lián)的分支并不會被刪除哦!
git worktree list
顯示所有已添加的工作區(qū)。
git worktree list # 顯示完整的hash值 git worktree list --porcelain
git worktree lock <worktree>
用于鎖定工作區(qū)<worktree>
,以防止在合并或其他操作時被意外刪除。
git worktree unlock <worktree>
解鎖工作區(qū)<worktree>
。
git worktree處理分支依賴沖突
背景
現(xiàn)在遠程倉庫有一個項目gitworktree,存在兩個分支vue
和react
,兩個分支作為兩個項目并行開發(fā),且兩分支下的依賴存在差異。
步驟
1、 將gitworktree目錄下所有內(nèi)容遷移到新的文件夾gitworktree/project1,方便在一個文件夾下管理。
2、 在目錄gitworktree/project1下,執(zhí)行git worktree add ../vue vue
。執(zhí)行完后可以發(fā)現(xiàn)gitworktree目錄下存在兩個文件夾,分別是project1 和 vue。
3、 在目錄gitworktree/project1下,執(zhí)行git worktree add ../react react
。執(zhí)行完后可以發(fā)現(xiàn)gitworktree目錄下存在三個文件夾,分別是project1 、 vue 和 react。
這時候就可以愉快的玩耍了,可以像往常一樣add、commit、merge
,甚至cherry-pick
!兩個分支vue
和 react
已經(jīng)隔離開了,且依賴互不影響。
與往常不同的是,vue
和react
之間不能互相切換分支,只需要打開對應(yīng)工作區(qū)即可進入對應(yīng)的分支。
到此這篇關(guān)于git worktree與分支依賴隔離的文章就介紹到這了,更多相關(guān)git worktree與分支依賴隔離內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Git如何實現(xiàn)撤銷提交(命令行+IDEA)
- git提交報錯pre -commit hook failed (add --no-verify)問題及解決
- git提交出現(xiàn)commit提醒信息界面怎樣退出
- git合并部分提交的實現(xiàn)
- git如何將master分支上的代碼合并到自己新建的分支上
- gitlab分支合并沖突的處理過程
- git分支或指定文件回退到指定版本命令詳解
- GitLab在IDEA中回滾主分支問題
- git流水線(Pipeline)導(dǎo)致分支(Branch)無法合并問題及解決
- git如何合并某個分支的某次提交(cherry-pick)
- git如何從某個分支的指定歷史版本中創(chuàng)建新分支
- Git提交到錯誤分支如何解決
相關(guān)文章
基于IntelliJ IDEA/Android Studio插件開發(fā)指南(推薦)
Android Studio是基于Intellij IDEA開發(fā)的,所以開發(fā)Android Studio的插件,其實就是開發(fā)IDEA的插件。根據(jù)官方推薦,使用IDEA IDE來開發(fā)IDEA插件,本文給大家介紹插件開發(fā)的基本流程,感興趣的朋友一起看看吧2021-10-10VsCode中ctrl+s后會在當前目錄下自動生成dist目錄的方法
這篇文章主要介紹了VsCode中ctrl+s后會在當前目錄下自動生成dist目錄,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-09-09教你如何在WordPress發(fā)布文章時自定義文章作者名稱
這篇文章主要介紹了如何在WordPress發(fā)布文章時自定義文章作者名稱2021-09-09