使用独立构建对 Nextjs 应用程序进行 Docker 化

使用独立构建对 nextjs 应用程序进行 docker 化

介绍

docker 近年来因允许将应用程序放置在容器内而受到欢迎。这些容器可以部署到任何环境,并且在所有环境中都以相同的方式工作,无论应用程序运行的平台如何,都提供统一行为。这些容器使用图像,它们是应用程序的副本或压缩快照。通过将它们放置在容器中,它们将完全按原样显示。这是一些人迫切需要的技术之一,而另一些人直到听说它才意识到他们需要它。

就其本身而言,next.js 是最流行的 react 框架。与使用 webpack 或 vite 等捆绑器的任何其他 javascript 应用程序一样,使用项目的编译版本进行生产。这称为构建。构建旨在提供应用程序所需的最少量代码,使其与开发中的功能相同。这确保了 javascript 文件非常轻量级,允许浏览器在尽可能短的时间内获取和解释它们,以呈现用户界面或执行应用程序所需的任何任务。”

next.js 特别提供了一个进一步减小构建大小的版本:独立构建。如果我们使用 docker 为 next.js 应用程序创建映像,我们可以轻松地将我们构建的出色应用程序部署到任何环境,而无需担心兼容性或其他配置。在本文中,我们将了解如何实现它。

包管理器

就我而言,我喜欢使用 pnpm 来减少 node_modules 文件夹的磁盘大小。因此,next.js docker 镜像的示例使用了这个包管理器,但如果您愿意,您可以稍作调整以使用 npm 或 yarn。

next.js 配置

在 next.config.js 文件中,我们必须指定当应用程序编译用于生产时,生成的构建类型将是独立的。为此,我们需要包括以下内容:

/** @type {import('next').nextconfig} */const nextconfig = {  output: "standalone"};export default nextconfig;

这样,应用程序的输出将是独立类型。

dockerfile

代表我们的 docker 镜像的文件是 dockerfile。通常该文件放置在项目的根目录中。让我们一步一步来创建它。

基础镜像

每个 docker 镜像都从基础镜像开始。在这种情况下,任何运行服务器的 javascript 项目都需要像 node.js 这样的运行时。我们将以与我们的项目兼容的 node.js 版本的 docker 镜像为基础。就我而言,我喜欢使用 alpine 版本的图像,因为它更轻量。但是,我们在构建镜像时必须检查是否存在兼容性问题,否则,我们必须使用“非alpine”版本的镜像。对于此示例,我使用 node:22.6.0-alpine3.19 图像作为基础。

from node:22.6.0-alpine3.19 as base

我们放置一个别名以在图像的不同步骤或阶段回收它。

系统和 pnpm 依赖项

下一阶段是安装依赖项。在这种情况下,只需要一个系统依赖项:libc6-compat。这里提到了原因。

from base as build-depsrun apk add --no-cache libc6-compat

由于 node.js 默认不包含 pnpm,因此需要激活它并设置环境变量,以便缓存已安装的包。

env pnpm_home="/pnpm"env path="$pnpm_home:$path"run corepack enablerun corepack prepare pnpm@latest --activate

然后,我们必须设置工作目录,以明确区分系统文件夹和应用程序文件夹。在本例中,我们使用 /app。

workdir /app

现在我们必须复制包含项目依赖信息的文件并安装它们。

copy package.json pnpm-lock.yaml ./run pnpm install --frozen-lockfile --prefer-frozen-lockfile

–frozen-lockfile 和 –prefer-frozen-lockfile 参数用于遵守 pnpm 锁定文件中指定的版本。

为了完成此阶段,添加了 sharp 库。这是在 next.js 的生产环境中优化图像所必需的。

run pnpm add sharp

整个舞台是这样的:

from base as build-depsrun apk add --no-cache libc6-compatenv pnpm_home="/pnpm"env path="$pnpm_home:$path"run corepack enablerun corepack prepare pnpm@latest --activateworkdir /appcopy package.json pnpm-lock.yaml ./run pnpm install --frozen-lockfile --prefer-frozen-lockfilerun pnpm add sharp

构建应用程序

下一阶段是编译 next.js 应用程序。这是使映像正常工作的关键所在,因为 dockerfile 的其余部分没有任何不同,或者您在任何其他示例中找不到。 在此阶段,需要将项目中使用的环境变量作为构建参数传递,并在生成构建之前设置它们。

这是因为,由于应用程序有两个工作时间,即构建时间和运行时间,如果环境变量在运行时不可用,则所有使用它们的静态资源都不会具有它们的值并且该应用程序将无法正常工作。在此示例中,使用了三个环境变量:next_public_backend_url、frontend_url 和 jwt_secret。

from base as builderarg next_public_backend_urlenv next_public_backend_url=$next_public_backend_urlarg frontend_urlenv frontend_url=$frontend_urlarg jwt_secretenv jwt_secret=$jwt_secret

