A 'serverless' example of using Chrome AWS Lambda as an AWS Lambda Layer. This project uses serverless framework to manage deployment. You can directly use the "buildchromelayer.sh" script packaged in this project to create a pre-built layer.
- Puppeteer should be usable in AWS Nodejs 10.x lambda runtime. (this problem is solved nicely by @alixaxel)
- We want to use chrome through a layer. This choice will make sense if you have many lambdas that needs Puppeteer.
- Function deployments should be as light as possible. We don't want to pull any extra luggage in terms of chrome binaries.
- clone project into your workspace.
- run ./buildchromelayer.sh to create the lambda layer using latest Chrome AWS Lambda
boni@devasur:~/src/chrome-aws-lambda-test$ ./buildchromelayer.sh Cloning into 'chrome-aws-lambda'... remote: Enumerating objects: 34, done. remote: Counting objects: 100% (34/34), done. remote: Compressing objects: 100% (29/29), done. remote: Total 34 (delta 0), reused 17 (delta 0), pack-reused 0 Unpacking objects: 100% (34/34), done. make: '../chrome-layer/chrome_aws_node10x.zip' is up to date. -rw-rw-r-- 1 boni boni 41M Oct 22 11:54 ../chrome-layer/chrome_aws_node10x.zip
- Deploy code to AWS Console.
- Login to Lambda Console. Select deployed function. Use Test option to confirm the deployment works.
- Create a new Test event
{ "url": "https://github.com/alixaxel" }
- Click Test.
- Check Output
- Create a new Test event
-
in serverless.yml I am using plugin serverless-plugin-include-dependencies to keep the function sizes as small as possible.
-
in serverless.yml we are excluding all heavy weights from getting into the lambda thorugh appropriate packaging. This helps to keep the sizes of lambda small and manageable.
package: exclude: - layer/** - layer1/** - node_modules/** - node_modules/**/chrome-aws-lambda/**
-
Lambda execution environment is manipulated by Chrome AWS Lambda during instantiation of the library. This is necessary because of mismatch of some required library versions in AWS Linux 2. In the future this environment may change. So it is highly recommended that you keep a watch on updates to Chrome AWS Lambda Github.
- Creates chromium executable by inflating (brotlli) chromium.br (target /tmp/chrmoium)
- Creates missing *.so libraries by inflating aws.tar.br
- manipulates the LD_LIBRARY_PATH to ensure packaged Linux libraries are loaded in correct order so that Puppeteer works.
- Uses an appropriate execution path to chromium that it creates
-
You can manage a lambda layer through a path to a folder or using an artifact reference to a pre-built layer zip. Here we are using the pre-built layer approach. Also remember that there is a bit of post processing that happens using the files in your layer on every execution of Lambda. This is a necessary evil.
Creating Layer
layers: chromePreBuilt: package: artifact: chrome-layer/chrome_aws_node10x.zip
Referencing layer in function using {title cased layer name} + LambdaLayer notation.
loadWithChromeAwsLambda: timeout: 120 memorySize: 1024 layers: - { Ref: ChromePreBuiltLambdaLayer} handler: overloadedpuppeteer.loadChrome