」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 前端架構:如何免費託管您的 Web 應用程式

前端架構:如何免費託管您的 Web 應用程式

發佈於2024-11-04
瀏覽:648

我正在進行一個個人項目,旨在幫助用戶尋找芝加哥音樂會。從架構角度來看,該專案的一個值得注意的方面是整個 Web 應用程式完全免費託管。

下圖說明了架構組件:

Front-End Architecture: How to Host Your Web App for Free

免責聲明:我沒有受到我在這裡提到的任何服務的贊助;我強調它們只是因為我發現它們很有用。

專案程式碼庫

GitHub 是最受歡迎的免費託管程式碼庫的平台。我還嘗試過 Bitbucket 和 GitLab 等替代方案,它們也同樣有效。老實說,這些選項中的任何一個都可以完成工作 - 只需選擇一個並繼續前進,無需過度思考。

前端工作流程編排

在專業環境中,您通常會直接與 AWS 或其他雲端服務供應商合作,讓您能夠完全控制部署、通知和監控。然而,這種方法需要更多的時間和精力。幸運的是,Netlify 和 Vercel 等服務消除了許多麻煩,簡化了這個過程。它們允許快速部署,但依賴其生態系統。一旦您的網站開始接收大量流量(數千次造訪),最好檢查免費套餐限制以避免意外費用。對於個人項目,我已經多次使用這些服務,到目前為止沒有任何問題。

也就是說,Netlify 提供了一些開箱即用的功能。在架構圖中,Netlify 自動提供了三個元件:

  • GUI 整合

Netlify 的 GUI 讓您可以整合程式碼庫儲存庫 - 在我的例子中是 GitHub。 Netlify 了解 Next.js 應用程式的預設設定並使用它們無縫部署程式碼。

  • 靜態網站託管

chicagomusiccompass.com 是靜態 Web 應用程序,這意味著不涉及伺服器。觸發部署時,應用程式會產生儲存在 S3 儲存桶中的靜態資產(HTML、JS 和 CSS)。然後,Netlify 使用 CloudFront 處理配置,為您提供現成的 URL。

  • Lambda 函數

靜態網站通常需要從其他網域取得資料。這通常需要一個代理,稱為「前端的後端」(BFF)。預設情況下,客戶端應用程式無法存取其他網域,除非伺服器透過 CORS 明確允許,但這並不總是常見的做法。對於這個項目,我使用代理從不同的網域中提取 JSON 檔案

Netlify 管理所有部署編排並提供一個 URL(子網域),您可以將其連結到您的網域以獲得使用者友好的 URL。

例如,這是我的專案的Netlify URL

https://clinquant-chebakia-f64a5b.netlify.app/

然後,我使用 CNAME 記錄設定我的網域,將 www 指向 Netlify URL:

Front-End Architecture: How to Host Your Web App for Free

當使用者造訪 https://www.chicagomusiccompass.com/ 時,DNS 會將網域解析為其最終目的地 - Netlify URL ?.

雖然這裡發生了很多事情,但其中大部分都是透過儀表板(GUI)進行配置的。關鍵是要理解一切是如何連結在一起的;剩下的只是瀏覽使用者介面。

自動排程任務(Cron 作業)

cron-job.org 是一項允許您免費執行 cron 作業的服務。以下是它在此設置中的工作原理:

a) Netlify 部署掛鉤:
Netlify 提供了一個可設定的 Webhook(URL 端點),觸發後會重新部署網站。這確保了 chiagomusiccompass.com 可以在需要時自動更新。

Front-End Architecture: How to Host Your Web App for Free

b) cron-job.org 整合:
透過 cron-job.org,您可以安排一個 cron 作業——在本例中,設定為每天運行。這份作業只是觸發 Netlify 部署掛鉤,提示 Netlify 每天重新部署(更新)網站。

Front-End Architecture: How to Host Your Web App for Free
注意:雖然chicagomusiccompass.com也有後端元件,但本文只關注前端架構。

概括

chicagomusiccompass.com 是一個 Next.js 應用程序,建置後會產生一個靜態網站(無伺服器)以及幾個 Lambda 函數。 GitHub 儲存庫與 Netlify 集成,因此每次推送到儲存庫都會觸發新的部署。此過程會產生新版本的靜態網站並更新 Lambda 函數。 Netlify 處理這些文件的部署並自動配置必要的網路基礎設施,允許透過子網域存取 Web 應用程式。此外,我還配置了自訂網域chicagomusiccompass.com,以指向Netlify。該網站透過觸發 Netlify 部署掛鉤的每日 cron 作業來保持最新狀態。

