後端技術考古題-開發工具 中篇

閱讀時間約 5 分鐘

※ 主題關鍵字

  • Git flow:
raw-image


說明:

  1. Git Flow 是一種基於 Git 版本控制系統的擴展,用於協助團隊進行項目的軟體開發和版本管理,就流程來說屬於概括性的流程
  2. 這種工作流程定義了一組明確的分支模型,以協助有效地進行功能開發、修復錯誤和發布版本。
  3. Git Flow 可以針對不同的開發環境建置不同的測試或正式版本。
  4. 在Git Flow流程下,不同開發者可以同時開發不同功能,或者同時一起開發一個大功能。當開發和發佈同時進行時,彼此將不受影響。因此整個開發過程中,會有良好的共同程式開發和版本控制協作流程。
  5. 透過Git Flow所創造出一個具統一性、受規範、自動化(搭配 CI/CD)的開發流程,可以減少人為犯錯的風險、同時提升效率。

Git Flow五種分支的介紹:

  • 兩個長期存在的分支,且絕對不會被刪除:
  1. 主分支Master。
  2. 開發分支Develop。
  • 三種短期(臨時性)分支。開發完畢被merge進develop或master後就會被刪除的分支:
  1. 功能分支(feature branch)。
  2. 預發分支(release branch)。
  3. 修復分支(hotfix branch)。
raw-image


Git Flow包含五種分支負責處理不同的功能:

  1. Master: Master分支會專門放正式發布版本或隨時可以上線的版本。
raw-image
  1. Developer: 用來存放最新開發版本的代碼,是開發過程中代碼的中心分支。開發人員通常會以Developer這條分支為基礎,再開出Feature分支進行新功能的開發,當Feature的功能開發完畢,Feature的分支會合併回Developer。
raw-image
  1. Feature:Feature分支裡面主要是用來處理開發新功能,會是基於Developer分支開出來,功能完成時,再把開出來的Feature分支合併回Developer分支。
raw-image
  1. Release:用於支援準備發佈正式產品前的預備分支。允許修正小問題,並為發布版本準備或修改中介資料。
  2. HotFix:在Master分支中出現重大錯誤時,可以直接從Master分支建立HotFix分支來快速實施錯誤修正。
raw-image



  • GitHub flow
raw-image

整個 GitHub Flow 是基於主分支的一種輕量化工作流程,屬於 Git 的核心概念,目的在幫助團隊及專案定期的進行部署。它重點在於簡單、靈活且容易理解,特別適用於需要快速反應和頻繁交付的專案。

使用說明:

先有一個共有的遠端倉庫,然後各自用fork把遠端倉庫fork回到自己的倉庫。開發好後,再利用PR(pull request)回去共有的遠端倉庫,審核過後merge(合併)進master。

raw-image


※ GitHub Flow 的主要特點:

  1. 主分支(Main Branch): GitHub Flow 使用一個主分支,通常命名為 mainmaster,用於代表產品的穩定狀態。這是所有發布版本的基礎。
  2. 建立分支(Branching): 每當需要測試新功能、修復錯誤或進行任何其他工作時,團隊成員會在主分支的基礎上創建一個新的分支。這個分支將包含他們所進行的更改。分離出的新分支對 master 來說是非常重要的,因此分支命名應該具有描述性,讓其他人清楚知道分支正在進行的工作項目。
建立分支

建立分支


  1. 提交(Commits): 在分支上進行工作時,開發者將其更改進行提交(commit)。每次提交都應該要有相關的提交訊息(Commits Message),解釋此次提交內容。
Add Commits

Add Commits

2. 拉取請求(Pull Requests): 當在分支上完成一項任務時,開發者會向主分支提出拉取請求(pull request)。Pull Request 是一個通知團隊進行代碼審查、討論和測試的機會,因此對於協作開源專案和管理共享儲存庫的修改非常有用。

  1. 代碼審查(Code Review): 團隊成員將檢查拉取請求中的更改,提供反饋並確保代碼符合標準。這有助於確保代碼的質量和一致性。
拉取請求和代碼審查

拉取請求和代碼審查

4. 合併(Merge): 一旦拉取請求經過審查,並經過必要的更改和測試,就可以將其合併到主分支中。

合併

合併

5. 部署(Deploy): 已經被檢閱且通過測試的分支被合併到主分支上後,將被部署為生產版本,形成新的軟體發布。

部署(Deploy)

部署(Deploy)

※總結:

  • 所有在 master 分支都是可部署(Deployable)的。
  • 要增加新功能時,從 master 開一個此新功能的分支,分支命名應該具有描述性。
  • 需要回饋、幫助時,或是當完成新功能要合併(Merge)回 master 分支時,請使用 Pull Request。
  • 經過審查、測試過後,就可以合併回 master 分支。
  • 合併之後就可以馬上部署程式碼。



  • 什麼是 rebase:

說明: 

  1. rebase是 Git中的一個操作,主要用於合併分支或整理提交歷史。
  2. rebase 簡單來說就像「移花接木」,把你的分支接到別的分支上。
_images/rebase.png

_images/rebase.png

