AWS Amplify Fargate의 서버리스 컨테이너와 서버리스 Next.js SSR 비교
3422 단어 reactnextjsawscontainers
AWS Amplify Fargate
Fargate에서 Amplify POC가 작동하려면 다음을 수행해야 합니다.
next.config.js
로 output: 'standalone'
강화/** @type {import('next').NextConfig} */
const nextConfig = {
reactStrictMode: true,
swcMinify: true,
output: 'standalone'
}
module.exports = nextConfig
Dockercompose
.# Install dependencies only when needed
FROM public.ecr.aws/docker/library/node:alpine AS deps
# Check https://github.com/nodejs/docker-node/tree/b4117f9333da4138b03a546ec926ef50a31506c3#nodealpine to understand why libc6-compat might be needed.
RUN apk add --no-cache libc6-compat
WORKDIR /app
COPY package.json yarn.lock ./
RUN yarn install --frozen-lockfile
# If using npm with a `package-lock.json` comment out above and use below instead
# COPY package.json package-lock.json ./
# RUN npm ci
# Rebuild the source code only when needed
FROM public.ecr.aws/docker/library/node:alpine AS builder
WORKDIR /app
COPY --from=deps /app/node_modules ./node_modules
COPY . .
# Next.js collects completely anonymous telemetry data about general usage.
# Learn more here: https://nextjs.org/telemetry
# Uncomment the following line in case you want to disable telemetry during the build.
# ENV NEXT_TELEMETRY_DISABLED 1
RUN yarn build
# Production image, copy all the files and run next
FROM public.ecr.aws/docker/library/node:alpine AS runner
WORKDIR /app
ENV NODE_ENV production
# Uncomment the following line in case you want to disable telemetry during runtime.
# ENV NEXT_TELEMETRY_DISABLED 1
RUN addgroup --system --gid 1001 nodejs
RUN adduser --system --uid 1001 nextjs
# You only need to copy next.config.js if you are NOT using the default configuration
COPY --from=builder /app/next.config.js ./
COPY --from=builder /app/public ./public
COPY --from=builder /app/package.json ./package.json
# Automatically leverage output traces to reduce image size
# https://nextjs.org/docs/advanced-features/output-file-tracing
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
CMD ["node", "server.js"]
AWS 빌드에 AWS 라이브러리의 이미지를 사용하는 것이 중요합니다. 이미지
public.ecr.aws/docker/library/node:alpine
를 참조하십시오.node:alpine
를 사용하고 싶다면 docker hub download rate limit에 대해 알아야 합니다.대략 작동합니다.
성공 !
이것이 제가 2021년에
Next.js
SSR 앱을 AWS에 배포한 방법이며, 이제 2022년에는 SSR support in Amplify우리는 더 잘할 수 있습니다. 모든 것을 버리고 처음부터 시작합시다.
Reference
이 문제에 관하여(AWS Amplify Fargate의 서버리스 컨테이너와 서버리스 Next.js SSR 비교), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://dev.to/hexfloor/serverless-containers-vs-serverless-nextjs-ssr-on-aws-amplify-fargate-2pkh텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념 (Collection and Share based on the CC Protocol.)