CI_CD流程範本

CI/CD 流程範本 Prompt 目標 指導 AI 建立完整的 CI/CD 流程,包含持續整合、持續部署和基礎設施即程式碼。 角色設定 你是一位資深 DevOps 工程師,具備豐富的 CI/CD 流程設計和實作經驗,熟悉各種自動化部署工具和雲端平台。 任務描述 請協助我為 {專案名稱} 建立完整的 CI/CD 流程。 專案 DevOps 背景 專案名稱: {填入專案名稱} 應用架構: {填入應用架構,如:微服務、單體應用} 技術棧: {填入技術棧} 部署平台: {填入目標平台,如:AWS、Azure、GCP、Kubernetes} 團隊規模: {填入團隊人數} 發布頻率: {填入預期發布頻率} CI/CD 設計要求 請按照以下結構設計 CI/CD 流程: 1. 持續整合設計 原始碼管理策略 建置流程設計 自動化測試整合 程式碼品質門檻 2. 持續部署設計 部署策略選擇 環境管理規劃 發布流程設計 回退機制設計 3. 基礎設施管理 基礎設施即程式碼 環境配置管理 監控和告警設置 安全性配置 4. 自動化工具整合 CI/CD 工具選擇 容器化策略 編排工具配置 工具鏈整合 5. 品質和安全 程式碼掃描整合 漏洞檢測流程 合規性檢查 稽核日誌管理 6. 監控和運維 應用程式監控 基礎設施監控 日誌聚合分析 事件響應流程 輸出格式 # {專案名稱} CI/CD 流程設計 ## 1. 流程概覽 ### 1.1 CI/CD 流程圖 開發者提交程式碼 ↓ 程式碼品質檢查 ↓ 自動化建置 ↓ 自動化測試 ↓ 安全掃描檢查 ↓ 部署到測試環境 ↓ 整合測試執行 ↓ 部署到預生產環境 ↓ 使用者驗收測試 ↓ 部署到生產環境 ↓ 監控和回饋 ...

October 31, 2025 · 9 min · 1830 words · Eric Cheng

Clean Architecture教學

Clean Architecture 教學手冊 📖 手冊說明 本教學手冊專為新進開發同仁設計,旨在幫助您: 理解 Clean Architecture 的核心概念與設計哲學 學會在專案中運用 Clean Architecture 進行開發 具備考取 Clean Architecture 認證的能力 📚 目錄 基礎篇:Clean Architecture 核心概念 1.1 什麼是 Clean Architecture? 1.2 核心原則 1.3 Clean Architecture vs 傳統架構 1.4 常見誤解與迷思 1.5 實務注意事項 架構篇:分層架構與職責 2.1 Clean Architecture 總覽 2.2 第一層:Entities(實體層) 2.3 第二層:Use Cases(用例層) 2.4 第三層:Interface Adapters(介面適配層) 2.5 第四層:Frameworks & Drivers(框架與驅動層) 2.6 層間通信與依賴注入 2.7 實務注意事項 實作篇:專案範例實戰 3.1 專案概述:會員管理系統 3.2 Domain 層實作 3.3 Use Case 層實作 3.4 Interface Adapters 層實作 3.5 實務注意事項 專案應用篇:團隊開發規範 ...

October 31, 2025 · 39 min · 8133 words · Eric Cheng

Clean Code教學

Clean Code 教學手冊 📚 目錄 Clean Code 簡介 1.1 什麼是 Clean Code? 1.2 為什麼 Clean Code 重要? 1.3 與專案品質的關係 核心原則與最佳實踐 2.1 命名原則 2.2 函式原則 2.3 類別與物件原則 2.4 註解原則 2.5 格式化原則 2.6 錯誤處理原則 2.7 測試原則 實務範例與對照 3.1 電商購物車範例 3.2 改善對照分析 3.3 使用者註冊系統範例 3.4 重構步驟與技巧 專案應用指引 4.1 團隊程式碼規範 4.2 程式碼審查流程 4.3 常見反模式與改善 4.4 開發工具配置 4.5 持續整合配置 認證考試重點 5.1 Clean Code 認證概述 5.2 核心知識點 5.3 常見考試題型 5.4 考試準備策略 5.5 考試注意事項 檢查清單 6.1 程式碼撰寫檢查清單 6.2 程式碼品質檢查清單 6.3 重構檢查清單 6.4 團隊協作檢查清單 6.5 專案層級檢查清單 6.6 持續改進檢查清單 6.7 快速參考卡 1. Clean Code 簡介 1.1 什麼是 Clean Code? Clean Code(乾淨程式碼) 是指易於閱讀、理解和維護的程式碼。它不僅僅是能夠運行的程式碼,更是一種追求程式碼品質的哲學。 ...

October 31, 2025 · 34 min · 7184 words · Eric Cheng

code review 指引

Code Review 指引 目錄 前言 1.1 目的 1.2 適用範圍 1.3 Code Review 的價值 Code Review 基本原則 2.1 核心原則 2.2 責任分工 Code Review 流程 3.1 提交 Pull Request (PR) 3.2 指定 Reviewers 3.3 進行程式碼檢查 詳細檢查項目 4.1 程式碼風格與規範 4.2 邏輯正確性檢查 4.3 效能考量檢查 4.4 安全性檢查 4.5 測試覆蓋率檢查 Code Review 工具與自動化 5.1 GitHub Pull Request Review 5.2 GitLab Merge Request Review 5.3 SonarQube 程式碼品質檢查 5.4 ESLint 與 Prettier(前端) 實務操作指南 6.1 Review 意見分類與標準 6.2 常見審查重點清單 6.3 溝通技巧與最佳實務 6.4 Review 會議與討論 常見問題與解決方案 7.1 常見 Review 問題 7.2 效率提升技巧 團隊協作與衝突處理 8.1 Review 意見衝突處理 8.2 跨團隊 Review 協作 8.3 新人培訓與指導 特殊情況處理 9.1 緊急修正流程 9.2 大型重構 Review 9.3 第三方程式碼整合 持續改進與測量 10.1 Review 品質指標 10.2 流程效率分析 10.3 團隊成長追蹤 參考資源與延伸閱讀 11.1 程式碼品質標準 11.2 安全性資源 11.3 工具文件 11.4 最佳實務書籍 附錄 12.1 Review 檢查清單範本 12.2 團隊 Code Review 文化建立 1. 前言 1.1 目的 本指引旨在建立標準化的程式碼審查流程,確保所有程式碼在合併至主分支前都經過充分的檢查與評審,以提升程式碼品質、降低潛在錯誤與技術負債,並促進團隊知識分享與技能提升。 ...

October 31, 2025 · 21 min · 4448 words · Eric Cheng

