目錄
pull or fetch
merge or rebase
示例操作
其他命令参考
首頁 開發工具 Git 聊聊Gitlab怎麼優雅的拉取和合併程式碼

聊聊Gitlab怎麼優雅的拉取和合併程式碼

Mar 28, 2023 pm 07:09 PM
git github gitlab

Gitlab中怎麼優雅的拉取和合併程式碼?以下這篇文章跟大家介紹一下Gitlab中拉取和合併程式碼的方法,希望對大家有幫助!

聊聊Gitlab怎麼優雅的拉取和合併程式碼

pull or fetch

#拉取程式碼的操作有兩種形式,git pullgit fetch,那麼這兩種有什麼差別呢?

讓我們先來看看一個架構圖

圖中展示一個完整的git流程,為了更清晰的了解每個區域,我們下來解釋他們的功能:

  • 工作區(working directory), 簡言之就是你工作的區域。對git而言,就是的本地工作目錄。
  • 暫存區(stage area, 又稱為索引區index), 是把修改提交版本庫之前的一個過渡階段。在工作目錄下.git的目錄裡面有個index文件,儲存著關於暫存區的內容。 git add指令將工作區內容新增至暫存區。
  • 本地倉庫(local repository), 版本控制系統的倉庫,存在於本地。執行git commit指令後,會將暫存區內容提交到倉庫之中。 .git/objects目錄中存放了每一個提交的記錄,而在.git/refs目錄下存放的是分支資訊和tag資訊。
  • 遠端版本庫(remote repository), 與本地倉庫概念基本上一致,不同之處在於一個存在遠端,可用於遠端協作,但一個存在於本地。透過push/pull可實現本地與遠端的互動;
  • 遠端倉庫副本, 可以理解為存在於本地的遠端倉庫快取。當使用git fetch拉取遠端程式碼倉庫的時候,就相當於在本地有一個遠端倉庫的副本,你可以選擇把這個副本合併到本地倉庫。

從圖中可以看出來,當我們使用git pull拉取程式碼的時候,是直接合併到了本地分支,而使用git fetch拉取程式碼的時候,會先在本地產生一個遠端倉庫的副本,然後使用git mergegit rebase合併到本地分支。

既然能直接git pull何必多次一舉呢?試想一個場景,當你想合併別人的程式碼,又不知道人家改了什麼東西,是否能夠跟你程式碼合併到一起,這時候透過git fetch就能很輕易的實現。 git fetch以後實際上並不會立刻跟本地分支立刻合併,在git fetch以後,會顯示如下圖:

上圖顯示了遠端新增了一個test2分支,在test分支上多了個提交訊息,這時候在.git/refs/remotes/origin 目錄下可以看到多了一個test2分支。

使用git log origin/test,可以查看具體的提交資訊

如果想查看提交的內容是啥,只能透過新建一個分支,

git checkout -b test-origin
git merge test
登入後複製

講到這裡,相信你已經明白了git pullgit fetch的差別了吧。總結一下:

  • git fetch 更安全,更人性化

  • git pull 更激進,破壞性更強

一般的Leader在管理專案的時候都是習慣性的使用git fetch查看最近新增了哪些分支,做了哪些修改,從而對專案做出更好的把控。

merge or rebase

上面提到的合併操作,一般我們直接透過git merge <分支名>去合併某個分支的程式碼。先看看直接使用git merge的問題,有一條看著很不順眼的Merge branch訊息,如下圖所示:

下圖是合併後的一個流程圖,當我們在main分支拉一個dev進行開發,這時候兩個分支都有提交記錄,當我們合併的時候,正常情況應該是在main的基礎上,直接合併,而不是多了一個C7的提交信息,也就是上面提到的Merge branch,這顯然是一個很不合理的現象(當然這也不影響git正常運作)。

那要如何解決這個現象所導致的問題呢?答案就是git rebase,俗稱變基。

下面我们先来看看变基以后git分支是什么样的了

可以看到,当dev分支更新之后,它会指向这些新创建的提交(commit),而那些老的提交会被丢弃。

示例操作

上面讲了这么多,现在让我们来实际操作一下。

场景:远程有一个main分支上有内容更新,现在我们需要把更新的内容合并到本地dev分支上,然后push到远程dev分支,当前分支实在dev分支。

简单实现(就是很朴实无华):

# 拉取main分支代码
git fetch origin main
# 合并到dev
git rebase origin/main
登入後複製

上面的git rebase还有个快捷的操作,直接一行命令搞定