以上圖來說,就是把 New Branch 的變更整個接到 Master 上。

  • Rebase 的使用時機:
  1. 整理提交歷史:rebase 可以對提交歷史進行清理和整理。
  2. 將一個分支的修改整合到另一個分支:使用 rebase有助於保持歷史的簡潔性,避免不必要的合併提交。
  3. 解決合併衝突:在進行 rebase 時,會發生合併衝突。當解決衝突後,可以繼續應用剩下的修改。
  4. 避免合併提交:使用 rebase 可以避免產生大量的合併提交,可以讓提交歷史更加緊湊,更容易理解。
  5. 在提交到遠端之前整理分支歷史: 在推送分支到遠端之前,進行 rebase 可以確保提交歷史的整潔性,避免向遠端推送不必要的合併提交。


    全端網頁開發專業知識分享
    留言0
    查看全部
    發表第一個留言支持創作者!
    你可能也想看
    後端硬體輸出-解說 製作檔案後續流程 -->底片-->曬版-->印刷機---印刷 -->出版----------->印刷機---印刷 最先接觸的是底片機,那時照相機還是膠捲時代,而報紙與周刊要印刷前都是輸出成透明黑字圖底片,再經由曬版功序進入印刷機。 出片機 以下廠牌為當時最大宗(中譯名),西元年是我
    Thumbnail
    avatar
    怡伶
    2023-08-29
    非本科轉職後端工程師的心路歷程菜雞成長故事 寫這一篇主因也是因為身邊朋友陸陸續續想往軟體業發展,或是想動手做做小專案,故才成就了這一篇心路歷程,這邊會介紹我的背景、學習管道跟我如何選擇第一個程式語言作為敲門磚跟學習時間,希望能幫助還在努力中或是預計要轉職的各位有一個方向或是參考?(雖然我依然還是一個小菜雞,請鞭小力)
    Thumbnail
    avatar
    DDDDD
    2023-08-18
    【好想工作室 — 後端 (backend Camp)培訓心得(五):這麼多東西,要怎麼學最有效率?】初學後端的人,可能對如何學習後端技術或語言會感到很困惑。 本篇文章提供了作者的幾種思路,幫助後端學員進行學習
    Thumbnail
    avatar
    結語JYu
    2023-04-01
    【好想工作室 — 後端 (backend Camp)培訓心得(四):我快崩潰了,怎麼辦?】在工作室培訓難免會陷入低潮的原因,本篇文章分析了陷入低潮的原因,及提供預防及解決方法。
    Thumbnail
    avatar
    結語JYu
    2023-04-01
    好想工作室 — 後端 (backend Camp)培訓心得(三):我好想進來好想這篇文章針對對好想工作室後端培訓(backend camp)有興趣的人,給他們一些申請建議。
    Thumbnail
    avatar
    結語JYu
    2023-04-01
    【好想工作室 — 後端 (backend Camp)培訓心得(二):backend camp 在幹嘛】本篇文章介紹了好想工作室後端培訓(backend camp)可能會遇到的各種狀況。
    Thumbnail
    avatar
    結語JYu
    2023-04-01
    【好想工作室 — 後端 (backend Camp)培訓心得(一):好想工作室簡介】簡單介紹好想工作室。 好想工作室是一個在台南的「資訊聚落」,提供免費的軟體工程師培訓,目前位於台南火車站旁。
    Thumbnail
    avatar
    結語JYu
    2023-04-01
    技術分享 | 如何成為後端工程師嗨 我是森妮 上週讓大家投票下一篇文章,沒想到後端工程師篇壓倒性勝利 前端工程師篇不知道大家喜不喜歡!陸續在IG有收到私訊有不少關於後端工程師的問題,我只要有時間都會回應,也歡迎來跟我聊聊天 【後端工程師】 [工作流程] 團隊中的PM、SA與客戶進行需求確認 [學習路徑] >基礎概念與工具
    Thumbnail
    avatar
    森妮後端工程師日常
    2022-09-07
    碳權商機|因應極端氣候與國際碳定價趨勢,蘇貞昌:積極修定《氣候法》,納 2050 淨零排放 隨著全球啟動「淨零競逐」(Race to Zero),以及國際碳定價趨勢越來越盛行,行政院長蘇貞昌 8 月要求環保署積極辦理「溫室氣體減量及管理法」修法作業,不僅要納入 2050 淨零排放的減排目標,也要加速台灣碳定價制度的擬定。 蘇貞昌:台灣深受極端氣候衝擊,氣候行動不應落於人後 今年台灣面臨嚴
    Thumbnail
    avatar
    本住人
    2021-09-11
    Laravel Socialite 實作前後端分離的第三方登入 API本文使用網站的 FB 登入做示範 採用 Laravel 8 + Socialite 5 使用 Session 記錄狀態 不同版本可能會有些許語法及方法上的差異,請自行調整 前言 最近因為碰到需要實作 OAuth 第三方登入的需求,只好把之前隨便看看的東西撿回來研究並實作。不過我找到多數現存的中文文章
    Thumbnail
    avatar
    hms5232
    2021-02-21