Design Pattern教學

Design Pattern(設計模式)教學手冊 📋 目錄 基礎入門 1.1 什麼是 Design Pattern? 1.2 為什麼要使用 Design Pattern? 1.3 Design Pattern 的三大分類 1.4 在專案開發中的實際價值 1.5 學習路徑建議 1.6 注意事項與最佳實務 核心內容 - 創建型模式 2.1 Singleton Pattern(單例模式) 2.2 Factory Method Pattern(工廠方法模式) 2.3 Builder Pattern(建造者模式) 2.4 Abstract Factory Pattern(抽象工廠模式) 2.5 Prototype Pattern(原型模式) 2.6 創建型模式總結 核心內容 - 結構型模式 3.1 Adapter Pattern(適配器模式) 3.2 Decorator Pattern(裝飾者模式) 3.3 Facade Pattern(外觀模式) 3.4 Proxy Pattern(代理模式) 3.5 Composite Pattern(組合模式) 3.6 Bridge Pattern(橋接模式) 3.7 Flyweight Pattern(享元模式) 3.8 結構型模式總結 核心內容 - 行為型模式 4.1 Observer Pattern(觀察者模式) 4.2 Strategy Pattern(策略模式) 4.3 Template Method Pattern(模板方法模式) 4.4 Command Pattern(命令模式) 4.5 State Pattern(狀態模式) 4.6 Chain of Responsibility Pattern(責任鏈模式) 4.7 Iterator Pattern(迭代器模式) 4.8 Mediator Pattern(中介者模式) 4.9 Memento Pattern(備忘錄模式) 4.10 Visitor Pattern(訪問者模式) 4.11 Interpreter Pattern(解釋器模式) 4.12 行為型模式實務應用 專案應用指南 ...

October 31, 2025 · 77 min · 16328 words · Eric Cheng

Design Pattern教學(二)

Design Pattern 教學手冊(二)- 進階實務應用 目錄 第 1 章:設計模式概論 第 2 章:設計模式分類與全貌 第 3 章:創建型模式 第 4 章:結構型模式 第 5 章:行為型模式 第 6 章:專案應用指南 第 7 章:學習與練習 第 8 章:認證考試準備 第 9 章:附錄與資源 第 1 章:設計模式概論 1.1 設計模式的定義與歷史背景 1.1.1 什麼是設計模式? 設計模式(Design Pattern)是在軟體開發過程中,針對常見問題的通用解決方案。它是一套被反覆使用、多數人知曉的、經過分類編目的、代碼設計經驗的總結。 1.1.2 Gang of Four (GoF) 的貢獻 1994年,四位軟體工程師 Erich Gamma、Richard Helm、Ralph Johnson、John Vlissides 共同撰寫了《設計模式:可複用物件導向軟體的基礎》一書,定義了23個經典設計模式,被稱為「四人幫」(Gang of Four,GoF)。 timeline title 設計模式發展歷程 1987 : Christopher Alexander 提出建築模式概念 1994 : GoF 發表 23 個經典設計模式 1995 : Java 語言誕生,設計模式開始普及 2000 : 企業級應用廣泛採用設計模式 2010 : Spring Framework 大量運用設計模式 2020 : 微服務架構中的設計模式應用 1.2 為什麼需要設計模式? 1.2.1 解決重複問題 在軟體開發中,我們經常遇到相似的問題。設計模式提供了經過驗證的解決方案,避免重複造輪子。 ...

October 31, 2025 · 52 min · 11001 words · Eric Cheng

Domain-Driven Design教學

Domain-Driven Design (DDD) 教學手冊 專為新進開發同仁設計的 DDD 學習指南 適用技術棧:Vue 3.x (前端) + Spring Boot (後端) + 前後端分離架構 📚 目錄 DDD 基礎概念 1.1 什麼是 Domain-Driven Design? 1.2 DDD 核心概念概覽 1.3 DDD 的三層架構 1.4 實務案例:電商系統 核心構建塊 (Building Blocks) 2.1 Entity (實體) 2.2 Value Object (值對象) 2.3 Aggregate (聚合) 2.4 Repository (儲存庫) 2.5 Domain Service (領域服務) 戰略設計 (Strategic Design) 3.1 Domain、Subdomain 識別 3.2 Bounded Context (有界上下文) 3.3 Context Map (上下文映射) 3.4 Ubiquitous Language (統一語言) 3.5 Event Storming 實務應用 戰術設計 (Tactical Design) 4.1 Domain Events (領域事件) 4.2 Factory Pattern 在 DDD 中的應用 4.3 Specification Pattern (規格模式) DDD 在專案中的實際應用 ...

October 31, 2025 · 37 min · 7879 words · Eric Cheng

Domain-Driven Design教學(一)

