This project provides an AWS CDK construct to Deploy Serverless Next.js to Lambda@Edge. We designed the construct following these principles:
- Sensible defaults
- Feature parity with Next.js
- Fast deployments
- Build the AWS Lambda deployment package for you
- Provide
BehaviorOptions
for you to add to your CloudFront Distribution
This construct library aims for feature parity with Next.js. Through @sls-next/lambda-at-edge, this CDK construct supports:
- Next.js 10/11
- Static pages
- Server-side props
- Static props and static prop fallback
- Incremental static regeneration
- Image optimization
- API routes
// Create a ServerlessNextjs construct in your stack to get started.
// Your stack MUST be in us-east-1 as that's the only region in which AWS
// supports deploying edge lambdas.
const serverlessNextjs = new ServerlessNextjs(scope, 'NextJs', {
// Then produce and add a Next.js artifact to ServerlessNextjs by
// building it from your project directory.
nextjsArtifact: NextjsArtifact.fromBuild({
// Provide your Next.js project directory.
nextjsDirectory: pathToYourProjectDirectory,
// Provide the commands you need NextjsArtifact to run to build the
// `.next` directory.
buildCommand: ['yarn', 'next', 'build'],
}),
});
// Create CloudFront distribution
const dist = new cloudfront.Distribution(scope, 'Distribution', {
// And configure it with serverless Next.js as Lambda @ Edge
...serverlessNextjs.cloudFrontConfig,
// Add anything else you need on your CloudFront distribution here, like
// certificates, cnames, price classes, logging, etc.
});