如何在 Vercel 中託管 Hugo
我決定和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中文網其他相關文章!

熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

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

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

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

Dreamweaver CS6
視覺化網頁開發工具

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

Golang在性能和可擴展性方面優於Python。 1)Golang的編譯型特性和高效並發模型使其在高並發場景下表現出色。 2)Python作為解釋型語言,執行速度較慢,但通過工具如Cython可優化性能。

Golang在並發性上優於C ,而C 在原始速度上優於Golang。 1)Golang通過goroutine和channel實現高效並發,適合處理大量並發任務。 2)C 通過編譯器優化和標準庫,提供接近硬件的高性能,適合需要極致優化的應用。

goisidealforbeginnersandsubableforforcloudnetworkservicesduetoitssimplicity,效率和concurrencyFeatures.1)installgromtheofficialwebsitealwebsiteandverifywith'.2)

Golang適合快速開發和並發場景,C 適用於需要極致性能和低級控制的場景。 1)Golang通過垃圾回收和並發機制提升性能,適合高並發Web服務開發。 2)C 通過手動內存管理和編譯器優化達到極致性能,適用於嵌入式系統開發。

goimpactsdevelopmentpositationality throughspeed,效率和模擬性。 1)速度:gocompilesquicklyandrunseff,IdealforlargeProjects.2)效率:效率:ITScomprehenSevestAndardArdardArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdArdEcceSteral Depentencies,增強的Depleflovelmentimency.3)簡單性。

Golang和Python各有优势:Golang适合高性能和并发编程,Python适用于数据科学和Web开发。Golang以其并发模型和高效性能著称,Python则以简洁语法和丰富库生态系统著称。

Golang和C 在性能上的差異主要體現在內存管理、編譯優化和運行時效率等方面。 1)Golang的垃圾回收機制方便但可能影響性能,2)C 的手動內存管理和編譯器優化在遞歸計算中表現更為高效。

Golang和C 在性能競賽中的表現各有優勢:1)Golang適合高並發和快速開發,2)C 提供更高性能和細粒度控制。選擇應基於項目需求和團隊技術棧。