然后,pnpm 被激活,工作目录被设置,所有应用程序文件被复制并生成构建。

run corepack enablerun corepack prepare pnpm@latest --activateworkdir /appcopy --from=build-deps /app/node_modules ./node_modulescopy . .run pnpm build

整个舞台是这样的:

from base as builderarg next_public_backend_urlenv next_public_backend_url=$next_public_backend_urlarg frontend_urlenv frontend_url=$frontend_urlarg jwt_secretenv jwt_secret=$jwt_secretrun corepack enablerun corepack prepare pnpm@latest --activateworkdir /appcopy --from=build-deps /app/node_modules ./node_modulescopy . .run pnpm build

运行应用程序

最后一个阶段是运行应用程序。为此,我们首先设置 node 生产环境:

from base as runnerenv node_env=production

根据个人喜好,next.js 遥测被禁用。也就是说,我们基本上不会将应用程序数据发送到 vercel 来通过错误诊断和使用指标来改进 next.js。

env next_telemetry_disabled=1

此外,作为一个好的实践,建议在 docker 镜像中使用非 root 用户。例如,这可以避免容器有权访问主机网络时出现安全漏洞。为此,需要添加一个 nodejs 组和一个 nextjs 用户并分配 .next 文件夹属性。

run addgroup --system --gid 1001 nodejsrun adduser --system --uid 1001 nextjsrun mkdir .nextrun chown nextjs:nodejs .next

然后,复制独立构建生成的文件以创建与 next.js 默认构建相同的结构。

copy --from=builder --chown=nextjs:nodejs /app/.next/standalone ./copy --from=builder --chown=nextjs:nodejs /app/.next/static ./.next/staticcopy --from=builder --chown=nextjs:nodejs /app/public ./public

由于我们创建了 nextjs 用户,我们需要指定这将是要使用的用户。

user nextjs

同样,需要指定容器暴露的端口,以及将使用的节点端口和主机名,由于我们不知道确切的地址,因此主机名将为 0.0.0.0。

expose 3000env port=3000env hostname="0.0.0.0"

然后,从构建参数中指定应用程序运行时的环境变量。

arg next_public_backend_urlenv next_public_backend_url=$next_public_backend_urlarg frontend_urlenv frontend_url=$frontend_urlarg jwt_secretenv jwt_secret=$jwt_secret

可以使用 docker-compose.yml 文件中指定的环境变量,以及运行容器时,但是,在此上下文中的环境变量在构建时和运行时不同是没有意义的.

最后,我们运行服务器。

cmd ["node", "server.js"]

完整文件

完整的 dockerfile 如下所示:

FROM node:22.6.0-alpine3.19 AS baseFROM base AS build-depsRUN apk add --no-cache libc6-compatENV PNPM_HOME="/pnpm"ENV PATH="$PNPM_HOME:$PATH"RUN corepack enableRUN corepack prepare pnpm@latest --activateWORKDIR /appCOPY package.json pnpm-lock.yaml ./RUN pnpm install --frozen-lockfile --prefer-frozen-lockfileRUN pnpm add sharpFROM base AS builderARG NEXT_PUBLIC_BACKEND_URLENV NEXT_PUBLIC_BACKEND_URL=$NEXT_PUBLIC_BACKEND_URLARG FRONTEND_URLENV FRONTEND_URL=$FRONTEND_URLARG JWT_SECRETENV JWT_SECRET=$JWT_SECRETRUN corepack enableRUN corepack prepare pnpm@latest --activateWORKDIR /appCOPY --from=build-deps /app/node_modules ./node_modulesCOPY . .RUN pnpm buildFROM base AS runnerENV NODE_ENV=productionENV NEXT_TELEMETRY_DISABLED=1RUN addgroup --system --gid 1001 nodejsRUN adduser --system --uid 1001 nextjsRUN mkdir .nextRUN chown nextjs:nodejs .nextCOPY --from=builder --chown=nextjs:nodejs /app/.next/standalone ./COPY --from=builder --chown=nextjs:nodejs /app/.next/static ./.next/staticCOPY --from=builder --chown=nextjs:nodejs /app/public ./publicUSER nextjsEXPOSE 3000ENV PORT=3000ENV HOSTNAME="0.0.0.0"ARG NEXT_PUBLIC_BACKEND_URLENV NEXT_PUBLIC_BACKEND_URL=$NEXT_PUBLIC_BACKEND_URLARG FRONTEND_URLENV FRONTEND_URL=$FRONTEND_URLARG JWT_SECRETENV JWT_SECRET=$JWT_SECRETCMD ["node", "server.js"]

您还可以在此要点中找到该文件。

结论

