搜尋
首頁web前端js教程在 AWS Elastic Beanstalk 上部署 Next.js 的完整指南:使用 Docker、AWS CodePipeline 和 CodeBuild

介紹

透過 AWS Code Build、Code Deploy 和 GitLab 利用 AWS (Amazon Web Services) Elastic Beanstalk、Docker 和 CI/CD 管道,可以簡化且有效率地將 Next.js Web 應用程式部署到生產環境。本指南將引導您設定現代部署管道,以確保您的應用程式健壯、可擴展且易於維護。

先決條件

在深入部署流程之前,請確保您已:

  • 有權利在 AWS 中建立 Elastic Beanstalk 環境的 AWS 根帳戶或 IAM 帳戶

  • Docker 安裝在本機上

  • GitLab 或 GitHub 帳戶,包含 Next.js 應用程式的儲存庫

  • 已準備好部署的 Next.js 專案

步驟 1:設定 AWS Elastic Beanstalk

  • 建立 Elastic Beanstalk 環境 - 登入 AWS 管理控制台,導覽至 Elastic Beanstalk,然後建立一個新應用程式。

Complete Guide on Next.js Deployment on AWS Elastic Beanstalk: Using-Docker, AWS CodePipeline & CodeBuild

  • 輸入您的應用程式名稱,然後按一下「建立」。

  • 建立應用程式後,現在是建立新環境的時候了。點選建立新環境。

Complete Guide on Next.js Deployment on AWS Elastic Beanstalk: Using-Docker, AWS CodePipeline & CodeBuild

  • 選擇Web伺服器環境。環境名稱將帶有後綴 env 以及您的應用程式名稱,您可以根據需要進行編輯。

Complete Guide on Next.js Deployment on AWS Elastic Beanstalk: Using-Docker, AWS CodePipeline & CodeBuild

  • 輸入有效的環境名稱以及網域。輸入網域名稱.

Complete Guide on Next.js Deployment on AWS Elastic Beanstalk: Using-Docker, AWS CodePipeline & CodeBuild

  • 選擇合適的平台。在本例中,我們將選擇 Managed Platform 和 Docker 作為平台。

Complete Guide on Next.js Deployment on AWS Elastic Beanstalk: Using-Docker, AWS CodePipeline & CodeBuild

  • 在應用程式程式碼中,選擇範例應用程序,因為我們將透過 AWS Code Pipeline 部署我們自己的程式碼。

  • 在預設中,您可以將其保留為預設值,但是,對於生產應用程序,建議使用高可用性實例。選擇預設後,按一下“下一步”。

  • 建立或使用您現有的服務角色。在繼續建立 EC2 執行個體之前,擁有 Elastic Beanstalk 服務角色以及 EC2 服務角色設定非常重要。
    但是,如果您希望從終端透過 SSH 存取 EC2 實例,請新增 EC2 金鑰對,並建立 EC2 執行個體設定檔以執行必要的操作。

Complete Guide on Next.js Deployment on AWS Elastic Beanstalk: Using-Docker, AWS CodePipeline & CodeBuild

  • 選擇您要部署 EC2 執行個體的 VPC。

Complete Guide on Next.js Deployment on AWS Elastic Beanstalk: Using-Docker, AWS CodePipeline & CodeBuild

  • 選擇VPC後,選擇每個可用區中的子網路。若要在同一公有子網路中執行負載平衡器和實例,請將公有 IP 位址指派給實例,如圖所示。

Complete Guide on Next.js Deployment on AWS Elastic Beanstalk: Using-Docker, AWS CodePipeline & CodeBuild

  • 由於我們不需要設定資料庫,因此我們可以按一下「下一步」繼續下一步。

  • 對於根捲,我們將選擇通用SSD。

  • 現在,在安全群組中,您可以從現有的​​安全群組中進行選擇,也可以保持原樣,Elastic Beanstalk 將在設定 EC2 執行個體時為您建立安全群組。

  • 如果出於生產目的進行部署,始終建議配置自動擴展並選擇 Elastic Beanstalk 將建立來服務流量的實例類型。我們將和 t3 家族一起去。

Complete Guide on Next.js Deployment on AWS Elastic Beanstalk: Using-Docker, AWS CodePipeline & CodeBuild

  • 按一下「下一步」。

  • 在健康報告中,我們將使用基本報告,但請隨意根據您需要的報告類型從可用選項中進行選擇。

  • 我們也會取消選取託管平台更新,因為示範網站不需要它。

  • 保持其餘設定不變,然後按一下「下一步」。

  • 最後,檢查您的變更並點擊「提交」。

  • Elastic Beanstalk 將啟動您的環境,這需要一些時間。

