NAME
AWS::Lambda - It's Perl support for AWS Lambda Custom Runtime.
SYNOPSIS
Save the following Perl script as handler.pl.
sub handle {
my ($payload, $context) = @_;
return $payload;
}
and then, zip the script.
zip handler.zip handler.pl
Finally, create new function using awscli.
aws --region "$REGION" --profile "$PROFILE" lambda create-function \
--function-name "hello-perl" \
--zip-file "fileb://handler.zip" \
--handler "handler.handle" \
--runtime provided \
--role arn:aws:iam::xxxxxxxxxxxx:role/service-role/lambda-custom-runtime-perl-role \
--layers "arn:aws:lambda:$REGION:445285296882:layer:perl-5-32-runtime:1"
DESCRIPTION
This package makes it easy to run AWS Lambda Functions written in Perl.
Use Prebuild Public Lambda Layer
- Login to your AWS Account and go to the Lambda Console.
- Create a new function and give it a name and an IAM Role.
- For the "Runtime" selection, select Use custom runtime in function code or layer.
- In the "Designer" section of your function dashboard, select the Layers box.
- Scroll down to the "Referenced Layers" section and click Add a layer.
- Select the Provide a layer version ARN option, then copy/paste the Layer ARN for your region.
- Click the Add button.
- Click Save in the upper right.
- Upload your code and start using Perl in AWS Lambda!
You can get the layer ARN in your script by using get_layer_info.
use AWS::Lambda;
my $info = AWS::Lambda::get_layer_info(
"5.32", # Perl Version
"us-east-1", # Region
);
say $info->{runtime_arn}; # arn:aws:lambda:us-east-1:445285296882:layer:perl-5-32-runtime:1
say $info->{runtime_version}; # 1
say $info->{paws_arn} # arn:aws:lambda:us-east-1:445285296882:layer:perl-5-32-paws:1
say $info->{paws_version} # 1,
Or, you can use following one-liner.
perl -MAWS::Lambda -e 'AWS::Lambda::print_runtime_arn("5.32", "us-east-1")'
perl -MAWS::Lambda -e 'AWS::Lambda::print_paws_arn("5.32", "us-east-1")'
All available layer ARN list is here.
- Perl 5.32
arn:aws:lambda:af-south-1:445285296882:layer:perl-5-32-runtime:1arn:aws:lambda:ap-east-1:445285296882:layer:perl-5-32-runtime:1arn:aws:lambda:ap-northeast-1:445285296882:layer:perl-5-32-runtime:1arn:aws:lambda:ap-northeast-2:445285296882:layer:perl-5-32-runtime:1arn:aws:lambda:ap-south-1:445285296882:layer:perl-5-32-runtime:1arn:aws:lambda:ap-southeast-1:445285296882:layer:perl-5-32-runtime:1arn:aws:lambda:ap-southeast-2:445285296882:layer:perl-5-32-runtime:1arn:aws:lambda:ca-central-1:445285296882:layer:perl-5-32-runtime:1arn:aws:lambda:eu-central-1:445285296882:layer:perl-5-32-runtime:1arn:aws:lambda:eu-south-1:445285296882:layer:perl-5-32-runtime:1arn:aws:lambda:eu-west-1:445285296882:layer:perl-5-32-runtime:1arn:aws:lambda:eu-west-2:445285296882:layer:perl-5-32-runtime:1arn:aws:lambda:eu-west-3:445285296882:layer:perl-5-32-runtime:1arn:aws:lambda:me-south-1:445285296882:layer:perl-5-32-runtime:1arn:aws:lambda:sa-east-1:445285296882:layer:perl-5-32-runtime:1arn:aws:lambda:us-east-1:445285296882:layer:perl-5-32-runtime:1arn:aws:lambda:us-east-2:445285296882:layer:perl-5-32-runtime:1arn:aws:lambda:us-west-1:445285296882:layer:perl-5-32-runtime:1arn:aws:lambda:us-west-2:445285296882:layer:perl-5-32-runtime:1
- Perl 5.30
arn:aws:lambda:af-south-1:445285296882:layer:perl-5-30-runtime:2arn:aws:lambda:ap-east-1:445285296882:layer:perl-5-30-runtime:9arn:aws:lambda:ap-northeast-1:445285296882:layer:perl-5-30-runtime:9arn:aws:lambda:ap-northeast-2:445285296882:layer:perl-5-30-runtime:9arn:aws:lambda:ap-south-1:445285296882:layer:perl-5-30-runtime:9arn:aws:lambda:ap-southeast-1:445285296882:layer:perl-5-30-runtime:9arn:aws:lambda:ap-southeast-2:445285296882:layer:perl-5-30-runtime:9arn:aws:lambda:ca-central-1:445285296882:layer:perl-5-30-runtime:9arn:aws:lambda:eu-central-1:445285296882:layer:perl-5-30-runtime:9arn:aws:lambda:eu-south-1:445285296882:layer:perl-5-30-runtime:2arn:aws:lambda:eu-west-1:445285296882:layer:perl-5-30-runtime:9arn:aws:lambda:eu-west-2:445285296882:layer:perl-5-30-runtime:9arn:aws:lambda:eu-west-3:445285296882:layer:perl-5-30-runtime:9arn:aws:lambda:me-south-1:445285296882:layer:perl-5-30-runtime:7arn:aws:lambda:sa-east-1:445285296882:layer:perl-5-30-runtime:9arn:aws:lambda:us-east-1:445285296882:layer:perl-5-30-runtime:9arn:aws:lambda:us-east-2:445285296882:layer:perl-5-30-runtime:9arn:aws:lambda:us-west-1:445285296882:layer:perl-5-30-runtime:9arn:aws:lambda:us-west-2:445285296882:layer:perl-5-30-runtime:9
- Perl 5.28
arn:aws:lambda:af-south-1:445285296882:layer:perl-5-28-runtime:2arn:aws:lambda:ap-east-1:445285296882:layer:perl-5-28-runtime:8arn:aws:lambda:ap-northeast-1:445285296882:layer:perl-5-28-runtime:15arn:aws:lambda:ap-northeast-2:445285296882:layer:perl-5-28-runtime:15arn:aws:lambda:ap-south-1:445285296882:layer:perl-5-28-runtime:15arn:aws:lambda:ap-southeast-1:445285296882:layer:perl-5-28-runtime:15arn:aws:lambda:ap-southeast-2:445285296882:layer:perl-5-28-runtime:15arn:aws:lambda:ca-central-1:445285296882:layer:perl-5-28-runtime:15arn:aws:lambda:eu-central-1:445285296882:layer:perl-5-28-runtime:15arn:aws:lambda:eu-south-1:445285296882:layer:perl-5-28-runtime:2arn:aws:lambda:eu-west-1:445285296882:layer:perl-5-28-runtime:15arn:aws:lambda:eu-west-2:445285296882:layer:perl-5-28-runtime:15arn:aws:lambda:eu-west-3:445285296882:layer:perl-5-28-runtime:15arn:aws:lambda:me-south-1:445285296882:layer:perl-5-28-runtime:6arn:aws:lambda:sa-east-1:445285296882:layer:perl-5-28-runtime:15arn:aws:lambda:us-east-1:445285296882:layer:perl-5-28-runtime:15arn:aws:lambda:us-east-2:445285296882:layer:perl-5-28-runtime:15arn:aws:lambda:us-west-1:445285296882:layer:perl-5-28-runtime:15arn:aws:lambda:us-west-2:445285296882:layer:perl-5-28-runtime:15
- Perl 5.26
arn:aws:lambda:af-south-1:445285296882:layer:perl-5-26-runtime:2arn:aws:lambda:ap-east-1:445285296882:layer:perl-5-26-runtime:9arn:aws:lambda:ap-northeast-1:445285296882:layer:perl-5-26-runtime:16arn:aws:lambda:ap-northeast-2:445285296882:layer:perl-5-26-runtime:16arn:aws:lambda:ap-south-1:445285296882:layer:perl-5-26-runtime:16arn:aws:lambda:ap-southeast-1:445285296882:layer:perl-5-26-runtime:16arn:aws:lambda:ap-southeast-2:445285296882:layer:perl-5-26-runtime:16arn:aws:lambda:ca-central-1:445285296882:layer:perl-5-26-runtime:16arn:aws:lambda:eu-central-1:445285296882:layer:perl-5-26-runtime:16arn:aws:lambda:eu-south-1:445285296882:layer:perl-5-26-runtime:2arn:aws:lambda:eu-west-1:445285296882:layer:perl-5-26-runtime:16arn:aws:lambda:eu-west-2:445285296882:layer:perl-5-26-runtime:15arn:aws:lambda:eu-west-3:445285296882:layer:perl-5-26-runtime:15arn:aws:lambda:me-south-1:445285296882:layer:perl-5-26-runtime:6arn:aws:lambda:sa-east-1:445285296882:layer:perl-5-26-runtime:15arn:aws:lambda:us-east-1:445285296882:layer:perl-5-26-runtime:15arn:aws:lambda:us-east-2:445285296882:layer:perl-5-26-runtime:15arn:aws:lambda:us-west-1:445285296882:layer:perl-5-26-runtime:15arn:aws:lambda:us-west-2:445285296882:layer:perl-5-26-runtime:15
Use Prebuild Zip Archive
- Login to your AWS Account and go to the Lambda Console.
- Create a new layer and give it a name.
- For the "Code entry type" selection, select Upload a file from Amazon S3.
- In the "License" section, input https://github.com/shogo82148/p5-aws-lambda/blob/master/LICENSE.
- Click Create button.
- Use the layer created. For detail, see Use Prebuild Public Lambda Layer section.
URLs for Zip archive are here.
https://shogo82148-lambda-perl-runtime-$REGION.s3.amazonaws.com/perl-$VERSION-runtime.zip
Run in Local using Docker
https://hub.docker.com/r/shogo82148/p5-aws-lambda is pre-build docker image based on https://hub.docker.com/r/lambci/lambda/
# Install the dependency.
docker run --rm -v $(PWD):/var/task shogo82148/p5-aws-lambda:build-5.32 \
cpanm --notest --local-lib extlocal --no-man-pages --installdeps .
# run an event.
docker run --rm -v $(PWD):/var/task shogo82148/p5-aws-lambda:5.32 \
handler.handle '{"some":"event"}'
AWS XRay SUPPORT
AWS X-Ray is a service that collects data about requests that your application serves. You can trace AWS Lambda requests and sends segment data with pre-install module AWS::XRay.
use utf8;
use warnings;
use strict;
use AWS::XRay qw/ capture /;
sub handle {
my ($payload, $context) = @_;
capture "myApp" => sub {
capture "nested" => sub {
# do something ...
};
};
capture "another" => sub {
# do something ...
};
return;
}
1;
Paws SUPPORT
If you want to call AWS API from your Lambda function, you can use a pre-build Lambda Layer for Paws - A Perl SDK for AWS (Amazon Web Services) APIs.
Use Prebuild Public Lambda Layer
Add the perl-runtime layer and the perl-paws layer into your lambda function.
aws --region "$REGION" --profile "$PROFILE" lambda create-function \
--function-name "hello-perl" \
--zip-file "fileb://handler.zip" \
--handler "handler.handle" \
--runtime provided \
--role arn:aws:iam::xxxxxxxxxxxx:role/service-role/lambda-custom-runtime-perl-role \
--layers \
"arn:aws:lambda:$REGION:445285296882:layer:perl-5-32-runtime:1" \
"arn:aws:lambda:$REGION:445285296882:layer:perl-5-32-paws:1"
Now, you can use Paws to call AWS API from your Lambda function.
use Paws;
my $obj = Paws->service('...');
my $res = $obj->MethodCall(Arg1 => $val1, Arg2 => $val2);
print $res->AttributeFromResult;
All available layer ARN list is here.
- Perl 5.32
arn:aws:lambda:af-south-1:445285296882:layer:perl-5-32-paws:1arn:aws:lambda:ap-east-1:445285296882:layer:perl-5-32-paws:1arn:aws:lambda:ap-northeast-1:445285296882:layer:perl-5-32-paws:1arn:aws:lambda:ap-northeast-2:445285296882:layer:perl-5-32-paws:1arn:aws:lambda:ap-south-1:445285296882:layer:perl-5-32-paws:1arn:aws:lambda:ap-southeast-1:445285296882:layer:perl-5-32-paws:1arn:aws:lambda:ap-southeast-2:445285296882:layer:perl-5-32-paws:1arn:aws:lambda:ca-central-1:445285296882:layer:perl-5-32-paws:1arn:aws:lambda:eu-central-1:445285296882:layer:perl-5-32-paws:1arn:aws:lambda:eu-south-1:445285296882:layer:perl-5-32-paws:1arn:aws:lambda:eu-west-1:445285296882:layer:perl-5-32-paws:1arn:aws:lambda:eu-west-2:445285296882:layer:perl-5-32-paws:1arn:aws:lambda:eu-west-3:445285296882:layer:perl-5-32-paws:1arn:aws:lambda:me-south-1:445285296882:layer:perl-5-32-paws:1arn:aws:lambda:sa-east-1:445285296882:layer:perl-5-32-paws:1arn:aws:lambda:us-east-1:445285296882:layer:perl-5-32-paws:1arn:aws:lambda:us-east-2:445285296882:layer:perl-5-32-paws:1arn:aws:lambda:us-west-1:445285296882:layer:perl-5-32-paws:1arn:aws:lambda:us-west-2:445285296882:layer:perl-5-32-paws:1
- Perl 5.30
arn:aws:lambda:af-south-1:445285296882:layer:perl-5-30-paws:2arn:aws:lambda:ap-east-1:445285296882:layer:perl-5-30-paws:6arn:aws:lambda:ap-northeast-1:445285296882:layer:perl-5-30-paws:6arn:aws:lambda:ap-northeast-2:445285296882:layer:perl-5-30-paws:6arn:aws:lambda:ap-south-1:445285296882:layer:perl-5-30-paws:6arn:aws:lambda:ap-southeast-1:445285296882:layer:perl-5-30-paws:6arn:aws:lambda:ap-southeast-2:445285296882:layer:perl-5-30-paws:6arn:aws:lambda:ca-central-1:445285296882:layer:perl-5-30-paws:6arn:aws:lambda:eu-central-1:445285296882:layer:perl-5-30-paws:6arn:aws:lambda:eu-south-1:445285296882:layer:perl-5-30-paws:2arn:aws:lambda:eu-west-1:445285296882:layer:perl-5-30-paws:6arn:aws:lambda:eu-west-2:445285296882:layer:perl-5-30-paws:6arn:aws:lambda:eu-west-3:445285296882:layer:perl-5-30-paws:6arn:aws:lambda:me-south-1:445285296882:layer:perl-5-30-paws:5arn:aws:lambda:sa-east-1:445285296882:layer:perl-5-30-paws:6arn:aws:lambda:us-east-1:445285296882:layer:perl-5-30-paws:6arn:aws:lambda:us-east-2:445285296882:layer:perl-5-30-paws:6arn:aws:lambda:us-west-1:445285296882:layer:perl-5-30-paws:6arn:aws:lambda:us-west-2:445285296882:layer:perl-5-30-paws:6
- Perl 5.28
arn:aws:lambda:af-south-1:445285296882:layer:perl-5-28-paws:2arn:aws:lambda:ap-east-1:445285296882:layer:perl-5-28-paws:5arn:aws:lambda:ap-northeast-1:445285296882:layer:perl-5-28-paws:5arn:aws:lambda:ap-northeast-2:445285296882:layer:perl-5-28-paws:5arn:aws:lambda:ap-south-1:445285296882:layer:perl-5-28-paws:5arn:aws:lambda:ap-southeast-1:445285296882:layer:perl-5-28-paws:5arn:aws:lambda:ap-southeast-2:445285296882:layer:perl-5-28-paws:5arn:aws:lambda:ca-central-1:445285296882:layer:perl-5-28-paws:5arn:aws:lambda:eu-central-1:445285296882:layer:perl-5-28-paws:5arn:aws:lambda:eu-south-1:445285296882:layer:perl-5-28-paws:2arn:aws:lambda:eu-west-1:445285296882:layer:perl-5-28-paws:5arn:aws:lambda:eu-west-2:445285296882:layer:perl-5-28-paws:5arn:aws:lambda:eu-west-3:445285296882:layer:perl-5-28-paws:5arn:aws:lambda:me-south-1:445285296882:layer:perl-5-28-paws:4arn:aws:lambda:sa-east-1:445285296882:layer:perl-5-28-paws:5arn:aws:lambda:us-east-1:445285296882:layer:perl-5-28-paws:5arn:aws:lambda:us-east-2:445285296882:layer:perl-5-28-paws:5arn:aws:lambda:us-west-1:445285296882:layer:perl-5-28-paws:5arn:aws:lambda:us-west-2:445285296882:layer:perl-5-28-paws:5
- Perl 5.26
arn:aws:lambda:af-south-1:445285296882:layer:perl-5-26-paws:2arn:aws:lambda:ap-east-1:445285296882:layer:perl-5-26-paws:6arn:aws:lambda:ap-northeast-1:445285296882:layer:perl-5-26-paws:6arn:aws:lambda:ap-northeast-2:445285296882:layer:perl-5-26-paws:6arn:aws:lambda:ap-south-1:445285296882:layer:perl-5-26-paws:6arn:aws:lambda:ap-southeast-1:445285296882:layer:perl-5-26-paws:6arn:aws:lambda:ap-southeast-2:445285296882:layer:perl-5-26-paws:6arn:aws:lambda:ca-central-1:445285296882:layer:perl-5-26-paws:6arn:aws:lambda:eu-central-1:445285296882:layer:perl-5-26-paws:6arn:aws:lambda:eu-south-1:445285296882:layer:perl-5-26-paws:2arn:aws:lambda:eu-west-1:445285296882:layer:perl-5-26-paws:6arn:aws:lambda:eu-west-2:445285296882:layer:perl-5-26-paws:5arn:aws:lambda:eu-west-3:445285296882:layer:perl-5-26-paws:5arn:aws:lambda:me-south-1:445285296882:layer:perl-5-26-paws:4arn:aws:lambda:sa-east-1:445285296882:layer:perl-5-26-paws:5arn:aws:lambda:us-east-1:445285296882:layer:perl-5-26-paws:5arn:aws:lambda:us-east-2:445285296882:layer:perl-5-26-paws:5arn:aws:lambda:us-west-1:445285296882:layer:perl-5-26-paws:5arn:aws:lambda:us-west-2:445285296882:layer:perl-5-26-paws:5
URLs for Zip archive are here.
https://shogo82148-lambda-perl-runtime-$REGION.s3.amazonaws.com/perl-$VERSION-paws.zip
Run in Local using Docker
https://hub.docker.com/r/shogo82148/p5-aws-lambda is pre-build docker image based on https://hub.docker.com/r/lambci/lambda/
# Install the dependency.
docker run --rm -v $(PWD):/var/task shogo82148/p5-aws-lambda:build-5.32-paws \
cpanm --notest --local-lib extlocal --no-man-pages --installdeps .
# run an event.
docker run --rm -v $(PWD):/var/task shogo82148/p5-aws-lambda:5.32-paws \
handler.handle '{"some":"event"}'
CREATE MODULE LAYER
To create custom module layer such as the Paws Layer,
install the modules into /opt/lib/perl5/site_perl in the layer.
# Create Some::Module Layer
docker run --rm \
-v $(PWD):/var/task \
-v $(PATH_TO_LAYER_DIR)/lib/perl5/site_perl:/opt/lib/perl5/site_perl \
shogo82148/p5-aws-lambda:build-5.32 \
cpanm --notest --no-man-pages Some::Module
cd $(PATH_TO_LAYER_DIR) && zip -9 -r $(PATH_TO_DIST)/some-module.zip .
SEE ALSO
LICENSE
The MIT License (MIT)
Copyright (C) Ichinose Shogo.
AUTHOR
Ichinose Shogo shogo82148@gmail.com