該網站已經運行了幾個月,目前沒有獲得太多流量,但就基礎設施成本而言,我沒有支付一分錢。

在專業環境中,根據專案要求,我可能會選擇類似的解決方案,尤其是在早期階段。後來,隨著業務的成長和需求的發展,我可以遷移某些元件。

如今,前端架構變得非常令人興奮,尤其是當您可以利用免費服務時。但是,請記住,如果一項服務是免費的,那麼您可能就是產品

版本聲明 本文轉載於:https://dev.to/garciadiazjaime/front-end-architecture-how-to-host-your-web-app-for-free-29ke?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • 我們如何計算 JavaScript 物件的大致記憶體佔用量?
    我們如何計算 JavaScript 物件的大致記憶體佔用量?
    確定 JavaScript 物件的記憶體佔用在 JavaScript 中,了解物件的記憶體消耗對於優化效能和避免記憶體洩漏至關重要。本文解決了獲取 JavaScript 物件大小的查詢,深入研究了估計此類物件所佔用的大致記憶體的解決方案。 確定物件大小In JavaScript 中沒有專門設計的內建...
    程式設計 發佈於2024-11-16
  • 從本地主機到生產:OneBootcamp 的問題優先 SRE 之旅
    從本地主機到生產:OneBootcamp 的問題優先 SRE 之旅
    我在X(以前的Twitter)上遇到了One2N 舉辦的一個問題優先的SRE 訓練營(在這裡你可以構建一個應用程序,並將其從本地主機擴展到生產環境),我想,「哎呀是啊!我會嘗試一下。」這篇部落格文章開啟了我的旅程,我將記錄我在訓練營中處理每項練習的經驗。 這篇介紹文章將連結到其他條目,詳細介紹我對...
    程式設計 發佈於2024-11-16
  • 大批
    大批
    方法是可以在物件上呼叫的 fns 數組是對象,因此它們在 JS 中也有方法。 slice(begin):將陣列的一部分提取到新數組中,而不改變原始數組。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index ...
    程式設計 發佈於2024-11-16
  • Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta:列偏移的刪除和恢復Bootstrap 4 在其Beta 1 版本中引入了重大更改柱子偏移了。然而,隨著 Beta 2 的後續發布,這些變化已經逆轉。 從 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    程式設計 發佈於2024-11-16
  • 如何在Python中遞歸搜尋子資料夾並檢索檔案?
    如何在Python中遞歸搜尋子資料夾並檢索檔案?
    遞歸子資料夾搜尋與檔案擷取在程式設計領域,遍歷目錄和擷取檔案可能是一項常見任務。一種有效的方法是採用遞歸演算法搜尋子資料夾並累積滿足特定條件的檔案清單。 遇到的問題使用者遇到了障礙嘗試在遞歸子資料夾搜尋中建立特定檔案的清單時。該問題源於子資料夾變數拉入子資料夾清單而不是包含該檔案的目前資料夾。 子資...
    程式設計 發佈於2024-11-16
  • 如何使用 CSS 建立倒數計時器
    如何使用 CSS 建立倒數計時器
    Written by Carlos Mucuho✏️ Countdown timers are a popular feature on many websites, enhancing functionality for events, sales, and user engagement. Wh...
    程式設計 發佈於2024-11-16
  • ## 像素完美縮小可以在瀏覽器大小調整期間保存影像品質嗎?
    ## 像素完美縮小可以在瀏覽器大小調整期間保存影像品質嗎?
    透過縮小尺寸重新取樣會降低影像品質? 此處的目標是縮小影像的大小,同時在瀏覽器環境中保持其品質。使用 HTML5 畫布縮小影像時會出現此問題,導致影像品質下降。 縮小尺寸與插值縮小尺寸和插值是不同的技術。縮小是指透過組合來源影像中的像素以在目標影像中建立較少的像素來減小影像尺寸,而插值是指在放大時在...
    程式設計 發佈於2024-11-16
  • Python 3.x 的 super() 函數在沒有參數的情況下如何運作,有哪些潛在的陷阱以及如何避免它們?
    Python 3.x 的 super() 函數在沒有參數的情況下如何運作,有哪些潛在的陷阱以及如何避免它們?
    揭開Python 3.x神奇Super()的秘密Python 3.x引入了super()函數的一個特殊方面:可以在沒有參數的情況下呼叫它。這種看似平凡的行為隱藏了編譯時魔法和執行時間支援的強大組合,提供了巨大的靈活性和效率。 隱藏的編譯時魔法透過無參數的 super() 調用,Python 編譯器在...
    程式設計 發佈於2024-11-16
  • PHP如何將變數轉換為字串?
    PHP如何將變數轉換為字串?
    PHP中的字串轉換Java和.NET程式設計師可能習慣toString()方法,它提供了一種便捷的轉換方式任何物件到字串表示形式。 PHP 透過轉換運算子提供類似的功能。 PHP 的轉換運算子要將 PHP 變數轉換為字串,可以使用 (string) 轉換運算子。此語法允許您將任何類型的變數明確轉換為...
    程式設計 發佈於2024-11-16
  • 如何修復「無法將 MySQL 日期/時間值轉換為 System.DateTime」錯誤?
    如何修復「無法將 MySQL 日期/時間值轉換為 System.DateTime」錯誤?
    了解「無法將MySQL 日期/時間值轉換為System.DateTime」錯誤從MySQL 資料庫檢索資料有時會導致錯誤「無法將MySQL 日期/時間值轉換為System.DateTime」。當從資料庫檢索的資料的 DbType 與 .NET 資料類型的對應屬性不相容時,就會發生這種情況。 修正轉換...
    程式設計 發佈於2024-11-16
  • 如何使用 PDO 準備語句將多行插入資料庫?
    如何使用 PDO 準備語句將多行插入資料庫?
    使用PDO 準備好的語句插入多行使用單一準備好的語句將多行插入資料庫不僅是可能的,而且推薦用於使用單一插入查詢的方法第一種方法涉及使用具有多個值的單一INSERT 查詢:INSERT INTO Table (col1, col2, col3) VALUES ('abc', 'def', 'ghi'...
    程式設計 發佈於2024-11-16
  • Java中如何計算兩個日期之間的天數?
    Java中如何計算兩個日期之間的天數?
    在Java 中計算兩個日期之間的天數在Java 程式語言中,計算兩個日期之間的天數可以很簡單任務。但是,當日期儲存為字串時,需要仔細轉換才能準確處理它們。 將字串日期轉換為日期物件要有效地處理日期,您可以將它們從字串轉換為 Date 或 LocalDate 類型。 Java 提供了各種類別和方法來促...
    程式設計 發佈於2024-11-16
  • 如何使用“...”標記在 C++ 可變參數模板中打包和解包參數?
    如何使用“...”標記在 C++ 可變參數模板中打包和解包參數?
    可變參數範本中「...」標記的語法規則在C 中,可變參數範本可以建構接受參數數量可變。 「...」標記在此上下文中起著至關重要的作用,充當參數包或參數解包器。 省略號放置的語法規則The “...”標記的位置決定了其功能:Pack : 當它出現在名稱的左邊時,「...」表示參數套件: ...thin...
    程式設計 發佈於2024-11-16
  • 如何有效地從 JavaScript 中的另一個陣列中存在的陣列中刪除元素?
    如何有效地從 JavaScript 中的另一個陣列中存在的陣列中刪除元素?
    高效刪除與另一個陣列相符的陣列元素在JavaScript 中,可能需要刪除一個陣列中存在於另一個陣列中的元素。這可以有效地實現,而無需借助循環和拼接。 jQuery 方法使用jQuery,可以利用grep() 和inArray() 函數:myArray = $.grep(myArray, funct...
    程式設計 發佈於2024-11-16
  • 很棒的免費 Tailwind 登陸頁面模板
    很棒的免費 Tailwind 登陸頁面模板
    幾個月前,我開源了一個 tailwind 登陸頁面模板列表,從那時起它就變得越來越流行,所以這裡是存儲庫中的一些頂級 tailwind 登陸頁面。 你在 Github 上查看它們並複製資料夾 從Github獲取⭐️ 或您也可以從網頁目錄下載 從網路下載 1.Pixa AI - Pi...
    程式設計 發佈於2024-11-16

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3