From a0809954323559994609f05345192e4120aee3cf Mon Sep 17 00:00:00 2001 From: Harold Date: Sat, 18 Sep 2021 17:32:43 -0400 Subject: [PATCH 1/2] Update the readme and package description --- .projenrc.js | 2 ++ README.md | 35 +++++++++++++++++++++-------------- 2 files changed, 23 insertions(+), 14 deletions(-) diff --git a/.projenrc.js b/.projenrc.js index 893cf12..5ba2b82 100644 --- a/.projenrc.js +++ b/.projenrc.js @@ -14,6 +14,8 @@ const project = new TypeScriptProject({ npmRegistryUrl: 'https://npm.pkg.github.com', npmTokenSecret: 'NPM_TOKEN', releaseToNpm: true, + description: 'Enables running `serverless-next.js` applications using Origin Lamdbda functions for reduced cost and improved speed.', + keywords: ['serverless', 'next.js', 'lamda', 'aws', 'serverless-next.js'], eslintOptions: { prettier: true, diff --git a/README.md b/README.md index 5fea57f..215b0ca 100644 --- a/README.md +++ b/README.md @@ -1,18 +1,25 @@ # Overview -The [serverless-next.js](https://github.com/serverless-nextjs/serverless-next.js) project is fantastic in that it allows deploying Next.js applications using Lambda functions. +An extension of [serverless-next.js](https://github.com/serverless-nextjs/serverless-next.js) that allows running the Next.js application as AWS Lambda functions are the origin instead of using Lambda @ Edge. -However, some choices made by the `serverless-next.js` project may be less than ideal for some consuming projects, such as: +# Setting Up New App -- Lambda @ Edge Usage - - In limited cases, Lambda @ Edge is fantastic for quick rendering of server-side rendered pages that `need no AWS origin data` - - This use case is quite limited in practice - - Speed: Calls to origin have to be carefully consolidated into 1 single origin call - - Getting a record from DynamoDB, then to get a corresponding file from s3, would cause you wait for the edge to origin latency (e.g. 300 ms RTT from APAC to US East 1) twice, taking 600 ms, vs 300 ms total if calling a service in the origin that hits DyanamoDB then s3 (in the same region) - - Cost: Lambda @ Edge is most cost efficiently used if modifying request or response objects without calling out to origin services; any origin calls will cause the Lambda billing clock to continue running while waiting up to 300 ms for an RTT from edge to origin to make a 1 ms call to DynamoDB - - Implementing the same @ origin would cost ~1 ms for Lambda @ Edge request transformation (if any) and 1 ms @ origin for the DynamoDB request - - In this case, the cost would be 2 ms of Lambda vs 300 ms of Lambda @ Edge, a savings of 99% in ms billed (or Lambda @ Edge would bill 150x more than Lambda @ Origin) - - Lambda @ Origin billing is in 1 ms increments as of Dec 2020: https://aws.amazon.com/about-aws/whats-new/2020/12/aws-lambda-changes-duration-billing-granularity-from-100ms-to-1ms/ - - Lambda @ Edge pricing is $0.00005001 / GB-Sec while Lambda pricing is $0.0000166667 / GB-Sec - Lambda @ Edge is 200% (3x) more expensive than Lambda @ Origin (or, Lambda @ Origin is 66% less expensive than Lambda @ Edge) - - Added together, Lambda @ Edge for origin calls to DynamoDB would be 450x more expensive than letting CloudFront call back to the origin and hit a Lambda @ Origin which then hits DynamoDB - - Cost - Again: Lambda @ Edge calling DynamoDB (or any other service) from the edge (e.g. APAC) to the origin (e.g. US East 1) will incur elevated Lambda @ Edge billing charges for the entire duration of the DynamoDB call to the origin, including all RTT wire transit time (which will be 500 ms to 1,000 ms in the APAC to US East 1 case). When run with Lambda @ Origin the Lambda bililng for wire transit time is completely eliminated. +Honestly, the instructions are going to have to wait a bit after 2021-09-18 as there are other components being released, shortly, that make it easier to give an example of how to use this. + +# Motivations + +[serverless-next.js](https://github.com/serverless-nextjs/serverless-next.js) is a fantastic project in that it allows deploying Next.js applications using Lambda functions. + +However, the `Lambda @ Edge` usage by the `serverless-next.js` project may be less than ideal for some consuming projects, for the following reasons: + +- In limited cases, Lambda @ Edge is fantastic for quick rendering of server-side rendered pages that `need no AWS origin data` + - This use case is quite limited in practice +- Speed: Calls to origin have to be carefully consolidated into 1 single origin call + - Getting a record from DynamoDB, then to get a corresponding file from s3, would cause you wait for the edge to origin latency (e.g. 300 ms RTT from APAC to US East 1) twice, taking 600 ms, vs 300 ms total if calling a service in the origin that hits DyanamoDB then s3 (in the same region) +- Cost: Lambda @ Edge is most cost efficiently used if modifying request or response objects without calling out to origin services; any origin calls will cause the Lambda billing clock to continue running while waiting up to 300 ms for an RTT from edge to origin to make a 1 ms call to DynamoDB + - Implementing the same @ origin would cost ~1 ms for Lambda @ Edge request transformation (if any) and 1 ms @ origin for the DynamoDB request + - In this case, the cost would be 2 ms of Lambda vs 300 ms of Lambda @ Edge, a savings of 99% in ms billed (or Lambda @ Edge would bill 150x more than Lambda @ Origin) + - Lambda @ Origin billing is in 1 ms increments as of Dec 2020: https://aws.amazon.com/about-aws/whats-new/2020/12/aws-lambda-changes-duration-billing-granularity-from-100ms-to-1ms/ + - Lambda @ Edge pricing is $0.00005001 / GB-Sec while Lambda pricing is $0.0000166667 / GB-Sec - Lambda @ Edge is 200% (3x) more expensive than Lambda @ Origin (or, Lambda @ Origin is 66% less expensive than Lambda @ Edge) + - Added together, Lambda @ Edge for origin calls to DynamoDB would be 450x more expensive than letting CloudFront call back to the origin and hit a Lambda @ Origin which then hits DynamoDB +- Cost - Again: Lambda @ Edge calling DynamoDB (or any other service) from the edge (e.g. APAC) to the origin (e.g. US East 1) will incur elevated Lambda @ Edge billing charges for the entire duration of the DynamoDB call to the origin, including all RTT wire transit time (which will be 500 ms to 1,000 ms in the APAC to US East 1 case). When run with Lambda @ Origin the Lambda billing for wire transit time is completely eliminated. From 436c9030b73f1b0902c7804ccbda37f111731839 Mon Sep 17 00:00:00 2001 From: Automation Date: Sat, 18 Sep 2021 21:34:14 +0000 Subject: [PATCH 2/2] chore: self mutation --- .projenrc.js | 3 ++- package.json | 8 ++++++++ 2 files changed, 10 insertions(+), 1 deletion(-) diff --git a/.projenrc.js b/.projenrc.js index 5ba2b82..8c3328d 100644 --- a/.projenrc.js +++ b/.projenrc.js @@ -14,7 +14,8 @@ const project = new TypeScriptProject({ npmRegistryUrl: 'https://npm.pkg.github.com', npmTokenSecret: 'NPM_TOKEN', releaseToNpm: true, - description: 'Enables running `serverless-next.js` applications using Origin Lamdbda functions for reduced cost and improved speed.', + description: + 'Enables running `serverless-next.js` applications using Origin Lamdbda functions for reduced cost and improved speed.', keywords: ['serverless', 'next.js', 'lamda', 'aws', 'serverless-next.js'], eslintOptions: { diff --git a/package.json b/package.json index faa8965..9248db2 100644 --- a/package.json +++ b/package.json @@ -1,5 +1,6 @@ { "name": "@pwrdrvr/serverless-nextjs-router", + "description": "Enables running `serverless-next.js` applications using Origin Lamdbda functions for reduced cost and improved speed.", "repository": { "type": "git", "url": "git://github.com/pwrdrvr/serverless-nextjs-router.git" @@ -68,6 +69,13 @@ "lambda-log": "^2.4.0" }, "bundledDependencies": [], + "keywords": [ + "aws", + "lamda", + "next.js", + "serverless", + "serverless-next.js" + ], "engines": { "node": ">= 12.0.0" },