# 拉取test分支代码合并到dev
git pull --rebase origin test
登入後複製

如果你不想每次都添加rebase,可以在终端中输入下面的命令:

git config --global pull.rebase true
登入後複製

这个配置就是告诉git在每次pull前先进行rebase操作

其他命令参考

# 查看本地分支
git branch
# 查看远程分支
git branch -r
# 查看所有分支
git branch -a

# 拉取所有远程分支代码
git fetch 
# 拉取origin源上所有分支代码
git fetch origin
# 拉取orign源上main分支代码
git fetch origin main

# 拉取远程分支到新建的一个本地分支并
git checkout -b newBrach origin/master
# 合并远程分支到本地
git pull --rebase origin master

# 查看提交日志
git log --oneline
# 查看某个人提交的日志
git log --author=xiumubai --oneline
# 查看某个文件提交的记录
git blame README.md
# 查看某次提交的内容
git show <commitid>
# 查看最近几次的提交

git log -p -n
登入後複製

(学习视频分享:编程基础视频

以上是聊聊Gitlab怎麼優雅的拉取和合併程式碼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1654
14
CakePHP 教程
1413
52
Laravel 教程
1306
25
PHP教程
1252
29
C# 教程
1225
24
git怎麼更新代碼 git怎麼更新代碼 Apr 17, 2025 pm 04:45 PM

更新 git 代碼的步驟:檢出代碼:git clone https://github.com/username/repo.git獲取最新更改:git fetch合併更改:git merge origin/master推送更改(可選):git push origin master

git怎麼下載項目到本地 git怎麼下載項目到本地 Apr 17, 2025 pm 04:36 PM

要通過 Git 下載項目到本地,請按以下步驟操作:安裝 Git。導航到項目目錄。使用以下命令克隆遠程存儲庫:git clone https://github.com/username/repository-name.git

git怎麼合併代碼 git怎麼合併代碼 Apr 17, 2025 pm 04:39 PM

Git 代碼合併過程:拉取最新更改以避免衝突。切換到要合併的分支。發起合併,指定要合併的分支。解決合併衝突(如有)。暫存和提交合併,提供提交消息。

git下載不動怎麼辦 git下載不動怎麼辦 Apr 17, 2025 pm 04:54 PM

解決 Git 下載速度慢時可採取以下步驟:檢查網絡連接,嘗試切換連接方式。優化 Git 配置:增加 POST 緩衝區大小(git config --global http.postBuffer 524288000)、降低低速限制(git config --global http.lowSpeedLimit 1000)。使用 Git 代理(如 git-proxy 或 git-lfs-proxy)。嘗試使用不同的 Git 客戶端(如 Sourcetree 或 Github Desktop)。檢查防火

git commit怎麼用 git commit怎麼用 Apr 17, 2025 pm 03:57 PM

Git Commit 是一種命令,將文件變更記錄到 Git 存儲庫中,以保存項目當前狀態的快照。使用方法如下:添加變更到暫存區域編寫簡潔且信息豐富的提交消息保存並退出提交消息以完成提交可選:為提交添加簽名使用 git log 查看提交內容

如何解決PHP項目中的高效搜索問題? Typesense助你實現! 如何解決PHP項目中的高效搜索問題? Typesense助你實現! Apr 17, 2025 pm 08:15 PM

在開發一個電商網站時,我遇到了一個棘手的問題:如何在大量商品數據中實現高效的搜索功能?傳統的數據庫搜索效率低下,用戶體驗不佳。經過一番研究,我發現了Typesense這個搜索引擎,並通過其官方PHP客戶端typesense/typesense-php解決了這個問題,大大提升了搜索性能。

git怎麼更新本地代碼 git怎麼更新本地代碼 Apr 17, 2025 pm 04:48 PM

如何更新本地 Git 代碼?用 git fetch 從遠程倉庫拉取最新更改。用 git merge origin/&lt;遠程分支名稱&gt; 將遠程變更合併到本地分支。解決因合併產生的衝突。用 git commit -m "Merge branch &lt;遠程分支名稱&gt;" 提交合併更改,應用更新。

git怎麼刪除倉庫 git怎麼刪除倉庫 Apr 17, 2025 pm 04:03 PM

要刪除 Git 倉庫,請執行以下步驟:確認要刪除的倉庫。本地刪除倉庫:使用 rm -rf 命令刪除其文件夾。遠程刪除倉庫:導航到倉庫設置,找到“刪除倉庫”選項,確認操作。

See all articles