Domain-Driven Design 教學手冊(一) 🎯 教學目標 本教學手冊旨在幫助開發團隊成員深入理解並正確應用 Domain-Driven Design (DDD),從基礎概念到實際應用,最終能夠通過 DDD 認證考試。 📚 完整目錄 第一篇:基礎入門 1. 什麼是 Domain-Driven Design (DDD) 1.1 背景與歷史 1.2 為什麼需要 DDD 1.3 與傳統開發方式的差異 💡 實務案例:電商系統設計差異 2. DDD 的核心理念 2.1 Domain(領域)的重要性 2.2 Ubiquitous Language(通用語言) 2.3 Model-Driven Design(模型驅動設計) 3. DDD 的兩大面向 3.1 戰略設計 (Strategic Design) 3.2 戰術設計 (Tactical Design) 3.3 戰略與戰術設計的關係 💯 第一篇檢查清單(Checklist) 🎓 第一篇總結 第二篇:DDD 戰略設計 (Strategic Design) 4. 子域 (Subdomain) 的分類 4.1 什麼是子域 4.2 核心領域 (Core Domain) 4.3 支援子域 (Supporting Subdomain) 4.4 通用子域 (Generic Subdomain) 4.5 子域分類實務工作坊 5. 限界上下文 (Bounded Context) 5.1 定義與識別方法 5.2 界定上下文的準則 5.3 限界上下文的邊界劃分範例 5.4 上下文大小的考量 6. 上下文映射 (Context Mapping) 6.1 Context Map 基本圖示 6.2 上下文之間的關係模式 6.3 整合模式選擇指南 7. 案例分析 7.1 如何將真實專案切分為子域與限界上下文 7.2 分析銀行/金融系統案例 💯 第二篇檢查清單(Checklist) 🎓 第二篇總結 第三篇:DDD 戰術設計 (Tactical Design) 8. 核心構件介紹 8.1 Entity(實體) 8.2 Value Object(值物件) 8.3 Aggregate(聚合)與 Aggregate Root 8.4 Repository(倉儲) 8.5 Service(領域服務 / 應用服務) 8.6 Factory(工廠) 💯 第三篇檢查清單(Checklist) 第四篇:DDD 與實務應用 9. 領域事件 (Domain Events) 9.1 什麼是領域事件 9.2 事件發布與訂閱模式 9.3 Event Sourcing 9.4 CQRS 與 DDD 的結合 10. 模組化與分層架構 10.1 DDD 分層架構 10.2 Hexagonal Architecture(六角架構) 10.3 Clean Architecture 11. 在微服務架構中的 DDD 11.1 Bounded Context 與微服務的對應 11.2 微服務邊界設計 11.3 資料一致性策略 12. 與敏捷、Scrum 的整合 12.1 Event Storming 12.2 Domain Storytelling 12.3 Scrum 中的 DDD 實踐 13. 專案最佳實踐 13.1 常見錯誤與反模式 13.2 成功案例分享 13.3 DDD 導入路線圖 💯 第四篇檢查清單(Checklist) 第五篇:學習檢測與認證準備 14. 章節小測驗 14.1 第一篇:基礎入門 - 測驗題 14.2 第二篇:戰略設計 - 測驗題 14.3 第三篇:戰術設計 - 測驗題 14.4 第四篇:實務應用 - 測驗題 15. DDD 認證考試重點整理 15.1 必考核心概念 15.2 認證準備策略 16. 模擬測驗題庫 16.1 綜合模擬試題 16.2 模擬試題答案 💯 第五篇檢查清單(Checklist) 附錄 A. 快速參考指南 A.1 DDD 核心概念速查表 B. 成功案例研究 B.1 電商平台 DDD 實施 C. 推薦資源 C.1 經典書籍 C.2 線上資源 第一篇:基礎入門 1. 什麼是 Domain-Driven Design (DDD) 1.1 背景與歷史 Domain-Driven Design(領域驅動設計)是由 Eric Evans 在 2003 年出版的同名書籍中首次系統性提出的軟體開發方法論。DDD 的核心思想是將複雜的業務邏輯透過領域模型來表達,讓軟體設計更貼近實際業務需求。 ...

October 31, 2025 · 32 min · 6732 words · Eric Cheng

Entity-Relationship Model (ER Model) 教學手冊

Entity-Relationship Model (ER Model) 教學手冊 📋 目錄 基礎知識 1.1 什麼是 ER Model 1.2 核心概念 1.3 ERD 符號與規則 1.4 基礎實作練習 專案應用 2.1 需求分析到 ER Model 2.2 案例研究:電商平台 2.3 案例研究:銀行系統 2.4 轉換為資料庫 Schema 2.5 完整專案開發流程 進階主題 3.1 實體類型與關聯度 3.2 正規化理論 3.3 常見設計錯誤 3.4 最佳實務 認證準備 4.1 認證內容與範圍 4.2 練習題庫 4.3 模擬考題 4.4 重點知識摘要 學習路徑 5.1 學習步驟建議 5.2 推薦工具 5.3 進階學習資源 檢查清單 6.1 設計階段檢查清單 6.2 資料庫實作檢查清單 6.3 品質保證檢查清單 6.4 專案交付檢查清單 6.5 學習成果檢核 6.6 持續改進檢查 附錄 A. ERD 符號速查表 B. SQL 資料型別對照表 C. 常用正規化檢查 SQL D. 設計模式範本 E. 效能優化檢查清單 F. 安全性檢查清單 G. 版本更新記錄 🚀 快速開始 📖 學習建議 如果您是第一次接觸 ER Model,建議按照以下順序學習: 🔰 初學者路徑(預估 2-3 週) 📚 基礎建立:先閱讀「基礎知識」章節,建立基本概念 🛠️ 實作練習:透過「專案應用」的案例練習實作 📈 深化理解:學習「進階主題」深化理解 ✅ 成果驗證:使用「檢查清單」驗證學習成果 🎯 進階用戶路徑 如果您已具備基礎概念,可直接從第 2 章「專案應用」開始 需要準備認證考試的用戶,重點關注第 4 章「認證準備」 尋找工具和資源的用戶,參考第 5 章「學習路徑」 ⏱️ 時間投入建議 基礎學習:每天 1-2 小時,持續 2-3 週 實作練習:每週 3-5 小時的專案實作 認證準備:額外 2-3 週的集中複習 1. 基礎知識 1.1 什麼是 ER Model Entity-Relationship Model(實體關係模型) 是一種用來描述現實世界資料結構的概念模型。它幫助我們: ...

October 31, 2025 · 28 min · 5802 words · Eric Cheng

GitHub使用hugo建立個人網頁教學

