iconDirEasy
部署上线

Docker部署

学习如何将DirEasy应用部署为Docker容器

在本指南中,我们将向您展示如何将DirEasy应用部署为Docker容器,这样您就可以将其部署到任何支持Docker镜像的平台或服务器上。

为什么要将应用部署为Docker容器?

将应用部署为Docker容器可以让您完全控制服务器环境。它确保了更好的隐私性,如果管理得当可以节省成本,并提供了根据特定需求自定义服务器设置的灵活性。与Vercel等无服务器平台相比,它还可以提升应用性能,因为它消除了冷启动问题。

为Docker部署配置Next.js应用

首先我们需要将Next.js应用配置为独立应用,以便稍后在Docker容器中运行。为此,在项目中添加以下next.config.ts文件:

nextConfig.output = 'standalone';

为Next.js应用设置Docker配置

接下来,在代码库根目录创建Dockerfile(Dockerfile),内容如下:

Dockerfile
FROM node:20-alpine AS base
FROM base AS deps
RUN apk add --no-cache libc6-compat
WORKDIR /app
COPY package.json pnpm-lock.yaml* ./
RUN corepack enable pnpm && pnpm i --frozen-lockfile
FROM base AS builder
WORKDIR /app
COPY --from=deps /app/node_modules ./node_modules
COPY . .
RUN corepack enable pnpm \
  && pnpm build
FROM base AS runner
WORKDIR /app
 
ENV NODE_ENV production
RUN addgroup --system --gid 1001 nodejs
RUN adduser --system --uid 1001 nextjs
 
COPY --from=builder /app/public ./public
RUN mkdir .next
RUN chown nextjs:nodejs .next
COPY --from=builder --chown=nextjs:nodejs /app/.next/standalone ./
COPY --from=builder --chown=nextjs:nodejs /app/.next/static ./.next/static
 
USER nextjs
 
EXPOSE 3000
 
ENV PORT 3000
ENV HOSTNAME "0.0.0.0"
CMD ["node", "server.js"]

在DirEasy项目根目录,还需要添加.dockerignore文件,内容如下:

.dockerignore
Dockerfile
.dockerignore
node_modules
**/node_modules
npm-debug.log
README.md
.next
.git

以上就是所有必要的修改!现在您可以将应用构建为Docker镜像,并部署到任何可以运行Docker镜像的地方。

在本地使用Docker运行应用

如果您在本地机器上安装了Docker,并想在那里运行Next.js应用来测试Docker镜像,只需从项目根目录运行以下命令:

终端
docker build -f Dockerfile . --no-cache -t direasy-docker
docker run -p 3000:3000 direasy-docker

要完全使用应用程序,您需要将.env文件中定义的必要环境变量传递给容器。

现在您可以将应用部署到任何支持Docker镜像的服务器上。

目录