我決定和Hugo一起建立我的個人網站。我的選擇唯一基於的是建置時間。我認為 Hugo 在內容管理方面與 Astro 處於同一水平,但目前還沒有達到這個水平。或者,我可以說它有自己的路徑,因為它比我遇到的大多數其他靜態網站產生器都要舊。此外,它是一個 Go 應用程序,這是評估技術選擇時要考慮的另一個重要因素。
可以加什麼!
是的,可以擴充Hugo的功能。您可以透過修改建置過程的模組來添加缺少的功能。例如,我缺少 Hugo 中的 MDX 支援。我可以透過在建置時渲染 MDX 的模組來解決這個問題。我自己沒有嘗試過,但似乎是可能的。
我還可以添加一個並行構建管道——如果我們可以這樣稱呼它的話。這可能涉及使用 Vite、Turbo 或 Webpack 等工具。然而,這種方法可能會使建構過程複雜化,並可能減慢 Hugo 的主要建構機制。這些整合已用於合併 Tailwind 和其他前端庫。有趣的是,如果您查看 Hugo 即將推出的功能,您會看到整合 Tailwind 和其他技術的計劃。
基於 Vercel 構建
我使用了一些第三方 Hugo 工具,特別是 HugoMods。圖標模組引起了我的注意,因為我想在我的網站上添加圖標而不導入整個字體。搜尋時,首先出現的是圖示模組。它提供了各種圖標供應商,包括 Bootstrap、Font Awesome、Feather 圖標等等。
在當地,一切都很順利。然而,在推動我的改變之後,似乎沒有任何改變。在檢查 Vercel 中的建置頁面後,我注意到...
[12:10:48.021] Running build in Washington, D.C., USA (East) – iad1 [12:10:48.210] Cloning github.com/mohessaid/mohessaid (Branch: main, Commit: eaeecd1) [12:10:48.449] Cloning completed: 238.727ms [12:10:49.038] Restored build cache from previous deployment (5i5sCdjnY3KZXgGBqbqfgJUjrwYB) [12:10:49.132] Running "vercel build" [12:10:49.714] Vercel CLI 39.0.2 [12:10:50.440] Total in 3 ms [12:10:50.441] Error: failed to load modules: failed to download modules: binary with name "go" not found in PATH [12:10:50.446] Error: Command "hugo --gc" exited with 1 [12:10:50.625]
當 Hugo 嘗試安裝建置所需的模組時,它找不到 Go 二進位。我向Claude和GPT尋求協助,希望能快速解決問題,但他們無法提供直接協助。我必須引導他們完成每一步,最終,我對他們幫助我的能力失去了希望。
如果不是因為 Vercel 輸入欄位的限制,我甚至使用 Claude 來實現幾乎成功的解決方案。
什麼有效?
我在 Vercel 儀表板中導航至我的網站的設定頁面。在「環境變數」標籤中,我新增了一個名為「HUGO_VERSION」的變量,並將其值設定為最新可用的 Hugo 版本。
在「常規」標籤中,選擇 Hugo 作為框架預設。然後使用以下內容覆蓋建置命令:
curl -L https://go.dev/dl/go1.22.2.linux-amd64.tar.gz -o go1.22.2.linux-amd64.tar.gz && tar -C /usr/local -xzf go1.22.2.linux-amd64.tar.gz && export PATH=$PATH:/usr/local/go/bin && go env GOTPATH && hugo --gc --minify
注意:我使用的是 Go 版本 1.22.2,這是撰寫本文時的最新版本。您可以修改版本以滿足您的特定要求。
為什麼要建置命令?
我理解你的懷疑。和你一樣,我認為我有一個聰明的解決方案。最初,我嘗試在 Install Command 欄位中安裝 Go,但慘敗。儘管我進行了詳盡的故障排除,但 Vercel 的建置過程仍無法找到二進位檔案。
在探索了無數潛在的解決方案但沒有成功之後,我偶然發現了一個 GitHub 問題,其中有人將整個安裝過程直接放在建置欄位中。照著他們的方法,我終於獲得了成功。至此,解決方案就說明了一切。
嘗試將這些步驟放入安裝命令欄位中可能會導致錯誤。
或這個
安裝 Amazon Linux Extras 並不能解決 Go 安裝難題。透過此方法可用的 Go 版本明顯過時。我徹底測試了這種方法並遇到了一致的失敗。我嘗試在安裝命令中同時使用 yum 和 dnf 套件管理器,但這兩種方法都未能成功解決 Go 二進位問題。
最後,我在不同的平台上分享了這篇文章,以測試哪個平台在搜尋結果中排名第一。幾個月前我就願意這麼做。但是,我找不到合適的貼文。您可以從這裡開始進行實驗。
以上是如何在 Vercel 中託管 Hugo的詳細內容。更多資訊請關注PHP中文網其他相關文章!

Go的"strings"包提供了豐富的功能,使字符串操作高效且簡單。 1)使用strings.Contains()檢查子串。 2)strings.Split()可用於解析數據,但需謹慎使用以避免性能問題。 3)strings.Join()適用於格式化字符串,但對小數據集,循環使用 =更有效。 4)對於大字符串,使用strings.Builder構建字符串更高效。

Go語言使用"strings"包進行字符串操作。 1)拼接字符串使用strings.Join函數。 2)查找子串使用strings.Contains函數。 3)替換字符串使用strings.Replace函數,這些函數高效且易用,適用於各種字符串處理任務。

資助bytespackageingoisesential foreffited byteSemanipulation,uperingFunctionsLikeContains,index,andReplaceForsearchingangingAndModifyingBinaryData.itenHancesperformanceNandCoderAceAnibility,MakeitiTavitalToolToolToolToolToolToolToolToolToolForhandLingBinaryData,networkProtocols,networkProtocoLss,networkProtocols,andetFilei

Go語言使用"encoding/binary"包進行二進制編碼與解碼。 1)該包提供binary.Write和binary.Read函數,用於數據的寫入和讀取。 2)需要注意選擇正確的字節序(如BigEndian或LittleEndian)。 3)數據對齊和錯誤處理也是關鍵,確保數據的正確性和性能。

1)usebybytes.joinforconcatenatinges,2)bytes.bufferforincrementalwriting,3)bytes.indexorbytes.indexorbytes.indexbyteforsearching bytes.bytes.readereforrednorederencretingnchunknunknchunknunk.sss.inc.softes.4)

theencoding/binarypackageingoiseforporptimizingBinaryBinaryOperationsDuetoitssupportforendiannessessandefficityDatahandling.toenhancePerformance:1)usebinary.nativeendiandiandiandiandiandiandiandian nessideendian toavoid avoidByteByteswapping.2)

Go的bytes包主要用於高效處理字節切片。 1)使用bytes.Buffer可以高效進行字符串拼接,避免不必要的內存分配。 2)bytes.Equal函數用於快速比較字節切片。 3)bytes.Index、bytes.Split和bytes.ReplaceAll函數可用於搜索和操作字節切片,但需注意性能問題。

字節包提供了多種功能來高效處理字節切片。 1)使用bytes.Contains檢查字節序列。 2)用bytes.Split分割字節切片。 3)通過bytes.Replace替換字節序列。 4)用bytes.Join連接多個字節切片。 5)利用bytes.Buffer構建數據。 6)結合bytes.Map進行錯誤處理和數據驗證。


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

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

熱門文章

熱工具

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器

Dreamweaver Mac版
視覺化網頁開發工具

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具