GitHub使用Hugo建立個人網頁教學 文件版本: 1.0 最後更新: 2025年10月15日 適用環境: Windows 10/11 難度等級: ⭐⭐ (初級-中級) 📋 教學大綱 前置條件與工具安裝 建立 Hugo 專案 本機預覽網站 選擇與設定 Hugo Theme 部署到 GitHub Pages 維護與更新內容的流程 設定自訂網域(選用) 檢查清單(Checklist) 🎯 學習目標 完成本教學後,您將能夠: ✅ 在 Windows 環境安裝與設定 Hugo 開發環境 ✅ 建立並預覽 Hugo 靜態網站 ✅ 選擇與客製化 Hugo 主題 ✅ 使用 GitHub Actions 自動部署網站到 GitHub Pages ✅ 維護與更新網站內容 ✅ (選用)設定自訂網域名稱 1. 前置條件與工具安裝 1.1 環境需求 在開始之前,請確認您的環境符合以下需求: 作業系統: Windows 10 或更新版本 網路連線: 穩定的網際網路連線 磁碟空間: 至少 500MB 可用空間 系統權限: 能夠安裝應用程式的權限 1.2 安裝 Git Git 是版本控制工具,用於管理專案程式碼與部署到 GitHub。 1.2.1 安裝步驟 下載 Git for Windows 前往官方網站: https://git-scm.com/download/win 下載最新版本的 Git for Windows 安裝程式 執行安裝程式 雙擊下載的 .exe 檔案 建議使用預設設定,一路點選「Next」 重要選項: 編輯器選擇:建議選擇 “Use Visual Studio Code as Git’s default editor” PATH 環境變數:選擇 “Git from the command line and also from 3rd-party software” 換行字元轉換:選擇 “Checkout Windows-style, commit Unix-style line endings” 驗證安裝 開啟 PowerShell,執行以下指令: git --version 預期輸出類似: git version 2.43.0.windows.1 設定 Git 使用者資訊 git config --global user.name "您的名字" git config --global user.email "your.email@example.com" 1.2.2 流程圖 graph TD A[下載 Git 安裝程式] --> B[執行安裝程式] B --> C[選擇安裝選項] C --> D[完成安裝] D --> E[開啟 PowerShell] E --> F[驗證 git --version] F --> G{版本顯示正確?} G -->|是| H[設定使用者資訊] G -->|否| I[重新安裝] I --> B H --> J[Git 安裝完成] ⚠️ 注意事項 安裝後需要重新開啟 PowerShell 才能使用 git 指令 使用者名稱與 Email 會顯示在您的 Git 提交記錄中 建議使用與 GitHub 帳號相同的 Email 1.3 安裝 Hugo Hugo 是一個快速的靜態網站產生器,使用 Go 語言開發。 安裝方式(使用 Chocolatey) 方法一:使用 Chocolatey(推薦) 安裝 Chocolatey 套件管理器 以系統管理員權限開啟 PowerShell,執行: Set-ExecutionPolicy Bypass -Scope Process -Force; [System.Net.ServicePointManager]::SecurityProtocol = [System.Net.ServicePointManager]::SecurityProtocol -bor 3072; iex ((New-Object System.Net.WebClient).DownloadString('https://community.chocolatey.org/install.ps1')) 安裝 Hugo Extended 版本 choco install hugo-extended -y 💡 為什麼選擇 Extended 版本? Extended 版本支援 SCSS/SASS 處理,許多現代主題需要此功能。 驗證安裝 關閉並重新開啟 PowerShell(一般權限即可),執行: hugo version 預期輸出類似: hugo v0.121.1-00b46fed8e47f7bb0a85d7cfc2d9f1356379dca7+extended windows/amd64 BuildDate=2023-12-08T08:47:45Z VendorInfo=gohugoio 方法二:手動下載安裝 前往 Hugo GitHub Releases: https://github.com/gohugoio/hugo/releases 下載 hugo_extended_x.xx.x_windows-amd64.zip 解壓縮到 C:\Hugo\bin 將 C:\Hugo\bin 加入系統 PATH 環境變數 1.3.1 設定流程圖 graph LR A[選擇安裝方式] --> B{Chocolatey 或 手動?} B -->|Chocolatey| C[安裝 Chocolatey] B -->|手動| D[下載 Hugo ZIP] C --> E[choco install hugo-extended] D --> F[解壓縮到 C:\Hugo\bin] F --> G[設定 PATH 環境變數] E --> H[驗證: hugo version] G --> H H --> I{安裝成功?} I -->|是| J[完成] I -->|否| K[檢查 PATH 設定] 1.3.2 注意事項 務必安裝 Extended 版本,而非標準版本 手動安裝時,確認 PATH 環境變數設定正確 某些防毒軟體可能會阻擋 Chocolatey 安裝,需暫時停用 1.4 安裝 VS Code Visual Studio Code 是微軟開發的輕量級程式碼編輯器。 1.4.1 安裝步驟 下載 VS Code 前往官方網站: https://code.visualstudio.com/ 點選 “Download for Windows” 執行安裝程式 雙擊下載的 .exe 檔案 建議勾選的選項: ☑️ 將「透過 Code 開啟」加入 Windows 檔案總管目錄內容功能表 ☑️ 將「透過 Code 開啟」加入 Windows 檔案總管檔案內容功能表 ☑️ 將 Code 註冊為支援的檔案類型編輯器 ☑️ 將 Code 加入 PATH 安裝推薦的擴充套件 開啟 VS Code 後,安裝以下擴充套件(Extensions): Hugo Language and Syntax Support (作者: budparr) Markdown All in One (作者: Yu Zhang) Git Graph (作者: mhutchie) 安裝方式:按 Ctrl+Shift+X 開啟擴充套件面板,搜尋並安裝。 1.4.2 注意事項 VS Code 會自動偵測系統已安裝的 Git 建議啟用自動儲存功能:File > Auto Save 1.5 申請 GitHub 帳號 如果您還沒有 GitHub 帳號,請依照以下步驟申請。 申請步驟 前往 GitHub 官網 網址: https://github.com/ 註冊帳號 點選右上角的 “Sign up” 輸入 Email、密碼、使用者名稱 完成驗證(Captcha) 選擇免費方案(Free) 驗證 Email 登入您的 Email 信箱 點選 GitHub 寄送的驗證連結 完成個人資料設定 建議上傳大頭照 填寫簡介(Bio) 1.5.1 注意事項 GitHub 使用者名稱將成為您的網站網址的一部分:https://username.github.io 使用者名稱一旦設定後更改較為繁瑣,請謹慎選擇 建議使用與工作相關的專業名稱 1.6 環境檢查總覽 完成所有安裝後,請執行以下指令檢查環境: # 檢查 Git git --version # 檢查 Hugo hugo version # 檢查 VS Code(開啟 VS Code) code --version 預期輸出範例: PS C:\Users\YourName> git --version git version 2.43.0.windows.1 PS C:\Users\YourName> hugo version hugo v0.121.1-00b46fed8e47f7bb0a85d7cfc2d9f1356379dca7+extended windows/amd64 BuildDate=2023-12-08T08:47:45Z VendorInfo=gohugoio PS C:\Users\YourName> code --version 1.85.0 0ee08df0cf4527e40edc9aa28f4b5bd38bbff2b2 x64 系統架構圖 graph TB subgraph "開發環境" A[Windows 10/11] B[Git] C[Hugo Extended] D[VS Code] end subgraph "雲端服務" E[GitHub Account] F[GitHub Repository] G[GitHub Pages] end A --> B A --> C A --> D B --> F C --> H[本地網站] H --> F F --> G E --> F style A fill:#e1f5ff style E fill:#fff4e1 style G fill:#e8f5e9 2. 建立 Hugo 專案 2.1 建立專案資料夾 首先,選擇一個適當的位置建立您的 Hugo 專案。 操作步驟 開啟 PowerShell 導航到適當的目錄 # 例如:在 D 槽建立專案 cd D:\developer\repos 使用 Hugo 建立新專案 hugo new site my-website 其中 my-website 是您的專案名稱,可自行更改。 進入專案資料夾 cd my-website 預期輸出結果 Congratulations! Your new Hugo site is created in D:\developer\repos\my-website. Just a few more steps and you're ready to go: 1. Download a theme into the same-named folder. Choose a theme from https://themes.gohugo.io/ or create your own with the "hugo new theme <THEMENAME>" command. 2. Perhaps you want to add some content. You can add single files with "hugo new <SECTIONNAME>\<FILENAME>.<FORMAT>". 3. Start the built-in live server via "hugo server". Visit https://gohugo.io/ for quickstart guide and full documentation. 2.2 專案結構說明 Hugo 專案建立後,會產生以下目錄結構: my-website/ ├── archetypes/ # 內容範本 │ └── default.md ├── assets/ # 需要處理的資源(SCSS、JS 等) ├── content/ # 網站內容(Markdown 文件) ├── data/ # 資料檔案(JSON、YAML、TOML) ├── layouts/ # 自訂版面配置 ├── static/ # 靜態檔案(圖片、CSS、JS) ├── themes/ # 主題資料夾 └── hugo.toml # 網站設定檔(或 config.toml) 各目錄功能說明 目錄/檔案 用途 是否必要 archetypes/ 定義新內容的預設前置資料(Front Matter) ⭐⭐⭐ content/ 存放網站的所有內容文章(Markdown) ⭐⭐⭐⭐⭐ data/ 存放結構化資料供模板使用 ⭐⭐ layouts/ 自訂 HTML 模板覆寫主題 ⭐⭐⭐ static/ 直接複製到網站根目錄的靜態檔案 ⭐⭐⭐⭐ themes/ 安裝的主題 ⭐⭐⭐⭐⭐ hugo.toml 網站主要設定檔 ⭐⭐⭐⭐⭐ 2.3 初始化 Git 儲存庫 將專案加入版本控制管理。 # 初始化 Git git init # 建立 .gitignore 檔案 @" # Hugo 產生的檔案 /public/ /resources/_gen/ /.hugo_build.lock # 作業系統檔案 .DS_Store Thumbs.db # 編輯器檔案 .vscode/ .idea/ *.swp *.swo *~ "@ | Out-File -FilePath .gitignore -Encoding utf8 # 加入所有檔案 git add . # 第一次提交 git commit -m "Initial commit: Hugo site created" 2.3.1 流程圖 graph LR A[hugo new site my-website] --> B[建立專案結構] B --> C[cd my-website] C --> D[git init] D --> E[建立 .gitignore] E --> F[git add .] F --> G[git commit] G --> H[專案建立完成] style H fill:#c8e6c9 2.4 設定基本網站資訊 編輯 hugo.toml(或 config.toml)設定檔。 使用 VS Code 開啟專案 code . 編輯 hugo.toml 找到並編輯 hugo.toml 檔案: baseURL = 'https://yourusername.github.io/' languageCode = 'zh-tw' title = '我的個人網站' theme = '' # 稍後設定 [params] description = "這是我的個人網站,分享技術文章與生活點滴" author = "您的名字" [menu] [[menu.main]] name = "首頁" url = "/" weight = 1 [[menu.main]] name = "文章" url = "/posts/" weight = 2 [[menu.main]] name = "關於" url = "/about/" weight = 3 2.4.1 注意事項 baseURL 需要改成您的 GitHub Pages 網址:https://您的GitHub使用者名稱.github.io/ languageCode 設定為 zh-tw 可支援繁體中文 theme 欄位在安裝主題後填入 2.4.2 實務建議 安全性: 不要在設定檔中儲存敏感資訊(API Keys、密碼等) 效能: 保持設定檔簡潔,避免過多不必要的參數 可維護性: 為每個設定項目加上註解說明用途 3. 本機預覽網站 3.1 啟動 Hugo 開發伺服器 Hugo 內建開發伺服器,支援即時預覽(Live Reload)。 啟動指令 hugo server -D 參數說明: server: 啟動開發伺服器 -D: 顯示草稿(Draft)狀態的文章 3.1.1 預期輸出 Start building sites … hugo v0.121.1-00b46fed8e47f7bb0a85d7cfc2d9f1356379dca7+extended windows/amd64 BuildDate=2023-12-08T08:47:45Z VendorInfo=gohugoio | ZH-TW -------------------+-------- Pages | 3 Paginator pages | 0 Non-page files | 0 Static files | 0 Processed images | 0 Aliases | 0 Sitemaps | 1 Cleaned | 0 Built in 45 ms Environment: "development" Serving pages from memory Running in Fast Render Mode. For full rebuilds on change: hugo server --disableFastRender Web Server is available at http://localhost:1313/ (bind address 127.0.0.1) Press Ctrl+C to stop 3.2 在瀏覽器中預覽 開啟瀏覽器 前往 http://localhost:1313/ 您應該會看到一個空白或基本的網站(尚未安裝主題) 常用的開發伺服器參數 # 顯示草稿文章 hugo server -D # 指定埠號 hugo server --port 8080 # 允許外部存取(區域網路) hugo server --bind 0.0.0.0 --baseURL http://你的IP:1313 # 停用 Fast Render(完整重建) hugo server --disableFastRender # 開啟詳細日誌 hugo server --verbose 3.3 建立第一篇文章 使用指令建立文章 hugo new posts/my-first-post.md 這會在 content/posts/ 目錄下建立 my-first-post.md 檔案。 編輯文章內容 使用 VS Code 開啟 content/posts/my-first-post.md: --- title: "我的第一篇文章" date: 2025-10-15T10:00:00+08:00 draft: false tags: ["Hugo", "部落格"] categories: ["教學"] --- ## 歡迎來到我的部落格! 這是我使用 Hugo 建立的第一篇文章。 ### Hugo 的優點 - 🚀 建置速度極快 - 📝 使用 Markdown 撰寫 - 🎨 豐富的主題選擇 - 🔧 高度可客製化 ### 程式碼範例 ```python def hello_hugo(): print("Hello, Hugo!") hello_hugo() 祝大家使用愉快! Front Matter 說明 Front Matter 是文章開頭的 YAML/TOML 區塊,定義文章的詮釋資料: 欄位 說明 範例 title 文章標題 “我的第一篇文章” date 發布日期 2025-10-15T10:00:00+08:00 draft 是否為草稿 true / false tags 標籤 [“Hugo”, “部落格”] categories 分類 [“教學”] author 作者 “Your Name” description 摘要 “本文介紹…” 3.4 即時預覽更新 儲存文章後,Hugo 會自動重建網站,瀏覽器會自動重新整理顯示最新內容。 開發流程圖 sequenceDiagram participant Dev as 開發者 participant VSCode as VS Code participant Hugo as Hugo Server participant Browser as 瀏覽器 Dev->>VSCode: 編輯 .md 檔案 VSCode->>VSCode: 自動儲存 VSCode->>Hugo: 檔案變更通知 Hugo->>Hugo: 重新建置網站 Hugo->>Browser: WebSocket 推送更新 Browser->>Browser: 自動重新整理 Browser-->>Dev: 顯示最新內容 3.5 停止開發伺服器 在 PowerShell 中按下 Ctrl + C 即可停止伺服器。 3.5.1 注意事項 開發伺服器僅供本地開發使用,不適合正式部署 預設僅監聽 localhost,外部無法存取 修改 hugo.toml 後需要重新啟動伺服器 3.5.2 實務建議 開發習慣: 保持開發伺服器運行,善用即時預覽功能 效能: 大型網站可使用 --disableFastRender 確保完整重建 安全性: 不要在開發伺服器上使用正式環境的 API Key 4. 選擇與設定 Hugo Theme 4.1 選擇適合的主題 Hugo 擁有豐富的主題生態系統,您可以從官方主題庫選擇。 主題推薦 主題名稱 特色 適用情境 難度 PaperMod 極簡、快速、SEO 友善 個人部落格 ⭐⭐ Hugo-Theme-Stack 現代化、多功能 技術部落格 ⭐⭐⭐ Ananke 官方推薦、簡潔 初學者 ⭐ LoveIt 功能豐富、中文支援佳 個人網站 ⭐⭐⭐ Academic/Wowchemy 學術型網站 研究人員、教師 ⭐⭐⭐⭐ 瀏覽主題 前往 Hugo 官方主題庫:https://themes.gohugo.io/ 選擇考量因素 mindmap root((Hugo 主題選擇)) 設計風格 極簡主義 多彩豐富 專業商務 個人創意 功能需求 部落格 作品集 文件網站 電商展示 技術要求 是否需要 Extended 版本 相依套件複雜度 客製化難易度 維護狀態 最後更新時間 Star 數量 Issue 處理速度 文件完整性 4.2 安裝主題(以 PaperMod 為例) 方法一:使用 Git Submodule(推薦) 使用 Git Submodule 可以方便地更新主題。 # 確認在專案根目錄 cd D:\developer\repos\my-website # 加入主題作為 Submodule git submodule add --depth=1 https://github.com/adityatelange/hugo-PaperMod.git themes/PaperMod # 更新 Submodule git submodule update --init --recursive 方法二:直接下載主題 # 下載並解壓縮到 themes 資料夾 # 手動從 GitHub 下載 ZIP 並解壓縮到 themes/PaperMod/ 方法三:使用 Hugo Modules(進階) # 初始化 Hugo Module hugo mod init github.com/yourusername/my-website # 在 hugo.toml 中加入 # [module] # [[module.imports]] # path = "github.com/adityatelange/hugo-PaperMod" 安裝流程圖 graph TD A[選擇安裝方式] --> B{Git Submodule?} B -->|是| C[git submodule add] B -->|否| D{Hugo Modules?} D -->|是| E[hugo mod init + 設定] D -->|否| F[手動下載 ZIP] C --> G[更新 hugo.toml] E --> G F --> G G --> H[設定 theme = 'PaperMod'] H --> I[重啟 hugo server] I --> J[檢查網站外觀] style J fill:#c8e6c9 4.3 設定主題 4.3.1 編輯 hugo.toml baseURL = 'https://yourusername.github.io/' languageCode = 'zh-tw' title = '我的技術部落格' theme = 'PaperMod' # 啟用 emoji 支援 enableEmoji = true # 設定摘要長度 summaryLength = 70 # 設定分頁 paginate = 10 [params] # 網站描述 description = "分享程式開發、技術學習與生活心得" # 作者資訊 author = "Your Name" # 顯示閱讀時間 ShowReadingTime = true # 顯示分享按鈕 ShowShareButtons = true # 顯示文章目錄 ShowToc = true TocOpen = false # 顯示程式碼複製按鈕 ShowCodeCopyButtons = true # 首頁資訊 [params.homeInfoParams] Title = "歡迎來到我的部落格 👋" Content = """ 這裡分享我的技術學習筆記、專案經驗與生活點滴。 - 🔧 主要技術: Java, Python, Go - 📚 專注領域: 後端開發、DevOps - 💡 持續學習中... """ # 社群媒體連結 [[params.socialIcons]] name = "github" url = "https://github.com/yourusername" [[params.socialIcons]] name = "linkedin" url = "https://linkedin.com/in/yourprofile" [[params.socialIcons]] name = "email" url = "mailto:your.email@example.com" # 選單設定 [menu] [[menu.main]] identifier = "home" name = "首頁" url = "/" weight = 10 [[menu.main]] identifier = "posts" name = "文章" url = "/posts/" weight = 20 [[menu.main]] identifier = "archives" name = "歸檔" url = "/archives/" weight = 30 [[menu.main]] identifier = "tags" name = "標籤" url = "/tags/" weight = 40 [[menu.main]] identifier = "about" name = "關於" url = "/about/" weight = 50 # 語法高亮設定 [markup] [markup.highlight] style = "monokai" lineNos = true lineNumbersInTable = true noClasses = false 4.4 建立必要頁面 建立關於頁面 hugo new about.md 編輯 content/about.md: --- title: "關於我" date: 2025-10-15 draft: false ShowToc: false --- ## 👨‍💻 自我介紹 哈囉!我是 [Your Name],是一位熱愛技術的軟體工程師。 ### 技能 - **程式語言**: Java, Python, JavaScript - **框架**: Spring Boot, Django, React - **工具**: Git, Docker, Jenkins ### 興趣 - 📖 閱讀技術書籍 - 🏃‍♂️ 慢跑 - 📷 攝影 ### 聯絡方式 - Email: your.email@example.com - GitHub: [@yourusername](https://github.com/yourusername) 建立歸檔頁面 hugo new archives.md 編輯 content/archives.md: --- title: "文章歸檔" layout: "archives" url: "/archives/" summary: archives --- 4.5 客製化主題樣式(選用) 覆寫 CSS 建立 assets/css/extended/custom.css: /* 自訂顏色 */ :root { --primary: #1e88e5; --secondary: #424242; } /* 自訂標題樣式 */ .post-title { font-size: 2rem; font-weight: 700; } /* 自訂程式碼區塊 */ .highlight { border-radius: 8px; padding: 1rem; } /* 響應式調整 */ @media (max-width: 768px) { .post-title { font-size: 1.5rem; } } 覆寫部分模板 如需客製化 HTML 結構,可在 layouts/ 資料夾中覆寫主題檔案: layouts/ ├── _default/ │ └── single.html # 覆寫單篇文章版面 ├── partials/ │ └── footer.html # 覆寫頁尾 └── shortcodes/ └── youtube.html # 自訂 shortcode 4.6 驗證主題設定 重啟開發伺服器 # 停止目前的 server (Ctrl+C) # 重新啟動 hugo server -D 檢查項目 ✅ 網站外觀符合主題風格 ✅ 選單項目正確顯示 ✅ 社群媒體圖示正常 ✅ 文章列表正確顯示 ✅ 語法高亮運作正常 ✅ 響應式設計在手機上正常 主題設定流程總覽 graph TB A[瀏覽主題庫] --> B[選擇適合主題] B --> C[使用 Git Submodule 安裝] C --> D[編輯 hugo.toml 設定] D --> E[建立必要頁面] E --> F{需要客製化?} F -->|是| G[建立自訂 CSS/Template] F -->|否| H[完成主題設定] G --> H H --> I[重啟 hugo server 驗證] style H fill:#c8e6c9 4.6.1 注意事項 不同主題的設定參數可能不同,請參考主題的官方文件 使用 Git Submodule 時,更新主題需使用 git submodule update --remote 客製化前建議先備份原始主題檔案 過度客製化可能導致主題更新困難 4.6.2 實務建議 選擇策略: 優先選擇維護活躍、文件完整的主題 效能考量: 避免選擇過於臃腫、載入緩慢的主題 SEO 優化: 確認主題支援 Open Graph、Twitter Cards 等 meta 標籤 可維護性: 使用覆寫(override)方式客製化,而非直接修改主題檔案 5. 部署到 GitHub Pages 5.1 建立 GitHub Repository 步驟說明 登入 GitHub 前往 https://github.com 並登入 建立新的 Repository 點選右上角的 + 號 選擇 “New repository” Repository 設定 Repository name: yourusername.github.io ⚠️ 必須使用 使用者名稱.github.io 格式 Description: “My personal website built with Hugo” Public: 選擇 Public(免費用戶只能使用 Public repo 的 GitHub Pages) 不要勾選: Initialize this repository with a README 建立 Repository 點選 “Create repository” Repository 命名規則 graph LR A[GitHub 使用者名稱] --> B[yourusername] B --> C[Repository 名稱] C --> D[yourusername.github.io] D --> E[網站網址] E --> F[https://yourusername.github.io] style F fill:#e1f5ff 5.2 連結本地專案與遠端 Repository 在專案目錄中執行以下指令: # 設定遠端 Repository git remote add origin https://github.com/yourusername/yourusername.github.io.git # 檢查遠端設定 git remote -v # 建立主分支(如果尚未建立) git branch -M main # 第一次推送 git push -u origin main 5.2.1 預期輸出 Enumerating objects: 15, done. Counting objects: 100% (15/15), done. Delta compression using up to 8 threads Compressing objects: 100% (10/10), done. Writing objects: 100% (15/15), 2.50 KiB | 2.50 MiB/s, done. Total 15 (delta 0), reused 0 (delta 0), pack-reused 0 To https://github.com/yourusername/yourusername.github.io.git * [new branch] main -> main Branch 'main' set up to track remote branch 'main' from 'origin'. 5.3 設定 GitHub Actions 自動部署 GitHub Actions 可以自動建置並部署 Hugo 網站。 建立 Workflow 檔案 建立 .github/workflows/hugo.yml 檔案: # 建立目錄 New-Item -ItemType Directory -Force -Path .github\workflows # 建立 workflow 檔案 New-Item -ItemType File -Path .github\workflows\hugo.yml 編輯 hugo.yml 使用 VS Code 開啟 .github/workflows/hugo.yml 並貼上以下內容: name: Deploy Hugo site to Pages on: # 當推送到 main 分支時觸發 push: branches: - main # 允許手動觸發 workflow_dispatch: # 設定 GitHub Pages 的權限 permissions: contents: read pages: write id-token: write # 避免同時執行多個部署 concurrency: group: "pages" cancel-in-progress: false # 預設使用 bash defaults: run: shell: bash jobs: # 建置工作 build: runs-on: ubuntu-latest env: HUGO_VERSION: 0.121.1 steps: - name: Install Hugo CLI run: | wget -O ${{ runner.temp }}/hugo.deb https://github.com/gohugoio/hugo/releases/download/v${HUGO_VERSION}/hugo_extended_${HUGO_VERSION}_linux-amd64.deb \ && sudo dpkg -i ${{ runner.temp }}/hugo.deb - name: Install Dart Sass run: sudo snap install dart-sass - name: Checkout uses: actions/checkout@v4 with: submodules: recursive fetch-depth: 0 - name: Setup Pages id: pages uses: actions/configure-pages@v4 - name: Install Node.js dependencies run: "[[ -f package-lock.json || -f npm-shrinkwrap.json ]] && npm ci || true" - name: Build with Hugo env: # For maximum backward compatibility with Hugo modules HUGO_ENVIRONMENT: production HUGO_ENV: production run: | hugo \ --gc \ --minify \ --baseURL "${{ steps.pages.outputs.base_url }}/" - name: Upload artifact uses: actions/upload-pages-artifact@v2 with: path: ./public # 部署工作 deploy: environment: name: github-pages url: ${{ steps.deployment.outputs.page_url }} runs-on: ubuntu-latest needs: build steps: - name: Deploy to GitHub Pages id: deployment uses: actions/deploy-pages@v3 Workflow 檔案說明 區段 說明 on.push.branches 觸發條件:推送到 main 分支 permissions 授予 workflow 必要的權限 jobs.build 建置工作:安裝 Hugo、建置網站 jobs.deploy 部署工作:將產生的檔案部署到 GitHub Pages HUGO_VERSION 指定 Hugo 版本(建議與本地相同) 5.4 設定 GitHub Pages 在 GitHub 網站上設定 前往您的 Repository 頁面 點選 Settings 在左側選單選擇 Pages 在 “Build and deployment” 區段: Source: 選擇 “GitHub Actions” 儲存設定 5.4.1 設定流程圖 graph TD A[進入 Repository Settings] --> B[選擇 Pages] B --> C[Source 選擇 GitHub Actions] C --> D[儲存設定] D --> E[等待 Workflow 執行] E --> F{部署成功?} F -->|是| G[訪問 username.github.io] F -->|否| H[檢查 Actions 錯誤訊息] H --> I[修正問題] I --> J[重新推送] J --> E style G fill:#c8e6c9 5.5 推送並觸發部署 # 加入 GitHub Actions workflow git add .github/workflows/hugo.yml # 提交變更 git commit -m "Add GitHub Actions workflow for Hugo deployment" # 推送到 GitHub git push origin main 5.6 監控部署狀態 查看 Actions 執行狀態 前往 Repository 頁面 點選 Actions 標籤 查看最新的 workflow 執行狀態 部署成功標誌 ✅ build 工作完成 ✅ deploy 工作完成 ✅ 顯示綠色勾勾 訪問您的網站 部署成功後,前往 https://yourusername.github.io/ 查看您的網站! 5.7 部署流程完整視圖 sequenceDiagram participant Dev as 開發者 participant Local as 本地 Git participant GitHub as GitHub Repo participant Actions as GitHub Actions participant Pages as GitHub Pages participant User as 訪客 Dev->>Local: git commit & push Local->>GitHub: 推送程式碼 GitHub->>Actions: 觸發 Workflow Actions->>Actions: 安裝 Hugo Actions->>Actions: 建置網站 (hugo build) Actions->>Actions: 產生 public/ 目錄 Actions->>Pages: 部署靜態檔案 Pages->>Pages: 網站上線 User->>Pages: 訪問網站 Pages->>User: 回傳網頁內容 5.8 常見部署問題與解決方案 問題 1: Workflow 執行失敗 原因: Hugo 版本不匹配或主題問題 解決方案: # 檢查本地 Hugo 版本 hugo version # 在 hugo.yml 中設定相同版本 env: HUGO_VERSION: 0.121.1 # 與本地版本一致 問題 2: 主題無法載入 原因: Git Submodule 未正確同步 解決方案: # 在 Checkout 步驟中確保包含 - name: Checkout uses: actions/checkout@v4 with: submodules: recursive # 重要! fetch-depth: 0 問題 3: baseURL 設定錯誤 原因: hugo.toml 中的 baseURL 不正確 解決方案: # hugo.toml baseURL = 'https://yourusername.github.io/' # 結尾要有斜線 問題 4: CSS/JS 無法載入 原因: 相對路徑問題 解決方案: # 在 Build with Hugo 步驟中使用正確的 baseURL run: | hugo \ --gc \ --minify \ --baseURL "${{ steps.pages.outputs.base_url }}/" 5.9 效能優化建議 啟用快取 在 workflow 中加入快取步驟: - name: Cache Hugo resources uses: actions/cache@v3 with: path: resources key: ${{ runner.os }}-hugo-resources-${{ hashFiles('content/**') }} 圖片優化 # 使用 Hugo 的圖片處理功能 # 在文章中使用 Hugo 的 image processing 在 Markdown 中: 啟用 CDN(選用) 考慮使用 Cloudflare Pages 或其他 CDN 服務提升全球存取速度。 5.7.1 注意事項 GitHub Pages 有 1GB 儲存空間限制 每月頻寬限制 100GB 部署次數建議不要過於頻繁(每小時不超過 10 次) 私有 Repository 需要 GitHub Pro 方案才能使用 Pages 5.7.2 實務建議 安全性: 不要在 Repository 中儲存敏感資訊(API Keys、密碼) 效能: 使用圖片壓縮工具減少檔案大小 SEO: 確保 sitemap.xml 和 robots.txt 正確設定 可維護性: 定期更新 Hugo 版本和主題 6. 維護與更新內容的流程 6.1 日常更新工作流程 建立文章並部署的標準流程如下: 標準工作流程 graph TD A[開啟 VS Code] --> B[啟動 hugo server -D] B --> C[建立新文章] C --> D[撰寫內容] D --> E[本機預覽] E --> F{內容滿意?} F -->|否| D F -->|是| G[設定 draft: false] G --> H[git add .] H --> I[git commit -m 訊息] I --> J[git push origin main] J --> K[GitHub Actions 自動部署] K --> L[網站更新完成] style L fill:#c8e6c9 詳細步驟 步驟 1: 建立新文章 # 建立新文章 hugo new posts/2025/my-new-post.md # 或使用日期目錄結構 hugo new posts/2025-10-15-my-new-post.md 步驟 2: 編輯文章內容 --- title: "深入理解 Java Stream API" date: 2025-10-15T14:30:00+08:00 draft: false tags: ["Java", "Stream API", "函數式編程"] categories: ["程式設計"] author: "Your Name" description: "本文詳細介紹 Java 8 引入的 Stream API,包含常用操作與最佳實踐" cover: image: "images/java-stream.png" alt: "Java Stream API" caption: "Stream API 讓集合操作更優雅" --- ## 前言 Java 8 引入的 Stream API 徹底改變了集合處理的方式... ## 基本概念 Stream 是一個資料序列,支援各種操作來處理資料... ### 建立 Stream \`\`\`java // 從集合建立 List<String> list = Arrays.asList("a", "b", "c"); Stream<String> stream = list.stream(); // 從陣列建立 String[] array = {"a", "b", "c"}; Stream<String> stream2 = Arrays.stream(array); \`\`\` ## 常用操作 ### Filter(過濾) \`\`\`java list.stream() .filter(s -> s.startsWith("a")) .collect(Collectors.toList()); \`\`\` ## 總結 Stream API 提供了簡潔且高效的集合處理方式... 步驟 3: 本機預覽 # 如果 server 未啟動,執行 hugo server -D # 在瀏覽器開啟 http://localhost:1313/ 步驟 4: 提交並部署 # 檢查變更 git status # 加入所有變更 git add . # 提交(使用有意義的訊息) git commit -m "新增文章: 深入理解 Java Stream API" # 推送到 GitHub git push origin main 步驟 5: 等待部署完成 前往 GitHub Repository 的 Actions 頁面 確認 workflow 執行成功 訪問網站確認更新 6.2 Git 提交訊息最佳實踐 提交訊息格式 <類型>: <簡短描述> <詳細描述(選用)> <相關 Issue(選用)> 常用類型 類型 說明 範例 feat 新功能 feat: 新增留言功能 post 新文章 post: 新增 Java Stream API 教學 fix 修正錯誤 fix: 修正文章日期顯示問題 style 樣式調整 style: 更新首頁配色 docs 文件更新 docs: 更新 README refactor 重構 refactor: 重新組織文章分類 config 設定變更 config: 更新 hugo.toml 設定 範例 # 好的提交訊息 git commit -m "post: 新增 Docker 容器化部署教學" git commit -m "fix: 修正文章中程式碼區塊的語法高亮" git commit -m "style: 調整文章標題字體大小" # 不好的提交訊息(避免) git commit -m "update" git commit -m "fix bug" git commit -m "change" 6.3 管理草稿文章 草稿工作流程 stateDiagram-v2 [*] --> 草稿: hugo new post.md 草稿 --> 預覽: hugo server -D 預覽 --> 草稿: 繼續編輯 預覽 --> 發布: draft: false 發布 --> 線上: git push 線上 --> [*] 草稿文章不會被部署 --- title: "我的草稿文章" date: 2025-10-15 draft: true # 設為 true,不會出現在正式網站 --- 本機預覽草稿 # 包含草稿的預覽 hugo server -D # 不包含草稿的預覽(模擬正式環境) hugo server 將草稿變為正式文章 只需將 draft: true 改為 draft: false: ...

October 31, 2025 · 21 min · 4413 words · Eric Cheng