为 next.js 应用程序创建 docker 镜像一开始可能会令人畏惧,因为我们必须考虑所有因素。此外,人们普遍认为自托管 next.js 应用程序,即。例如,在 vercel 之外,情况很复杂。事实并非如此。了解了关键部分,其实很简单。

我希望通过这些信息,您可以毫无问题地对您的 next.js 应用程序进行 dockerize。你知道该怎么做,如果你有任何问题或想分享一些东西,请留在评论中:)

以上就是使用独立构建对 Nextjs 应用程序进行 Docker 化的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1493442.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月19日 15:41:37
下一篇 2025年12月19日 15:41:47

相关推荐

  • 配置 Tailwind CSS:初始化指南 |设置 Tailwind CSS:初始化指南

    简介 |简介意大利语:本文有意大利语和英语版本。向下滚动查看英文版本。英语:本文有意大利语和英语版本。向下滚动查看英文版本。 意大利语版 如何开始使用 tailwind css:项目完整指南 简介 在项目中配置 tailwind css 第一次似乎令人畏惧,特别是对于像我这样第一次尝试这个库的人来说…

    2025年12月24日
    000
  • 为什么多年的经验让我选择全栈而不是平均栈

    在全栈和平均栈开发方面工作了 6 年多,我可以告诉您,虽然这两种方法都是流行且有效的方法,但它们满足不同的需求,并且有自己的优点和缺点。这两个堆栈都可以帮助您创建 Web 应用程序,但它们的实现方式却截然不同。如果您在两者之间难以选择,我希望我在两者之间的经验能给您一些有用的见解。 在这篇文章中,我…

    2025年12月24日
    000
  • 如何设置独立 CLI:在 Shopify 中使用 Tailwind CSS,而不使用 Nodejs

    依赖关系 Shopify CLI:一种命令行界面工具,可帮助您开发和管理 Shopify 主题。TailwindCSS:实用程序优先的 CSS 框架,用于快速构建自定义设计。 设置 我们使用 Tailwind 作为独立的 CLI 工具。更多信息可以参考官方指南。 注意:如果您在配备 Intel 处理…

    2025年12月24日
    000
  • 谷歌怎么下载html5_HTML5无需下载浏览器直接渲染运行页面文件【说明】

    HTML5不是需下载的软件,而是浏览器原生标准;Chrome默认支持,可通过file://协议直接打开本地.html文件,或用http-server启动本地服务器以支持完整API功能。 如果您已编写好HTML5页面文件,但误以为需要“下载HTML5”才能运行,则需明确:HTML5不是可下载的独立软件…

    2025年12月23日
    000
  • 手机编程html5工具_移动端代码编辑器推荐【指南】

    推荐五款移动端HTML5编辑器:Acode Editor支持一键预览;DroidEdit Pro可FTP/SFTP远程编辑;Codeanywhere提供云端IDE与Git集成;SpckEditor专注极简单页开发;Termux组合方案实现命令行本地服务。 如果您希望在手机上直接编写、调试和预览 HT…

    2025年12月23日
    000
  • Selenium headless模式下动态菜单与复选框的交互策略

    本文旨在解决Selenium在无头浏览器模式下,无法直接点击隐藏或动态生成的复选框(input)的问题。通过分析HTML结构和Selenium的交互机制,文章提出并详细阐述了点击关联的“元素作为有效替代方案,并结合`execute_script`方法和适当的等待策略,提供了一套完整的解决方案和最佳…

    2025年12月23日
    000
  • Selenium自动化:在无头Chrome中点击自定义选择菜单的策略

    本文将详细介绍如何在Selenium无头Chrome浏览器环境中,有效处理具有复杂HTML结构的自定义选择菜单。针对直接点击`input`元素可能遇到的`TimeoutException`问题,教程将提供一种可靠的解决方案:通过点击与`input`关联的`label`元素来实现菜单选项的精确选择,并…

    2025年12月23日
    000
  • 使用Selenium在无头Chrome中交互动态菜单和复选框的策略

    本文深入探讨了在selenium无头chrome环境下,如何高效且稳定地与动态加载的菜单及复选框进行交互。核心策略包括配置无头浏览器以确保元素可见性,以及在面对直接点击`input`元素失效时,转而定位并点击其关联的`label`元素,并结合显式等待机制,以克服因元素隐藏或javascript事件绑…

    2025年12月23日
    000
  • Linux polybar状态栏,HTML+CSS加载进度实时!

    可通过 Bash 脚本在 Polybar 中模拟 HTML+CSS 风格进度条,利用 %{F#color} 标记和块字符 ▮ 动态显示已完成与未完成部分,结合实时任务进度输出格式化文本。 如果您希望在 Linux 的 Polybar 状态栏中显示一个基于 HTML+CSS 风格的加载进度条,并实时反…

    2025年12月23日
    000
  • Node.js Puppeteer爬虫的部署与自动化运行指南

    本教程详细指导如何部署基于node.js和puppeteer的网络爬虫,并实现其自动化定时执行。文章区分了前端静态网站与后端node.js脚本的部署策略,重点介绍了在windows环境下使用任务计划程序(task scheduler)进行定时任务配置的方法,同时提及了cors问题产生的原因及解决方案…

    2025年12月23日
    000
  • GitLab CI管道测试,HTML+CSS集成部署零出错!

    首先检查.gitlab-ci.yml配置是否正确,依次设置stages为build、test、deploy;在build阶段安装依赖并生成资源;在test阶段通过htmlhint和stylelint进行静态检查;启用node_modules缓存提升速度;部署时将dist目录上传至GitLab Pag…

    2025年12月23日
    000
  • Linux Debian用Gulp自动化,CSS编译HTML零等待!

    首先安装Node.js与npm,再初始化项目并安装Gulp及插件,接着配置gulpfile.js定义Sass编译与浏览器同步任务,最后通过gulp命令启动自动化流程,实现CSS即时编译与HTML实时更新。 如果您希望在Linux Debian系统中通过Gulp实现自动化工作流,以达到CSS即时编译、…

    2025年12月23日
    000
  • Node.js爬虫的服务器端部署与定时任务配置指南

    本文旨在指导开发者如何部署基于%ignore_a_1%的puppeteer网络爬虫,并实现其定时自动化运行。针对本地开发环境,文章详细介绍了利用windows任务计划程序配置定时任务的步骤,确保node.js脚本能按预设时间自动执行,更新数据。同时,文章也探讨了生产环境下的部署思路,强调了客户端与服…

    2025年12月23日
    000
  • Node.js爬虫的部署、调度与静态网站数据集成指南

    本教程详细阐述如何部署和自动化运行node.js网络爬虫,实现定时数据抓取并更新静态网站内容。我们将探讨node.js脚本的服务器端运行机制、windows任务计划程序等调度工具的配置,以及爬取数据与静态html页面集成的策略,旨在帮助您构建高效且自动化的数据更新流程。 1. 理解Node.js爬虫…

    2025年12月23日
    000
  • 部署与自动化运行Node.js网络爬虫:使用Windows任务计划程序

    本文将指导您如何部署一个基于node.js和puppeteer的网络爬虫,并利用windows任务计划程序实现其每日定时自动运行。我们将深入探讨服务器端脚本与静态网页的区别,提供详细的步骤配置任务计划,并讨论在自动化过程中需要注意的关键事项,如资源管理、错误处理及跨平台部署思路。 理解Node.js…

    2025年12月23日
    000
  • 部署与调度Node.js爬虫:从本地执行到云端集成

    本教程详细指导如何部署和调度一个基于node.js的网页爬虫,使其能够每日自动运行并将其数据提供给前端应用。文章将区分客户端与服务器端javascript的运行环境,介绍本地任务调度方法,并探讨将爬虫集成到在线服务以实现数据共享的策略,同时涵盖数据持久化、cors处理及部署最佳实践。 1. 理解No…

    2025年12月23日
    000
  • nodejs如何打开html_Node.js环境中HTML文件打开方法

    如果您在Node.js环境中需要打开或提供HTML文件的访问,通常意味着您希望启动一个本地服务器来渲染并展示HTML页面。以下是实现该功能的具体方法: 一、使用内置http模块创建服务器 通过Node.js的内置http模块可以快速搭建一个简易服务器,用于读取并返回HTML文件内容给客户端浏览器。 …

    2025年12月23日
    000
  • WSL2里写HTML+CSS,Windows秒变Linux开发机!

    使用WSL2可在Windows中高效进行Linux环境下的HTML与CSS开发。首先启用WSL2并安装Ubuntu 22.04,确保运行版本为2;接着安装Visual Studio Code及Remote – WSL插件,将项目存于Linux文件系统以实现编辑同步;通过Python内置服…

    2025年12月23日
    000
  • Windows WSL2中Linux环境运行HTML+CSS开发服务器

    在WSL2中配置Linux环境进行HTML+CSS开发,首先启用WSL2并安装Ubuntu等发行版,运行wsl –install后重启并设置用户;接着更新系统包sudo apt update && sudo apt upgrade;推荐使用Python3内置服务器,在项目…

    2025年12月23日
    000
  • Linux用stylelint实时校验CSS是否符合HTML规范

    Stylelint用于校验CSS书写规范,可通过配置文件和编辑器插件在Linux中实现实时检查,并结合chokidar监听文件变化,确保CSS代码质量并与HTML协同工作。 Stylelint 是一个强大的 CSS 代码检查工具,但它主要用于校验 CSS 的书写规范(如格式、可维护性、错误预防等),…

    2025年12月23日
    000

发表回复

登录后才能评论
关注微信