Complete Guide on Next.js Deployment on AWS Elastic Beanstalk: Using-Docker, AWS CodePipeline & CodeBuild

  • 成功啟動後,您將看到祝賀畫面。

Complete Guide on Next.js Deployment on AWS Elastic Beanstalk: Using-Docker, AWS CodePipeline & CodeBuild

第 2 步:建立 Next.js 應用程式(或使用現有應用程式)

  • 要建立 Next.js 應用程序,請開啟終端,進入要在其中建立應用程式的目錄,然後執行以下命令:
npx create-next-app@latest nextjs-blog --use-npm --example "https://github.com/vercel/next-learn/tree/main/basics/learn-starter" 

如果您已經準備好現有程式碼,您可以跳到下一部分

  • 您現在有一個名為 nextjs-blog 的新目錄。讓我們進入它:
cd nextjs-blog 

然後,執行以下指令:

npm run dev 

這將在連接埠 3000 上啟動 Next.js 應用程式的「開發伺服器」(稍後將詳細介紹)。

讓我們檢查一下它是否正常工作。在瀏覽器中開啟 http://localhost:3000。

  • 現在是時候在應用程式中建立 Dockerfile 了。

  • 在應用程式的根目錄中建立一個名為 Dockerfile 的文件,並加入以下程式碼:

FROM node:18-alpine 

RUN mkdir -p /app 

WORKDIR /app 

COPY . . 

RUN npm install 

RUN npm run build 

EXPOSE 3000 

CMD ["npm", "start"] 

  • 進行更改後,檢查建置是否成功非常重要。啟動docker引擎並執行以下命令:
docker build -t testapp . 

Complete Guide on Next.js Deployment on AWS Elastic Beanstalk: Using-Docker, AWS CodePipeline & CodeBuild

建置成功後,使用以下命令執行應用程式:

docker run -p 3000:3000 testapp 

  • 在應用程式的根目錄中建立一個名為 buildspec.yml 的檔案並新增以下程式碼。該文件將在稍後階段在 AWS 中設定程式碼管道時使用。
version: 0.2 

artifacts: 

  type: zip 

  files: 

    - '**/*' 

  • 將這些檔案新增至新的或現有的程式碼後,將這些變更推送到 Gitlab 或 GitHub 上的遠端儲存庫。

第 3 步:設定代碼管道

  • 登入 AWS 管理主控台,導覽至 Code Pipeline,然後按一下建立管道。

  • 輸入有效的管道名稱並選擇管道的執行模式。在我們的例子中,我們將選擇“排隊”(需要管道類型 V2)。

  • 建立新的服務角色(如果尚不存在)或從現有服務角色中進行選擇,然後按一下「下一步」。

Complete Guide on Next.js Deployment on AWS Elastic Beanstalk: Using-Docker, AWS CodePipeline & CodeBuild

  • 從來源提供者選擇您的工件儲存位置。我們將選擇“Gitlab”。

  • 從連線清單中,選擇現有連線或建立新連線。

Complete Guide on Next.js Deployment on AWS Elastic Beanstalk: Using-Docker, AWS CodePipeline & CodeBuild

  • 連線成功後,選擇儲存庫名稱和將使用程式碼的分支。

  • 對於觸發器類型,我們將選擇“無過濾器”,然後按一下“下一步”。

Complete Guide on Next.js Deployment on AWS Elastic Beanstalk: Using-Docker, AWS CodePipeline & CodeBuild

  • 接下來,我們選擇建置提供者。在我們的範例中,我們將選擇 AWS Code Build。選擇區域或將其保留為預設 AWS 區域。

Complete Guide on Next.js Deployment on AWS Elastic Beanstalk: Using-Docker, AWS CodePipeline & CodeBuild

  • 然後透過點擊「建立專案」在「程式碼建置」中建立一個新專案。這將打開一個新視窗。輸入項目名稱並將環境中的所有內容保留為預設值。

Complete Guide on Next.js Deployment on AWS Elastic Beanstalk: Using-Docker, AWS CodePipeline & CodeBuild

  • 指定建置規範時,請確保選擇「使用建置規格檔案」。這與我們之前創建的文件相同。將其他設定保留為預設值並轉到下一步。

Complete Guide on Next.js Deployment on AWS Elastic Beanstalk: Using-Docker, AWS CodePipeline & CodeBuild

  • 當您按一下「繼續程式碼管道」時,視窗將自動關閉並帶您返回程式碼管道螢幕。

  • 將構建類型指定為單一構建,然後按一下「下一步」。

Complete Guide on Next.js Deployment on AWS Elastic Beanstalk: Using-Docker, AWS CodePipeline & CodeBuild

  • 在新增部署階段,選擇部署提供者。在本例中,我們希望應用程式最終部署在 AWS Elastic Beanstalk 上。

Complete Guide on Next.js Deployment on AWS Elastic Beanstalk: Using-Docker, AWS CodePipeline & CodeBuild

  • 選擇應用程式名稱、環境名稱,配置回滾設置,然後按一下「下一步」。檢查您的程式碼管道設定並點擊“建立管道”。

第 4 步:網站上線!

將 Next.js Web 應用程式部署到生產環境非常簡單,並且可以使用 AWS Code Build、Code Deploy 和 GitLab 透過 AWS Elastic Beanstalk、Docker 和 CI/CD 管道更有效率地完成。

您可以使用 Elastic Beanstalk 提供的 URL 來存取它。在本地進行更改,當您推送到分支時,它將自動部署。

快樂編碼! !

以上是在 AWS Elastic Beanstalk 上部署 Next.js 的完整指南:使用 Docker、AWS CodePipeline 和 CodeBuild的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
Python vs. JavaScript:選擇合適的工具Python vs. JavaScript:選擇合適的工具May 08, 2025 am 12:10 AM

選擇Python還是JavaScript取決於項目類型:1)數據科學和自動化任務選擇Python;2)前端和全棧開發選擇JavaScript。 Python因其在數據處理和自動化方面的強大庫而備受青睞,而JavaScript則因其在網頁交互和全棧開發中的優勢而不可或缺。

Python和JavaScript:了解每個的優勢Python和JavaScript:了解每個的優勢May 06, 2025 am 12:15 AM

Python和JavaScript各有優勢,選擇取決於項目需求和個人偏好。 1.Python易學,語法簡潔,適用於數據科學和後端開發,但執行速度較慢。 2.JavaScript在前端開發中無處不在,異步編程能力強,Node.js使其適用於全棧開發,但語法可能複雜且易出錯。

JavaScript的核心:它是在C還是C上構建的?JavaScript的核心:它是在C還是C上構建的?May 05, 2025 am 12:07 AM

javascriptisnotbuiltoncorc; sanInterpretedlanguagethatrunsonenginesoftenwritteninc.1)JavascriptwasdesignedAsignedAsalightWeight,drackendedlanguageforwebbrowsers.2)Enginesevolvedfromsimpleterterpretpretpretpretpreterterpretpretpretpretpretpretpretpretpretcompilerers,典型地,替代品。

JavaScript應用程序:從前端到後端JavaScript應用程序:從前端到後端May 04, 2025 am 12:12 AM

JavaScript可用於前端和後端開發。前端通過DOM操作增強用戶體驗,後端通過Node.js處理服務器任務。 1.前端示例:改變網頁文本內容。 2.後端示例:創建Node.js服務器。

Python vs. JavaScript:您應該學到哪種語言?Python vs. JavaScript:您應該學到哪種語言?May 03, 2025 am 12:10 AM

選擇Python還是JavaScript應基於職業發展、學習曲線和生態系統:1)職業發展:Python適合數據科學和後端開發,JavaScript適合前端和全棧開發。 2)學習曲線:Python語法簡潔,適合初學者;JavaScript語法靈活。 3)生態系統:Python有豐富的科學計算庫,JavaScript有強大的前端框架。

JavaScript框架:為現代網絡開發提供動力JavaScript框架:為現代網絡開發提供動力May 02, 2025 am 12:04 AM

JavaScript框架的強大之處在於簡化開發、提升用戶體驗和應用性能。選擇框架時應考慮:1.項目規模和復雜度,2.團隊經驗,3.生態系統和社區支持。

JavaScript,C和瀏覽器之間的關係JavaScript,C和瀏覽器之間的關係May 01, 2025 am 12:06 AM

引言我知道你可能會覺得奇怪,JavaScript、C 和瀏覽器之間到底有什麼關係?它們之間看似毫無關聯,但實際上,它們在現代網絡開發中扮演著非常重要的角色。今天我們就來深入探討一下這三者之間的緊密聯繫。通過這篇文章,你將了解到JavaScript如何在瀏覽器中運行,C 在瀏覽器引擎中的作用,以及它們如何共同推動網頁的渲染和交互。 JavaScript與瀏覽器的關係我們都知道,JavaScript是前端開發的核心語言,它直接在瀏覽器中運行,讓網頁變得生動有趣。你是否曾經想過,為什麼JavaScr

node.js流帶打字稿node.js流帶打字稿Apr 30, 2025 am 08:22 AM

Node.js擅長於高效I/O,這在很大程度上要歸功於流。 流媒體匯總處理數據,避免內存過載 - 大型文件,網絡任務和實時應用程序的理想。將流與打字稿的類型安全結合起來創建POWE

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

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

熱工具

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境