KEMBAR78
Lambda DG | PDF | Amazon Web Services | Areas Of Computer Science
0% found this document useful (0 votes)
998 views487 pages

Lambda DG

lambda

Uploaded by

Sai Sandeep
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
998 views487 pages

Lambda DG

lambda

Uploaded by

Sai Sandeep
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 487

AWS Lambda

Developer Guide
AWS Lambda Developer Guide

AWS Lambda: Developer Guide


Copyright 2017 Amazon Web Services, Inc. and/or its aliates. All rights reserved.
Amazon's trademarks and trade dress may not be used in connection with any product or service that is not Amazon's, in any manner
that is likely to cause confusion among customers, or in any manner that disparages or discredits Amazon. All other trademarks not
owned by Amazon are the property of their respective owners, who may or may not be aliated with, connected to, or sponsored by
Amazon.
AWS Lambda Developer Guide

Table of Contents
What Is AWS Lambda? ........................................................................................................................ 1
When should I Use Lambda? ....................................................................................................... 1
Are You a First-time User of AWS Lambda? ................................................................................... 2
Lambda Functions .............................................................................................................................. 3
Compute Requirements Lambda Function Conguration ............................................................... 3
Invocation Types ........................................................................................................................ 4
Building Lambda Functions ......................................................................................................... 5
Authoring Code for Your Lambda Function ............................................................................ 5
Deploying Code and Creating a Lambda Function ................................................................... 6
Monitoring and Troubleshooting .......................................................................................... 7
AWS Lambda-Based Application Examples ............................................................................. 7
Related Topics ................................................................................................................... 8
Programming Model ........................................................................................................... 8
Creating a Deployment Package ......................................................................................... 60
Versioning and Aliases ...................................................................................................... 75
Environment Variables ...................................................................................................... 92
Tagging Lambda Functions ................................................................................................ 98
VPC Support .......................................................................................................................... 103
Conguring a Lambda Function for Amazon VPC Access ...................................................... 103
Internet Access for Lambda Functions ............................................................................... 104
Guidelines for Setting Up VPC-Enabled Lambda Functions ................................................... 105
Tutorials: Accessing Resources in an Amazon VPC ............................................................... 105
Troubleshooting and Monitoring ............................................................................................... 114
Troubleshooting Scenarios ............................................................................................... 114
Accessing CloudWatch Metrics .......................................................................................... 116
Accessing CloudWatch Logs ............................................................................................. 118
Metrics .......................................................................................................................... 119
Dead Letter Queues ........................................................................................................ 121
Building Applications with AWS Lambda ............................................................................................ 123
Example 1 ............................................................................................................................. 124
Example 2 ............................................................................................................................. 125
Example 3: Custom Application Publishes Events and Invokes a Lambda Function ........................... 125
Suggested Reading ......................................................................................................... 127
Event Source Mapping ............................................................................................................ 127
Event Source Mapping for AWS Services ............................................................................ 128
Event Source Mapping for AWS Stream-Based Services ........................................................ 129
Event Source Mapping for Custom Applications .................................................................. 130
Supported Event Sources ......................................................................................................... 131
Amazon S3 .................................................................................................................... 132
Amazon DynamoDB ........................................................................................................ 132
Amazon Kinesis Streams .................................................................................................. 132
Amazon Simple Notication Service .................................................................................. 132
Amazon Simple Email Service .......................................................................................... 133
Amazon Cognito ............................................................................................................. 133
AWS CloudFormation ...................................................................................................... 134
Amazon CloudWatch Logs ............................................................................................... 134
Amazon CloudWatch Events ............................................................................................. 134
AWS CodeCommit .......................................................................................................... 134
Scheduled Events (powered by Amazon CloudWatch Events) ................................................ 135
AWS Cong ................................................................................................................... 135
Amazon Alexa ................................................................................................................ 135
Amazon Lex ................................................................................................................... 136
Amazon API Gateway ...................................................................................................... 136
Other Event Sources: Invoking a Lambda Function On Demand ............................................ 136

iii
AWS Lambda Developer Guide

Sample Event Data ......................................................................................................... 136


Deploying Lambda-based Applications ...................................................................................... 144
Deploying Serverless Applications Using AWS CloudFormation ............................................. 144
Using the AWS Serverless Application Model (AWS SAM) ..................................................... 145
Create Your Own Serverless Application ............................................................................ 149
Automating Deployment of Lambda-based Applications ...................................................... 152
Test Your Serverless Applications Locally Using SAM Local (Public Beta) ......................................... 157
Supported Runtimes ....................................................................................................... 158
Requirements for Using SAM Local ................................................................................... 159
Getting Started Using SAM Local ...................................................................................... 159
Troubleshooting Lambda-Based Applications ............................................................................. 164
Tracing Lambda-Based Applications with AWS X-Ray ........................................................... 164
Setting Up AWS X-Ray with Lambda ................................................................................. 165
Lambda on the AWS X-Ray Service Map ............................................................................ 166
Lambda as an AWS X-Ray Trace ....................................................................................... 167
Emitting Trace Segments from a Lambda Function ............................................................. 168
The AWS X-Ray Daemon in the Lambda Environment .......................................................... 172
Using Environment Variables to Communicate with AWS X-Ray ............................................ 173
Lambda Traces in the AWS X-Ray Console: Examples ........................................................... 173
How It Works ................................................................................................................................. 175
How Does AWS Lambda Run My Code? The Container Model ....................................................... 175
Concurrent Executions ............................................................................................................. 176
Concurrent Execution Request Rate ................................................................................... 176
Concurrent Executions Limit ............................................................................................. 176
Scaling .......................................................................................................................... 177
Retries on Errors .................................................................................................................... 178
Permissions Model .................................................................................................................. 179
Manage Permissions: Using an IAM Role (Execution Role) ..................................................... 180
Manage Permissions: Using a Lambda Function Policy ......................................................... 181
Suggested Reading ......................................................................................................... 181
Execution Environment ............................................................................................................ 182
Environment Variables Available to Lambda Functions ........................................................ 182
Suggested Reading ......................................................................................................... 184
Getting Started .............................................................................................................................. 185
Step 1: Set Up an AWS Account and the AWS CLI ....................................................................... 185
Step 1.1: Set Up an Account ............................................................................................ 185
Step 1.2: Set Up the AWS CLI .......................................................................................... 188
Step 2: Create a HelloWorld Lambda Function and Explore the Console ......................................... 188
Preparing for the Getting Started ..................................................................................... 189
Step 2.1: Create a Hello World Lambda Function ................................................................ 189
Step 2.2: Invoke the Lambda Function .............................................................................. 192
Step 2.3: (Optional) Create a Lambda Function Authored in Java .......................................... 195
Step 2.4: (Optional) Create a Lambda Function Authored in C# ............................................. 196
Step 3: Create a Simple Microservice using Lambda and API Gateway ............................................ 197
Next Step ...................................................................................................................... 197
Step 3.1: Create an API Using Amazon API Gateway ............................................................ 197
Step 3.2: Test Sending an HTTPS Request ......................................................................... 198
Step 3.3: (Optional) Try Other Blueprints ........................................................................... 198
What's Next? .................................................................................................................. 199
Use Cases ...................................................................................................................................... 200
Amazon S3 ............................................................................................................................ 200
Tutorial ......................................................................................................................... 202
Kinesis ................................................................................................................................... 217
Tutorial ......................................................................................................................... 218
Amazon DynamoDB ................................................................................................................ 227
Tutorial ......................................................................................................................... 228
AWS CloudTrail ...................................................................................................................... 238

iv
AWS Lambda Developer Guide

Tutorial ......................................................................................................................... 239


Amazon SNS .......................................................................................................................... 253
Tutorial ......................................................................................................................... 253
Amazon API Gateway .............................................................................................................. 258
Using AWS Lambda with Amazon API Gateway (On-Demand Over HTTPS) ............................. 259
Mobile Backend (Android) ........................................................................................................ 272
Tutorial ......................................................................................................................... 273
Scheduled Events ................................................................................................................... 284
Tutorial ......................................................................................................................... 285
Custom User Applications ........................................................................................................ 290
Tutorial ......................................................................................................................... 291
AWS Lambda@Edge ........................................................................................................................ 299
How You Create Lambda Functions for Lambda@Edge ................................................................ 300
Setting IAM Permissions and Roles for Lambda@Edge ................................................................ 301
Creating a Lambda@Edge Function and Creating a Trigger for a CloudFront Event .......................... 303
Adding Triggers for a Lambda@Edge Function (AWS Lambda Console) .......................................... 304
Writing Functions for Lambda@Edge ........................................................................................ 306
Example: A/B Testing ...................................................................................................... 306
Example: HTTP Redirect .................................................................................................. 307
Editing a Lambda Function for Lambda@Edge ........................................................................... 307
Testing and Debugging ........................................................................................................... 309
Lambda@Edge Limits .............................................................................................................. 309
API Logging with AWS CloudTrail ..................................................................................................... 310
AWS Lambda Information in CloudTrail ..................................................................................... 310
Understanding AWS Lambda Log File Entries ............................................................................. 311
Best Practices ................................................................................................................................. 313
Function Code ........................................................................................................................ 313
Function Conguration ............................................................................................................ 314
Alarming and Metrics .............................................................................................................. 314
Stream Event Invokes .............................................................................................................. 315
Async Invokes ........................................................................................................................ 315
Lambda VPC .......................................................................................................................... 315
Limits ............................................................................................................................................ 317
List of AWS Lambda Limits ...................................................................................................... 317
AWS Lambda Limit Errors ........................................................................................................ 318
Authentication and Access Control .................................................................................................... 320
Authentication ....................................................................................................................... 320
Access Control ........................................................................................................................ 321
Overview of Managing Access .................................................................................................. 322
AWS Lambda Resources and Operations ............................................................................ 322
Understanding Resource Ownership .................................................................................. 322
Managing Access to Resources ......................................................................................... 323
Specifying Policy Elements: Actions, Eects, Resources, and Principals ................................... 325
Specifying Conditions in a Policy ...................................................................................... 325
Using Identity-Based Policies (IAM Policies) ................................................................................ 326
Permissions Required to Use the AWS Lambda Console ....................................................... 327
AWS Managed (Predened) Policies for AWS Lambda .......................................................... 327
Customer Managed Policy Examples ................................................................................. 327
Console Permissions ........................................................................................................ 331
Using Resource-Based Policies (Lambda Function Policies) ........................................................... 338
Allow Amazon S3 to Invoke a Lambda Function ................................................................. 339
Allow Amazon API Gateway to Invoke a Lambda Function .................................................... 340
Cross-Account Scenario ................................................................................................... 340
Retrieve a Lambda Function Policy ................................................................................... 341
Remove Permissions ....................................................................................................... 341
Working with Lambda Function Versioning, Aliases, and Permissions ..................................... 341
Lambda API Permissions Reference ........................................................................................... 341

v
AWS Lambda Developer Guide

Policy Templates .................................................................................................................... 344


Basic: 'Basic Lambda Permissions' ..................................................................................... 344
VPCAccess: 'Lambda VPC Access Permissions' ..................................................................... 345
Kinesis: 'Lambda Kinesis stream poller permissions' ............................................................. 345
DynamoDB: 'Lambda DynamoDB stream poller permissions' ................................................. 346
Edge: 'Basic Edge Lambda permissions' ............................................................................. 346
RedrivePolicySNS: Dead letter queue SNS permissions ....................................................... 346
RedrivePolicySQS: 'Dead letter queue SQS permissions' ....................................................... 347
.................................................................................................................................... 347
CloudFormation: 'CloudFormation stack read-only permissions' ............................................. 347
AMI: 'AMI read-only permissions' ...................................................................................... 347
KMS: 'KMS decryption permissions' ................................................................................... 348
S3: 'S3 object read-only permissions' ................................................................................ 348
Elasticsearch: 'Elasticsearch permissions' ............................................................................ 348
SES: 'SES bounce permissions' .......................................................................................... 348
TestHarness: 'Test Harness permissions' ............................................................................. 349
Microservice: 'Simple Microservice permissions' ................................................................... 349
VPN: 'VPN Connection Monitor permissions' ....................................................................... 349
SQS: 'SQS Poller permissions' ........................................................................................... 350
IoTButton: 'AWS IoT Button permissions' ........................................................................... 350
RekognitionNoDataAccess:'Amazon Rekognition no data permissions' .................................... 350
RekognitionReadOnlyAccess: 'Amazon Rekognition read-only permissions' .............................. 351
RekognitionWriteOnlyAccess: 'Amazon Rekognition write-only permissions' ............................ 351
API Reference ................................................................................................................................. 352
Actions .................................................................................................................................. 352
AddPermission ............................................................................................................... 354
CreateAlias ..................................................................................................................... 358
CreateEventSourceMapping .............................................................................................. 361
CreateFunction ............................................................................................................... 366
DeleteAlias ..................................................................................................................... 374
DeleteEventSourceMapping .............................................................................................. 376
DeleteFunction ............................................................................................................... 379
GetAccountSettings ......................................................................................................... 382
GetAlias ......................................................................................................................... 384
GetEventSourceMapping .................................................................................................. 387
GetFunction ................................................................................................................... 390
GetFunctionConguration ................................................................................................ 393
GetPolicy ....................................................................................................................... 398
Invoke ........................................................................................................................... 401
InvokeAsync ................................................................................................................... 406
ListAliases ...................................................................................................................... 408
ListEventSourceMappings ................................................................................................ 411
ListFunctions .................................................................................................................. 414
ListTags ......................................................................................................................... 417
ListVersionsByFunction .................................................................................................... 419
PublishVersion ................................................................................................................ 422
RemovePermission .......................................................................................................... 427
TagResource ................................................................................................................... 429
UntagResource ............................................................................................................... 431
UpdateAlias ................................................................................................................... 433
UpdateEventSourceMapping ............................................................................................ 436
UpdateFunctionCode ....................................................................................................... 440
UpdateFunctionConguration ........................................................................................... 446
Data Types ............................................................................................................................ 453
AccountLimit .................................................................................................................. 454
AccountUsage ................................................................................................................ 455
AliasConguration .......................................................................................................... 456

vi
AWS Lambda Developer Guide

DeadLetterCong ........................................................................................................... 458


Environment .................................................................................................................. 459
EnvironmentError ........................................................................................................... 460
EnvironmentResponse ..................................................................................................... 461
EventSourceMappingConguration ................................................................................... 462
FunctionCode ................................................................................................................. 464
FunctionCodeLocation ..................................................................................................... 465
FunctionConguration ..................................................................................................... 466
TracingCong ................................................................................................................. 470
TracingCongResponse .................................................................................................... 471
VpcCong ...................................................................................................................... 472
VpcCongResponse ......................................................................................................... 473
Document History .......................................................................................................................... 474
AWS Glossary ................................................................................................................................. 480

vii
AWS Lambda Developer Guide
When should I Use Lambda?

What Is AWS Lambda?

AWS Lambda is a compute service that lets you run code without provisioning or managing servers. AWS
Lambda executes your code only when needed and scales automatically, from a few requests per day
to thousands per second. You pay only for the compute time you consume - there is no charge when
your code is not running. With AWS Lambda, you can run code for virtually any type of application
or backend service - all with zero administration. AWS Lambda runs your code on a high-availability
compute infrastructure and performs all of the administration of the compute resources, including server
and operating system maintenance, capacity provisioning and automatic scaling, code monitoring and
logging. All you need to do is supply your code in one of the languages that AWS Lambda supports
(currently Node.js, Java, C# and Python).

You can use AWS Lambda to run your code in response to events, such as changes to data in an Amazon
S3 bucket or an Amazon DynamoDB table; to run your code in response to HTTP requests using Amazon
API Gateway; or invoke your code using API calls made using AWS SDKs. With these capabilities, you
can use Lambda to easily build data processing triggers for AWS services like Amazon S3 and Amazon
DynamoDB process streaming data stored in Kinesis, or create your own back end that operates at AWS
scale, performance, and security.

You can also build serverless applications composed of functions that are triggered by events and
automatically deploy them using AWS CodePipeline and AWS CodeBuild. For more information, see
Deploying Lambda-based Applications (p. 144).

For more information about the AWS Lambda execution environment, see Lambda Execution
Environment and Available Libraries (p. 182). For information about how AWS Lambda determines
compute resources required to execute your code, see Compute Requirements Lambda Function
Conguration (p. 3).

When Should I Use AWS Lambda?


AWS Lambda is an ideal compute platform for many application scenarios, provided that you can write
your application code in languages supported by AWS Lambda (that is, Node.js, Java, C# and Python),
and run within the AWS Lambda standard runtime environment and resources provided by Lambda.

When using AWS Lambda, you are responsible only for your code. AWS Lambda manages the compute
eet that oers a balance of memory, CPU, network, and other resources. This is in exchange for
exibility, which means you cannot log in to compute instances, or customize the operating system or
language runtime. These constraints enable AWS Lambda to perform operational and administrative

1
AWS Lambda Developer Guide
Are You a First-time User of AWS Lambda?

activities on your behalf, including provisioning capacity, monitoring eet health, applying security
patches, deploying your code, and monitoring and logging your Lambda functions.

If you need to manage your own compute resources, Amazon Web Services also oers other compute
services to meet your needs.

Amazon Elastic Compute Cloud (Amazon EC2) service oers exibility and a wide range of EC2
instance types to choose from. It gives you the option to customize operating systems, network and
security settings, and the entire software stack, but you are responsible for provisioning capacity,
monitoring eet health and performance, and using Availability Zones for fault tolerance.
Elastic Beanstalk oers an easy-to-use service for deploying and scaling applications onto Amazon EC2
in which you retain ownership and full control over the underlying EC2 instances.

Are You a First-time User of AWS Lambda?


If you are a rst-time user of AWS Lambda, we recommend that you read the following sections in order:

1. Read the product overview and watch the introductory video to understand sample use cases.
These resources are available on the AWS Lambda webpage.

Read the "How It Works" section of this guide. This section introduces various AWS Lambda
components you work with to create an end-to-end experience. For more information, see How It
Works (p. 175).
2. Review the Lambda Functions section of this guide. To understand the programming model and
deployment options for a Lambda function there are core concepts you should be familiar with. This
section explains these concepts and provides details of how they work in dierent languages that you
can use to author your Lambda function code. For more information, see Lambda Functions (p. 3).
3. Try the console-based Getting Started exercise. The exercise provides instructions for you to
create and test your rst Lambda function using the console. You also learn about the console
provided blueprints to quickly create your Lambda functions. For more information, see Getting
Started (p. 185).
4. Read the "Building Applications with AWS Lambda" section of this guide. This section introduces
various AWS Lambda components you work with to create an end-to-end experience. For more
information, see Building Applications with AWS Lambda (p. 123).

Beyond the Getting Started exercise, you can explore the various use cases, each of which is provided
with a tutorial that walks you through an example scenario. Depending on your application needs (for
example, whether you want event driven Lambda function invocation or on-demand invocation), you can
follow specic tutorials that meet your specic needs. For more information, see Use Cases (p. 200).

The following topics provide additional information about AWS Lambda:

AWS Lambda Function Versioning and Aliases (p. 75)


Troubleshooting and Monitoring AWS Lambda Functions with Amazon CloudWatch (p. 114)
Best Practices for Working with AWS Lambda Functions (p. 313)
AWS Lambda Limits (p. 317)

2
AWS Lambda Developer Guide
Compute Requirements Lambda Function Conguration

Lambda Functions

After you package up your custom code, including any dependencies, and upload it to AWS Lambda, you
have created a Lambda function.

If you are new to AWS Lambda, you might ask: what type of code can I run as a Lambda function? How
does AWS Lambda execute my code? How does AWS Lambda know the amount of memory and CPU
requirements needed to run my Lambda code? The following sections provide an overview of how a
Lambda function works.

Depending on your scenario, you can build applications where you use the AWS Lambda service to run all
or parts of your application code. For more information, see Building Lambda Functions (p. 5). How It
Works (p. 175) provides examples that illustrate how to create a Lambda function for specic scenarios.

The sections in this topic provide the following introductory information about Lambda functions:

Topics
Compute Requirements Lambda Function Conguration (p. 3)
Invocation Types (p. 4)
Introduction: Building Lambda Functions (p. 5)
Conguring a Lambda Function to Access Resources in an Amazon VPC (p. 103)
Troubleshooting and Monitoring AWS Lambda Functions with Amazon CloudWatch (p. 114)

Compute Requirements Lambda Function


Conguration
A Lambda function consists of code and any associated dependencies. In addition, a Lambda
function also has conguration information associated with it. Initially, you specify the conguration
information when you create a Lambda function. Lambda provides an API for you to update some of the
conguration data. Lambda function conguration information includes the following key elements:

Compute resources that you need You only specify the amount of memory you want to allocate for
your Lambda function. AWS Lambda allocates CPU power proportional to the memory by using the
same ratio as a general purpose Amazon EC2 instance type, such as an M3 type. For example, if you

3
AWS Lambda Developer Guide
Invocation Types

allocate 256 MB memory, your Lambda function will receive twice the CPU share than if you allocated
only 128 MB.

You can update the conguration and request additional memory in 64 MB increments from 128MB to
1536 MB. For information about relevant limits, see AWS Lambda Limits (p. 317).

To change the amount of memory your Lambda function requires, do the following:
1. Sign in to the AWS Management Console and navigate to the AWS Lambda console.
2. Choose the function whose memory size you wish to change.
3. Click the Conguration tab and then expand Advanced settings.
4. In the Memory (MB) list, choose your desired amount.

Optionally, you can update the memory size of your functions using the following AWS CLI command
(using valid 64 MB increments):

$ aws lambda update-function-configuration \


--function-name your function name \
--region region where your function resides \
--memory-size memory amount \
--profile adminuser

For information on setting up and using the AWS CLI, see Step 1: Set Up an AWS Account and the AWS
CLI (p. 185).


Maximum execution time (timeout) You pay for the AWS resources that are used to run your
Lambda function. To prevent your Lambda function from running indenitely, you specify a timeout.
When the specied timeout is reached, AWS Lambda terminates your Lambda function.
Important
Avoid using recursive code in your Lambda function, wherein the function automatically calls
itself until some arbitrary criteria is met. This could lead to unintended volume of function
invocations and escalated costs.


IAM role (execution role) This is the role that AWS Lambda assumes when it executes the Lambda
function on your behalf.


Handler name The handler refers to the method in your code where AWS Lambda begins execution.
AWS Lambda passes any event information, which triggered the invocation, as a parameter to the
handler method.

Invocation Types
AWS Lambda supports synchronous and asynchronous invocation of a Lambda function. You can control
the invocation type only when you invoke a Lambda function (referred to as on-demand invocation). The
following examples illustrate on-demand invocations:

Your custom application invokes a Lambda function.


You manually invoke a Lambda function (for example, using the AWS CLI) for testing purposes.

4
AWS Lambda Developer Guide
Building Lambda Functions

In both cases, you invoke your Lambda function using the Invoke (p. 401) operation, and you can
specify the invocation type as synchronous or asynchronous.

However, when you are using AWS services as event sources, the invocation type is predetermined for
each of these services. You don't have any control over the invocation type that these event sources use
when they invoke your Lambda function. For example, Amazon S3 always invokes a Lambda function
asynchronously and Amazon Cognito always invokes a Lambda function synchronously. For stream-based
AWS services (Amazon Kinesis Streams and Amazon DynamoDB Streams), AWS Lambda polls the stream
and invokes your Lambda function synchronously.

Introduction: Building Lambda Functions


You upload your application code in the form of one or more Lambda functions to AWS Lambda,
a compute service, and the service can run the code on your behalf. AWS Lambda takes care of
provisioning and managing the servers to run the code upon invocation.

Typically, the lifecycle for an AWS Lambda-based application includes authoring code, deploying code to
AWS Lambda, and then monitoring and troubleshooting. The following are general questions that come
up in each of these lifecycle phases:

Authoring code for your Lambda function What languages are supported? Is there a programming
model that I need to follow? How do I package my code and dependencies for uploading to AWS
Lambda? What tools are available?


Uploading code and creating Lambda functions How do I upload my code package to AWS
Lambda? How do I tell AWS Lambda where to begin executing my code? How do I specify compute
requirements like memory and timeout?


Monitoring and troubleshooting For my Lambda function that is in production, what metrics are
available? If there are any failures, how do I get logs or troubleshoot issues?

The following sections provide introductory information and the Example section at the end provides
working examples for you to explore.
Note
This topic provides an introductory overview of how you develop AWS Lambda-based
applications. The How It Works (p. 175) section describes the specics about Lambda
functions, event sources, and how AWS Lambda executes your Lambda functions.

Authoring Code for Your Lambda Function


You can author your Lambda function code in the languages that are supported by AWS Lambda. For a
list of supported languages, see Lambda Execution Environment and Available Libraries (p. 182). There
are tools for authoring code, such as the AWS Lambda console, Eclipse IDE, and Visual Studio IDE. But the
available tools and options depend on the following:

Language you choose to write your Lambda function code.


Libraries that you use in your code. AWS Lambda runtime provides some of the libraries and you must
upload any additional libraries that you use.

The following table lists languages, and the available tools and options that you can use.

5
AWS Lambda Developer Guide
Deploying Code and Creating a Lambda Function

Language Tools and Options for Authoring Code More Info

Node.js AWS Lambda console You can use the console if the
Visual Studio, with IDE plug-in (see languages you choose do not require
AWS Lambda Support in Visual compilation, the code is saved in a
Studio) single le, and it does not depend on
any libraries.
Your own authoring environment

Java Eclipse, with AWS Toolkit for Eclipse The AWS Toolkit also creates the
(see Using AWS Lambda with the deployment package, which is
AWS Toolkit for Eclipse) explained in Deploying Code and
Your own authoring environment Creating a Lambda Function (p. 6).

C# Visual Studio, with IDE plug-in (see The AWS Toolkit also creates the
AWS Lambda Support in Visual deployment package, which is
Studio) explained in Deploying Code and
.NET Core (see .NET Core installation Creating a Lambda Function (p. 6).
guide)
Your own authoring environment

Python AWS Lambda console You can use the console if the
Your own authoring environment languages you choose do not require
compilation, the code is saved in a
single le, and it does not depend on
any libraries.

In addition, regardless of the language you choose, there is a pattern to writing Lambda function code.
For example, how you write the handler method of your Lambda function (that is, the method that
AWS Lambda rst calls when it begins executing the code), how you pass events to the handler, what
statements you can use in your code to generate logs in CloudWatch Logs, how to interact with AWS
Lambda runtime and obtain information such as the time remaining before timeout, and how to handle
exceptions. The Programming Model (p. 8) section provides information for each of the supported
languages.
Note
After you familiarize yourself with AWS Lambda, see the Use Cases (p. 200), which provide
step-by-step instructions to help you explore the end-to-end experience.

Deploying Code and Creating a Lambda Function


To create a Lambda function, you rst package your code and dependencies in a deployment package.
Then, you upload the deployment package to AWS Lambda to create your Lambda function.

Topics
Creating a Deployment Package Organizing Code and Dependencies (p. 6)
Uploading a Deployment Package Creating a Lambda Function (p. 7)
Testing a Lambda Function (p. 7)

Creating a Deployment Package Organizing Code and


Dependencies
You must rst organize your code and dependencies in certain ways and create a deployment package.
Instructions to create a deployment package vary depending on the language you choose to author

6
AWS Lambda Developer Guide
Monitoring and Troubleshooting

the code. For example, you can use build plugins such as Jenkins (for Node.js and Python), and Maven
(for Java) to create the deployment packages. For more information, see Creating a Deployment
Package (p. 60).

When you create Lambda functions using the console, the console creates the deployment package for
you, and then uploads it to create your Lambda function.

Uploading a Deployment Package Creating a Lambda Function


AWS Lambda provides the CreateFunction (p. 366) operation, which is what you use to create a Lambda
function. You can use the AWS Lambda console, AWS CLI, and AWS SDKs to create a Lambda function.
Internally, all of these interfaces call the CreateFunction operation.

In addition to providing your deployment package, you can provide conguration information when you
create your Lambda function including the compute requirements of your Lambda function, the name
of the handler method in your Lambda function, and the runtime, which depends on the language you
chose to author your code. For more information, see Lambda Functions (p. 3).
Note
This section provides an introductory overview of developing AWS Lambda-based applications.
How It Works (p. 175) describes specics about Lambda functions, event sources, and how
AWS Lambda executes your Lambda functions.

Testing a Lambda Function


If your Lambda function is designed to process events of a specic type, you can use sample event data
to test your Lambda function using one of the following methods:

Test your Lambda function in the console.


Test your Lambda function using the AWS CLI. You can use the Invoke method to invoke your Lambda
function and pass in sample event data.

The console provides sample event data. The same data is also provided in the Sample Events Published
by Event Sources (p. 136) topic, which you can use in the AWS CLI to invoke your Lambda function.

Monitoring and Troubleshooting


After your Lambda function is in production, AWS Lambda automatically monitors functions on your
behalf, reporting metrics through Amazon CloudWatch. For more information, see Accessing Amazon
CloudWatch Metrics for AWS Lambda (p. 116).

To help you troubleshoot failures in a function, Lambda logs all requests handled by your function
and also automatically stores logs that your code generates in Amazon CloudWatch Logs. For more
information, see Accessing Amazon CloudWatch Logs for AWS Lambda (p. 118).

AWS Lambda-Based Application Examples


This guide provides several examples with step-by-step instructions. If you are new to AWS Lambda, we
recommend you try the following exercises:

Getting Started (p. 185) The Getting Started exercise provides a console-based experience. The
sample code is authored in Python. You can edit the code in the console, upload it to AWS Lambda,
and test it using sample event data provided in the console.


Use Cases (p. 200) If you cannot author your code using the console, you must create your own
deployment packages and use the AWS CLI (or SDKs) to create your Lambda function. For more

7
AWS Lambda Developer Guide
Related Topics

information, see Authoring Code for Your Lambda Function (p. 5). Most examples in the Uses
Cases section use the AWS CLI. If you are new to AWS Lambda, we recommend that you try one of
these exercises.

Related Topics
The following topics provide additional information.

Programming Model (p. 8)

Creating a Deployment Package (p. 60)

AWS Lambda Function Versioning and Aliases (p. 75)

Troubleshooting and Monitoring AWS Lambda Functions with Amazon CloudWatch (p. 114)

Programming Model
You write code for your Lambda function in one of the languages AWS Lambda supports. Regardless of
the language you choose, there is a common pattern to writing code for a Lambda function that includes
the following core concepts:

Handler Handler is the function AWS Lambda calls to start execution of your Lambda function. You
identify the handler when you create your Lambda function. When a Lambda function is invoked, AWS
Lambda starts executing your code by calling the handler function. AWS Lambda passes any event
data to this handler as the rst parameter. Your handler should process the incoming event data and
may invoke any other functions/methods in your code.


The context object and how it interacts with Lambda at runtime AWS Lambda also passes a
context object to the handler function, as the second parameter. Via this context object your code can
interact with AWS Lambda. For example, your code can nd the execution time remaining before AWS
Lambda terminates your Lambda function.

In addition, for languages such as Node.js, there is an asynchronous platform that uses callbacks. AWS
Lambda provides additional methods on this context object. You use these context object methods to
tell AWS Lambda to terminate your Lambda function and optionally return values to the caller.


Logging Your Lambda function can contain logging statements. AWS Lambda writes these logs to
CloudWatch Logs. Specic language statements generate log entries, depending on the language you
use to author your Lambda function code.


Exceptions Your Lambda function needs to communicate the result of the function execution to
AWS Lambda. Depending on the language you author your Lambda function code, there are dierent
ways to end a request successfully or to notify AWS Lambda an error occurred during execution. If you
invoke the function synchronously, then AWS Lambda forwards the result back to the client.

Note
Your Lambda function code must be written in a stateless style, and have no anity with the
underlying compute infrastructure. Your code should expect local le system access, child
processes, and similar artifacts to be limited to the lifetime of the request. Persistent state

8
AWS Lambda Developer Guide
Programming Model

should be stored in Amazon S3, Amazon DynamoDB, or another cloud storage service.Requiring
functions to be stateless enables AWS Lambda to launch as many copies of a function as needed
to scale to the incoming rate of events and requests. These functions may not always run on the
same compute instance from request to request, and a given instance of your Lambda function
may be used more than once by AWS Lambda.

The following language specic topics provide detail information:

Programming Model (Node.js) (p. 9)


Programming Model for Authoring Lambda Functions in Java (p. 24)
Programming Model for Authoring Lambda Functions in C# (p. 50)
Programming Model for Authoring Lambda Functions in Python (p. 41)

Programming Model (Node.js)


AWS Lambda currently supports the following Node.js runtimes:

Node.js runtime v6.10 (runtime = nodejs6.10)


Node.js runtime v4.3 (runtime = nodejs4.3)
Node.js runtime v0.10.42 (runtime = nodejs)
Important
Node v0.10.42 is currently marked as deprecated. You must migrate existing functions to
the newer Node.js runtime versions available on AWS Lambda (nodejs4.3 or nodejs6.10) as
soon as possible. You can request a one-time extension until June 30, 2017, by going to
the Lambda console and following the instructions provided. Failure to migrate or get
extension will result in any invocations of functions written in the Node v0.10.42 runtime
returning an invalid parameter value error. Note that you will have to follow this procedure
for each region that contains functions written in the Node v0.10.42 runtime. For information
about programming model dierences in the v0.10.42 runtime, see Using the Earlier Node.js
Runtime v0.10.42 (p. 18).

When you create a Lambda function, you specify the runtime that you want to use. For more
information, see runtime parameter of CreateFunction (p. 366).

The following sections explain how common programming patterns and core concepts apply when
authoring Lambda function code in Node.js. The programming model described in the following sections
apply to both versions, except where indicated.

Topics
Lambda Function Handler (Node.js) (p. 9)
The Context Object (Node.js) (p. 12)
Logging (Node.js) (p. 15)
Function Errors (Node.js) (p. 16)
Using the Earlier Node.js Runtime v0.10.42 (p. 18)

Lambda Function Handler (Node.js)


At the time you create a Lambda function you specify a handler, a function in your code, that AWS
Lambda can invoke when the service executes your code. Use the following general syntax when creating
a handler function in Node.js.

exports.myHandler = function(event, context,) {

9
AWS Lambda Developer Guide
Programming Model

...
}

The callback parameter is optional, depending on whether you want to return information to the caller.

exports.myHandler = function(event, context, callback) {


...

// Use callback() and return information to the caller.


}

In the syntax, note the following:

event AWS Lambda uses this parameter to pass in event data to the handler.
context AWS Lambda uses this parameter to provide your handler the runtime information of the
Lambda function that is executing. For more information, see The Context Object (Node.js) (p. 12).
callback You can use the optional callback to return information to the caller, otherwise return
value is null. For more information, see Using the Callback Parameter (p. 11).
Note
The callback is supported only in the Node.js runtimes v6.10 and v4.3. If you are using
runtime v0.10.42, you need to use the context methods (done, succeed, and fail) to properly
terminate the Lambda function. For information, see Using the Earlier Node.js Runtime
v0.10.42 (p. 18).
myHandler This is the name of the function AWS Lambda invokes. You export this so it is visible
to AWS Lambda. Suppose you save this code as helloworld.js. Then, helloworld.myHandler is the
handler. For more information, see handler in CreateFunction (p. 366).
Ifyou used the RequestResponseinvocation type (synchronous execution), AWS Lambda returns
the result of the Node.js function call to the client invoking the Lambda function (in the HTTP
response to the invocation request, serialized into JSON). For example, AWS Lambda console uses
theRequestResponseinvocation type, so when you test invoke the function using the console, the
console will display the return value.

If the handler does not return anything, AWS Lambda returns null.
Ifyou used the Eventinvocation type (asynchronous execution), the value is discarded.

Example

Consider the following Node.js example code.

exports.myHandler = function(event, context, callback) {


console.log("value1 = " + event.key1);
console.log("value2 = " + event.key2);
callback(null, "some success message");
// or
// callback("some error type");
}

This example has one function, which is also the handler. In the function, the console.log() statements
log some of the incoming event data to CloudWatch Logs. When the callback is called, the Lambda
function exits only after the Node.js event loop is empty (the Node.js event loop is not the same as the
event that was passed as a parameter).
Note
If you are using runtime v0.10.42, you need to use the context methods (done, succeed, and fail)
to properly terminate the Lambda function. For more information, see Using the Earlier Node.js
Runtime v0.10.42 (p. 18).

10
AWS Lambda Developer Guide
Programming Model

To upload and test this code as a Lambda function (console)

1. In the console, create a Lambda function using the following information:

Use the hello-world blueprint.


We recommend specifying nodejs6.10 as the runtime but you can also select nodejs4.3. The code
samples provided will work for either version.
In Handler, replace index.handlerwith exports.myHandler.

For instructions to create a Lambda function using the console, see Step 2.1: Create a Hello World
Lambda Function (p. 189).
2. Replace the template code with the code provided in this section and create the function.
3. Test the Lambda function using the Sample event template called Hello Worldprovided in the
Lambda console. For instructions on how to do this, see Step 2.2: Invoke the Lambda Function
Manually and Verify Results, Logs, and Metrics (p. 192).

Using the Callback Parameter


The Node.js runtimes v4.3 and v6.10 support the optional callback parameter. You can use it to
explicitly return information back to the caller. The general syntax is:

callback(Error error, Object result);

Where:

error is an optional parameter that you can use to provide results of the failed Lambda function
execution. When a Lambda function succeeds, you can pass null as the rst parameter.
result is an optional parameter that you can use to provide the result of a successful function
execution. The result provided must be JSON.stringify compatible. If an error is provided, this
parameter is ignored.

Note
Using the callback parameter is optional. If you don't use the optional callback parameter, the
behavior is same as if you called the callback() without any parameters. You can specify the
callback in your code to return information to the caller.

If you don't use callback in your code, AWS Lambda will call it implicitly and the return value is null.

When the callback is called (explicitly or implicitly), AWS Lambda continues the Lambda function
invocation until the Node.js event loop is empty.

The following are example callbacks:

callback(); // Indicates success but no information returned to the caller.


callback(null); // Indicates success but no information returned to the caller.
callback(null, "success"); // Indicates success with information returned to the caller.
callback(error); // Indicates error with error information returned to the caller.

AWS Lambda treats any non-null value for the error parameter as a handled exception.

Note the following:

Regardless of the invocation type specied at the time of the Lambda function invocation (see
Invoke (p. 401)), the callback method automatically logs the string representation of non-null values
of error to the Amazon CloudWatch Logs stream associated with the Lambda function.

11
AWS Lambda Developer Guide
Programming Model

If the Lambda function was invoked synchronously (using the RequestResponse invocation type), the
callback returns a response body as follows:
If error is null, the response body is set to the string representation of result.
If the error is not null, the error value will be populated in the response body.

Note
When the callback(error, null) (and callback(error)) is called, Lambda will log the rst
256 KB of the error object. For a larger error object, AWS Lambda truncates the log and displays
the text Truncated by Lambda next to the error object.

The Context Object (Node.js)


While a Lambda function is executing, it can interact with AWS Lambda to get useful runtime
information such as:

How much time is remaining before AWS Lambda terminates your Lambda function (timeout is one of
the Lambda function conguration properties).
The CloudWatch log group and log stream associated with the Lambda function that is executing.
The AWS request ID returned to the client that invoked the Lambda function. You can use the request
ID for any follow up inquiry with AWS support.
If the Lambda function is invoked through AWS Mobile SDK, you can learn more about the mobile
application calling the Lambda function.

AWS Lambda provides this information via the context object that the service passes as the second
parameter to your Lambda function handler. For more information, see Lambda Function Handler
(Node.js) (p. 9).

The following sections provide an example Lambda function that uses the context object, and then lists
all of the available methods and attributes.

Example

Consider the following Node.js example. The handler receives runtime information via a context
parameter.

console.log('Loading function');

exports.handler = function(event, context, callback) {


//console.log('Received event:', JSON.stringify(event, null, 2));
console.log('value1 =', event.key1);
console.log('value2 =', event.key2);
console.log('value3 =', event.key3);
console.log('remaining time =', context.getRemainingTimeInMillis());
console.log('functionName =', context.functionName);
console.log('AWSrequestID =', context.awsRequestId);
console.log('logGroupName =', context.logGroupName);
console.log('logStreamName =', context.logStreamName);
console.log('clientContext =', context.clientContext);
if (typeof context.identity !== 'undefined') {
console.log('Cognito
identity ID =', context.identity.cognitoIdentityId);
}
callback(null, event.key1); // Echo back the first key value
// or
// callback("some error type");
};

12
AWS Lambda Developer Guide
Programming Model

The handler code in this example logs some of the runtime information of the Lambda function to
CloudWatch. If you invoke the function using the Lambda console, the console displays the logs in the
Log output section. You can create a Lambda function using this code and test it using the console.

To test this code in the AWS Lambda console

1. In the console, create a Lambda function using the hello-world blueprint. In runtime, choose
nodejs6.10. For instructions on how to do this, see Step 2.1: Create a Hello World Lambda
Function (p. 189).
2. Test the function, and then you can also update the code to get more context information.

The Context Object Methods (Node.js)

The context object provides the following methods.

context.getRemainingTimeInMillis()

Returns the approximate remaining execution time (before timeout occurs) of the Lambda function
that is currently executing. The timeout is one of the Lambda function conguration. When the timeout
reaches, AWS Lambda terminates your Lambda function.

You can use this method to check the remaining time during your function execution and take
appropriate corrective action at run time.

The general syntax is:

context.getRemainingTimeInMillis();

The Context Object Properties (Node.js)

The context object provides the following property that you can update:

callbackWaitsForEmptyEventLoop

The default value is true. This property is useful only to modify the default behavior of the callback.
By default, the callback will wait until the Node.js runtime event loop is empty before freezing the
process and returning the results to the caller. You can set this property to false to request AWS
Lambda to freeze the process soon after the callback is called, even if there are events in the event
loop. AWS Lambda will freeze the process, any state data and the events in the Node.js event loop
(any remaining events in the event loop processed when the Lambda function is called next and if
AWS Lambda chooses to use the frozen process). For more information about callback, see Using the
Callback Parameter (p. 11).

In addition, the context object provides the following properties that you can use obtain runtime
information:

functionName

Name of the Lambda function that is executing.


functionVersion

The Lambda function version that is executing. If an alias is used to invoke the function, then
function_version will be the version the alias points to.
invokedFunctionArn

The ARN used to invoke this function. It can be a function ARN or an alias ARN. An unqualied ARN
executes the $LATEST version and aliases execute the function version it is pointing to.

13
AWS Lambda Developer Guide
Programming Model

memoryLimitInMB

Memory limit, in MB, you congured for the Lambda function. You set the memory limit at the time
you create a Lambda function and you can change it later.
awsRequestId

AWS request ID associated with the request. This is the ID returned to the client that called the
invoke method.
Note
If AWS Lambda retries the invocation (for example, in a situation where the Lambda
function that is processing Kinesis records throws an exception), the request ID remains the
same.
logGroupName

The name of the CloudWatch log group where you can nd logs written by your Lambda function.
logStreamName

The name of the CloudWatch log group where you can nd logs written by your Lambda function.
The log stream may or may not change for each invocation of the Lambda function.

The value is null if your Lambda function is unable to create a log stream, which can happen if
the execution role that grants necessary permissions to the Lambda function does not include
permissions for the CloudWatch actions.
identity

Information about the Amazon Cognito identity provider when invoked through the AWS Mobile
SDK. It can be null.
identity.cognitoIdentityId
identity.cognitoIdentityPoolId

For more information about the exact values for a specic mobile platform, see Identity Context
in the AWS Mobile SDK for iOS Developer Guide, and Identity Context in the AWS Mobile SDK for
Android Developer Guide.
clientContext

Information about the client application and device when invoked through the AWS Mobile SDK. It
can be null. Using clientContext, you can get the following information:
clientContext.client.installation_id
clientContext.client.app_title
clientContext.client.app_version_name
clientContext.client.app_version_code
clientContext.client.app_package_name
clientContext.Custom

Custom values set by the mobile client application.


clientContext.env.platform_version
clientContext.env.platform
clientContext.env.make
clientContext.env.model
clientContext.env.locale

For more information about the exact values for a specic mobile platform, see Client Context in the
AWS Mobile SDK for iOS Developer Guide, and Client Context in the AWS Mobile SDK for Android Developer
Guide.

14
AWS Lambda Developer Guide
Programming Model

Logging (Node.js)
Your Lambda function can contain logging statements. AWS Lambda writes these logs to CloudWatch. If
you use the Lambda console to invoke your Lambda function, the console displays the same logs.

The following Node.js statements generate log entries:

console.log()
console.error()
console.warn()
console.info()

For example, consider the following Node.js code example.

console.log('Loading function');

exports.handler = function(event, context, callback) {


//console.log('Received event:', JSON.stringify(event, null, 2));
console.log('value1 =', event.key1);
console.log('value2 =', event.key2);
console.log('value3 =', event.key3);
callback(null, event.key1); // Echo back the first key value

};

The screenshot shows an example Log output section in Lambda console, you can also nd
these logs in CloudWatch. For more information, seeAccessing Amazon CloudWatch Logs for AWS
Lambda (p. 118).

The console uses the RequestResponse invocation type (synchronous invocation) when invoking the
function, therefore it gets the return value (value1) back from AWS Lambda which the console displays.

To test the preceding Node.js code in AWS Lambda console

1. In the console, create a Lambda function using the hello-world blueprint. Make sure to select the
Node.js as theruntime. For instructions on how to do this, see Step 2.1: Create a Hello World
Lambda Function (p. 189).
2. Test the Lambda function using the Sample event template called Hello Worldprovided in the
Lambda console. For instructions on how to do this, see Step 2.2: Invoke the Lambda Function
Manually and Verify Results, Logs, and Metrics (p. 192). You can also update the code and try other
logging methods and properties discussed in this section.

15
AWS Lambda Developer Guide
Programming Model

For step-by-step instructions, see Getting Started (p. 185).

Finding Logs

You can nd the logs that your Lambda function writes, as follows:

In the AWS Lambda console The Log output section in the AWS Lambda console shows the logs.
In the response header, when you invoke a Lambda function programmatically If you invoke a
Lambda function programmatically, you can add theLogType parameter to retrieve the last 4 KB of log
data that is written to CloudWatch Logs. AWS Lambda returns this log information in thex-amz-log-
resultsheader in the response. For more information, seeInvoke.

If you use AWS CLI to invoke the function, you can specify the--log-typeparameter with
valueTailto retrieve the same information.
In CloudWatch Logs To nd your logs in CloudWatch you need to know the log group name
and log stream name. You can get that information by adding the context.logGroupName, and
context.logStreamName methods in your code. When you run your Lambda function, the resulting logs
in the console or CLI will show you the log group name and log stream name.

Function Errors (Node.js)


If your Lambda function noties AWS Lambda that it failed to execute properly, Lambda will attempt to
convert the error object to a String. Consider the following example:

console.log('Loading function');

exports.handler = function(event, context, callback) {


// This example code only throws error.
var error = new Error("something is wrong");
callback(error);

};

When you invoke this Lambda function, it will notify AWS Lambda that function execution completed
with an error and passes error information to AWS Lambda. AWS Lambda returns the error information
back to the client:

{
"errorMessage": "something is wrong",
"errorType": "Error",
"stackTrace": [
"exports.handler (/var/task/index.js:10:17)"
]
}

Note that the stack trace is returned as thestackTrace JSON array of stack trace elements.

How you get the error information back depends on the invocation type that the client species at the
time of function invocation:

If a client species theRequestResponseinvocation type (that is, synchronous execution), it returns the
result to the client that made the invoke call.

For example, the console always use theRequestResponseinvocation type, so the console will display
the error in theExecution resultsection as shown:

16
AWS Lambda Developer Guide
Programming Model

The same information is also sent to CloudWatch and the Log output section shows the same logs.

If a client species the Event invocation type (that is, asynchronous execution), AWS Lambda will not
return anything. Instead, it logs the error information to CloudWatch Logs. You can also see the error
metrics in CloudWatch Metrics.

Depending on the event source, AWS Lambda may retry the failed Lambda function. For example, if
Kinesis is the event source, AWS Lambda will retry the failed invocation until the Lambda function
succeeds or the records in the stream expire. For more information on retries, see Retries on
Errors (p. 178).

To test the preceding Node.js code (console)

1. In the console, create a Lambda function using the hello-world blueprint. In runtime, choose
Node.js and, in Role, choose Basic execution role. For instructions on how to do this, see Step 2.1:
Create a Hello World Lambda Function (p. 189).
2. Replace the template code with the code provided in this section.
3. Test the Lambda function using the Sample event template called Hello Worldprovided in the
Lambda console. For instructions on how to do this, see Step 2.2: Invoke the Lambda Function
Manually and Verify Results, Logs, and Metrics (p. 192).

Function Error Handling

You can create custom error handling to raise an exception directly from your Lambda function and
handle it directly (Retry or Catch) within an AWS Step Functions State Machine. For more information,
see Handling Error Conditions Using a State Machine.

17
AWS Lambda Developer Guide
Programming Model

Consider a CreateAccount state is a task that writes a customer's details to a database using a Lambda
function.

If the task succeeds, an account is created and a welcome email is sent.


If a user tries to create an account for a username that already exists, the Lambda function raises an
error, causing the state machine to suggest a dierent username and to retry the account-creation
process.

The following code samples demonstrate how to do this. Note that custom errors in Node.js must extend
the error prototype.

exports.handler = function(event, context, callback) {


function AccountAlreadyExistsError(message) {
this.name = "AccountAlreadyExistsError";
this.message = message;
}
AccountAlreadyExistsError.prototype = new Error();

const error = new AccountAlreadyExistsError("Account is in use!");


callback(error);
};

You can congure Step Functions to catch the error using a Catch rule:

{
"StartAt": "CreateAccount",
"States": {
"CreateAccount": {
"Type": "Task",
"Resource": "arn:aws:lambda:us-east-1:123456789012:function:CreateAccount",
"Next": "SendWelcomeEmail",
"Catch": [
{
"ErrorEquals": ["AccountAlreadyExistsError"],
"Next": "SuggestAccountName"
}
]
},

}
}

At runtime, AWS Step Functions catches the error, transitioning to the SuggestAccountName state as
specied in the Next transition.
Note
The name property of the Error object must match the ErrorEquals value.

Custom error handling makes it easier to create serverless applications. This feature integrates with all
the languages supported by the Lambda Programming Model (p. 8), allowing you to design your
application in the programming languages of your choice, mixing and matching as you go.

To learn more about creating your own serverless applications using AWS Step Functions and AWS
Lambda, see AWS Step Functions.

Using the Earlier Node.js Runtime v0.10.42


As of May 2017, AWS Lambda supports Node.js 6.10 and Node.js 4.3. For information about
specifying this runtime when you create your Lambda function, see the --runtime parameter of
CreateFunction (p. 366).

18
AWS Lambda Developer Guide
Programming Model

Node v0.10.42 is currently marked as deprecated. You must migrate existing functions to the newer
Node.js runtime versions available on AWS Lambda (nodejs4.3 or nodejs6.10) as soon as possible. You
can request a one-time extension until June 30, 2017, by going to the Lambda console and following
the instructions provided. Failure to migrate or get an extension will result in any invocations of
functions written in the Node v0.10.42 runtime returning an invalid parameter value error. Note that you
will have to follow this procedure for each region that contains functions written in the Node v0.10.42
runtime. The following section highlights AWS Lambda's runtime support policy, along with behavior
unique to runtime v0.10.42 and how to migrate your existing functions to newer versions.

Topics
Runtime Support Policy (p. 19)
Transitioning Lambda Function Code to Newer Runtimes (p. 19)
The Context Methods in Node.js Runtime v0.10.42 (p. 21)

Runtime Support Policy

AWS Lambda will only deprecate runtimes that are marked as EOL (End of Life) at the end of their
maintenance window as specied in the Node LTS working group page. Versions that are marked for
EOL (like Node 0.10) will stop supporting new function-creation rst. Existing functions will continue to
work until customers have sucient time to migrate to newer versions, and we will work with individual
customers as needed. AWS Lambda will add support for additional LTS (Long Term Support) versions of
Node within a few months of the version being marked as LTS.

Transitioning Lambda Function Code to Newer Runtimes

Node v0.10.42 is currently marked as deprecated. You must migrate existing functions to the newer
Node.js runtime versions available on AWS Lambda (nodejs4.3 or nodejs6.10) as soon as possible.
You can request a one-time extension until June 30, 2017, by going to the Lambda console and
following the instructions provided. Failure to migrate or get an extension will result in any invocations
of functions written in the Node v0.10.42 runtime returning an invalid parameter error. Note that you
will have to follow this procedure for each region that contains functions written in the Node v0.10.42
runtime.

The following sections explain how to migrate your existing Lambda function code to newer runtimes:

1. Review all your existing Lambda functions and plan your migration. You can obtain your list of
functions, along with their versions and aliases, in the following way:

To list Lambda functions using a blueprint, see Listing Lambda Functions and Updating to Newer
Runtime Using the Runtime Update Blueprint (p. 20).

To list Lambda functions using the console:


a. Sign in to the AWS Management Console and open the Lambda console.
b. Choose the Runtime column. This will sort all the Lambda functions for that region by their
runtime value.
c. Open each Lambda function with a runtime value of Node.js and then choose the Conguration
tab.
d. Choose the Qualiers dropdown list.
e. Select each version and view its runtime.
f. Select each alias to view the version it points to.
g. Repeat the preceeding steps for each region as necessary.
2. For each function:
a. Update the runtime rst manually or by running the nodejs-upgrade-functions blueprint in
UPDATE mode (for more information see Listing Lambda Functions and Updating to Newer
Runtime Using the Runtime Update Blueprint (p. 20). We strongly recommend updating any

19
AWS Lambda Developer Guide
Programming Model

use of the context method and replacing it with the callback approach. For more details, see The
Context Methods in Node.js Runtime v0.10.42 (p. 21).
b. Test and verify the Lambda function passes your internal validation for its behavior. If it fails, you
may need to update your Lambda code to work in the new runtime:
For a list of changes in Node.js v6.10, see Breaking changes between v5 and v6 on GitHub.
For a list of changes in Node.js v4.3, see API changes between v0.10 and v4 on GitHub.
c. Once your function is invoked successfully, the transition is complete.
3. Review your existing functions for versions and aliases. You can obtain a list of versions for each
function using either Listing Lambda Functions and Updating to Newer Runtime Using the Lambda
Console (p. 20) or Listing Lambda Functions and Updating to Newer Runtime Using the Runtime
Update Blueprint (p. 20). For each such version:
a. Copy the code to $LATEST.
b. Repeat the process from Step 2 above.
c. Republish the code when complete as a new version.
d. Update any alias thats currently pointing to the old version to the newly published version.
e. Delete the old version.

Listing Lambda Functions and Updating the Runtime Using the CLI

You can use the ListFunctions (p. 414) command to return a list of all Lambda functions and from that
list those created in the v0.10 runtime. The following code sample demonstrates how to do that:

#!/bin/bash

for REGION in $(aws ec2 describe-regions --output text --query 'Regions[].[RegionName]' |


egrep -v 'ca-central-1|sa-east-1' | sort); do
echo "...checking $REGION"
echo " nodejs0.10 functions: "
for i in $(aws lambda list-functions --output json --query 'Functions[*].[FunctionName,
Runtime]' --region $REGION | grep -v nodejs4.3 | grep -v nodejs6.10 | grep -B1 nodejs |
grep , | sort); do
echo " -> $i"
done
done

echo "This script only accounts for the \$LATEST versions of functions. You may need to
take a closer look if you are using versioning."

For each Lambda function returned that was created using the v0.10 runtime, use the
UpdateFunctionConguration (p. 446) command and set the --runtime value to nodejs4.3 or
nodejs6.10.

Listing Lambda Functions and Updating to Newer Runtime Using the Lambda Console

Sign in to the AWS Management Console and open the Lambda console.
Choose the Runtime tab. This will sort all the Lambda functions for that region by their runtime value.
Open each Lambda function with a runtime value of node.js and then choose the Conguration tab.
Set the Runtime value to Node.js 4.3 or Node.js 6.10.
Repeat this process for each region, as necessary.

Listing Lambda Functions and Updating to Newer Runtime Using the Runtime Update Blueprint

Sign in to the AWS Management Console and open the Lambda console.

20
AWS Lambda Developer Guide
Programming Model

Choose Create a Lambda Function.


Choose the nodejs-upgrade-functions blueprint and create a function using it.
Note that the function has the following environment variables available:
MODE = List or Backup or Upgrade
TARGET_RUNTIME = nodejs4.3 or nodejs6.10
EXCLUDED = a comma-separated list of function names to exclude from processing (do not include
spaces in the list)
To obtain a list of functions and versions, invoke the function from the console without any change to
the variable values.
To back up functions before upgrading, change the value of MODE to Backup and invoke the function
from the console. We strongly recommend you run this before upgrading your functions.
To update the runtime value of functions, change the value of MODE to Upgrade and invoke the
function from the console.
Repeat this process for each region as necessary.
Note that:
The blueprint will save your existing Node.js v1.0 function as a version and update $LATEST to
nodejs4.3 or nodejs6.10, depending on which version you chose. No other versions of the function
can be upgraded. You can use this version information to point any existing applications to that
version.
The blueprint does not modify aliases. Any aliases pointing to that function will have to be
remapped to the new version. For more information, see AWS Lambda Function Versioning and
Aliases (p. 75).

The Context Methods in Node.js Runtime v0.10.42


Node.js runtime v0.10.42 does not support the callback parameter for your Lambda function that
runtimes v4.3 and v6.10 support. When using runtime v0.10.42, you use the following context object
methods to properly terminate your Lambda function. The context object supports the done(),
succeed(), and fail() methods that you can use to terminate your Lambda function. These methods
are also present in runtimes v4.3 and v6.10 for backward compatibility. For information about
transitioning your code to use runtime v4.3 or v6.10, see Transitioning Lambda Function Code to Newer
Runtimes (p. 19).

context.succeed()
Indicates the Lambda function execution and all callbacks completed successfully. Here's the general
syntax:

context.succeed(Object result);

Where:

result is an optional parameter and it can be used to provide the result of the function execution.

The result provided must be JSON.stringify compatible. If AWS Lambda fails to stringify or encounters
another error, an unhandled exception is thrown, with the X-Amz-Function-Error response header set to
Unhandled.

You can call this method without any parameters (succeed()) or pass a null value (succeed(null)).

The behavior of this method depends on the invocation type specied in the Lambda function
invocation. For more information about invocation types, see Invoke (p. 401).

If the Lambda function is invoked using theEventinvocation type (asynchronous invocation), the
method will return HTTP status 202, request accepted response.

21
AWS Lambda Developer Guide
Programming Model

If the Lambda function is invoked using the RequestResponse invocation type (synchronous
invocation), the method will return HTTP status 200 (OK) and set the response body to the string
representation of the result.

context.fail()
Indicates the Lambda function execution and all callbacks completed unsuccessfully, resulting in a
handled exception. The general syntax is shown following:

context.fail(Error error);

Where:

error is an optional parameter that you can use to provide the result of the Lambda function
execution.

If the error value is non-null, the method will set the response body to the string representation of
error and also write corresponding logs to CloudWatch. If AWS Lambda fails to stringify or encounters
another error, an unhandled error occurs with the X-Amz-Function-Error header set to Unhandled.
Note
For the error from context.fail(error) and context.done(error, null), Lambda logs the
rst 256 KB of the error object. For larger error objects, AWS Lambda truncates the error and
displays the text: Truncated by Lambda next to the error object.

You can call this method without any parameters (fail()) or pass a null value (fail(null)).

context.done()
Causes the Lambda function execution to terminate.
Note
This method complements the succeed() and fail() methods by allowing the use of the "error
rst" callback design pattern. It provides no additional functionality.

The general syntax is:

context.done(Error error, Object result);

Where:

error is an optional parameter that you can use to provide results of the failed Lambda function
execution.
result is an optional parameter that you can use to provide the result of a successful function
execution. The result provided must be JSON.stringify compatible. If an error is provided, this
parameter is ignored.

You can call this method without any parameters (done()), or pass null (done(null)).

AWS Lambda treats any non-null value for the error parameter as a handled exception.

The function behavior depends on the invocation type specied at the time of the Lambda invocation.
For more information about invocation types, see Invoke (p. 401).

Regardless of the invocation type, the method automatically logs the string representation of non-null
values of error to the Amazon CloudWatch Logs stream associated with the Lambda function.
If the Lambda function was invoked using the RequestResponse (synchronous) invocation type, the
method returns response body as follows:

22
AWS Lambda Developer Guide
Programming Model

If error is null, set the response body to the JSON representation of result. This is similar to
context.succeed().
If the error is not null or the function is called with a single argument of type error, the error value
will be populated in the response body.

Note
For the error from both the done(error, null) and fail(error), Lambda logs the rst 256 KB
of the error object, and for larger error object, AWS Lambda truncates the log and displays the
text Truncated by Lambda" next to the error object.

Comparing the Context and Callback Methods

If you previously created Lambda functions using Node.js runtime v0.10.42, you used one of the context
object methods (done(), succeed(), and fail()) to terminate your Lambda function. In Node.js runtimes
v4.3 and v6.10, these methods are supported primarily for backward compatibility. We recommend you
use the callback (see Using the Callback Parameter (p. 11)). The following are callback examples
equivalent to the context object methods:

The following example shows the context.done() method and corresponding equivalent callback
supported in the newer runtime.

// Old way (Node.js runtime v0.10.42).


context.done(null, 'Success message');

// New way (Node.js runtime v4.3 or v6.10).


context.callbackWaitsForEmptyEventLoop = false;
callback(null, 'Success message');

Important
For performance reasons, AWS Lambda may reuse the same Node.js process for multiple
executions of the Lambda function. If this happens, AWS Lambda freezes the Node process
between execution,retaining the state information it needs to continue execution.
When the context methods are called, AWS Lambda freezes the Node process immediately,
without waiting for the event loop associated with the process to empty. The process state
and any events in the event loop are frozen. When the function is invoked again, if AWS
Lambda re-uses the frozen process, the function execution continues with its same global
state (for example, events that remained in the event loop will begin to get processed).
However, when you use callback, AWS Lambda continues the Lambda function execution until
the event loop is empty. After all events in the event loop are processed, AWS Lambda then
freezes the Node process, including any state variables in the Lambda function. Therefore,
if you want the same behavior as the context methods, you must set the context object
property, callbackWaitsForEmptyEventLoop, to false.
The following example shows the context.succeed() method and corresponding equivalent callback
supported in the newer runtime.

// Old way (Node.js runtime v0.10.42).


context.succeed('Success message');

// New way (Node.js runtime v4.3 or v6.10).


context.callbackWaitsForEmptyEventLoop = false;
callback(null, 'Success message');

The following example shows the context.fail() method and corresponding equivalent callback
supported in the newer runtime.

// Old way (Node.js runtime v0.10.42).


context.fail('Fail object');

23
AWS Lambda Developer Guide
Programming Model

// New way (Node.js runtime v4.3 or v6.10).


context.callbackWaitsForEmptyEventLoop = false;
callback('Fail object', 'Failed result');

Programming Model for Authoring Lambda Functions in Java


The following sections explain how common programming patterns and core concepts apply when
authoring Lambda function code in Java.

Topics
Lambda Function Handler (Java) (p. 24)
The Context Object (Java) (p. 34)
Logging (Java) (p. 36)
Function Errors (Java) (p. 39)

Additionally, note that AWS Lambda provides the following libraries:

aws-lambda-java-core This library provides the Context object, RequestStreamHandler, and the
RequestHandler interfaces. The Context object (The Context Object (Java) (p. 34)) provides runtime
information about your Lambda function. The predened interfaces provide one way of dening your
Lambda function handler. For more information, see Leveraging Predened Interfaces for Creating
Handler (Java) (p. 30).
aws-lambda-java-events This library provides predened types that you can use when writing
Lambda functions to process events published by Amazon S3, Kinesis, Amazon SNS, and Amazon
Cognito. These classes help you process the event without having to write your own custom
serialization logic.
Custom Appender for Log4j 1.2 You can use the custom Log4j (see Apache log4j) appender
provided by AWS Lambda for logging from your lambda functions. For more information, see Logging
(Java) (p. 36).

These libraries are available through the Maven Central Repository and can also be found on GitHub.

Lambda Function Handler (Java)


At the time you create a Lambda function you specify a handler that AWS Lambda can invoke when the
service executes the Lambda function on your behalf.

Lambda supports two approaches for creating a handler:

Loading the handler method directly without having to implement an interface. This section describes
this approach.
Implementing standard interfaces provided as part of aws-lambda-java-core library (interface
approach). For more information, see Leveraging Predened Interfaces for Creating Handler
(Java) (p. 30).

The general syntax for the handler is as follows:

outputType handler-name(inputType input, Context context) {


...
}

24
AWS Lambda Developer Guide
Programming Model

In order for AWS Lambda to successfully invoke a handler it must be invoked with input data that can be
serialized into the data type of the input parameter.

In the syntax, note the following:

inputType The rst handler parameter is the input to the handler, which can be event data
(published by an event source) or custom input that you provide such as a string or any custom data
object. In order for AWS Lambda to successfully invoke this handler, the function must be invoked with
input data that can be serialized into the data type of the input parameter.
outputType If you plan to invoke the Lambda function synchronously (using the RequestResponse
invocation type), you can return the output of your function using any of the supported data types.
For example, if you use a Lambda function as a mobile application backend, you are invoking it
synchronously. Your output data type will be serialized into JSON.

If you plan to invoke the Lambda function asynchronously (using the Event invocation type), the
outputType should be void. For example, if you use AWS Lambda with event sources such as Amazon
S3, Kinesis, and Amazon SNS, these event sources invoke the Lambda function using the Event
invocation type.
The inputType and outputType can be one of the following:
Primitive Java types (such as String or int).
Predened AWS event types dened in the aws-lambda-java-events library.

For example S3Event is one of the POJOs predened in the library that provides methods for you to
easily read information from the incoming Amazon S3 event.
You can also write your own POJO class. AWS Lambda will automatically serialize and deserialize
input and output JSON based on the POJO type.

For more information, see Handler Input/Output Types (Java) (p. 26).
You can omit the Context object from the handler method signature if it isn't needed. For more
information, see The Context Object (Java) (p. 34).

For example, consider the following Java example code.

package example;

import com.amazonaws.services.lambda.runtime.Context;
import com.amazonaws.services.lambda.runtime.RequestHandler;

public class Hello implements RequestHandler<Integer, String>


public String myHandler(int myCount, Context context) {
return String.valueOf(myCount);
}
}

In this example input is of type Integer and output is of type String. If you package this code
and dependencies, and create your Lambda function, you specify example.Hello::myHandler
(package.class::method-reference) as the handler.

In the example Java code, the rst handler parameter is the input to the handler (myHandler), which can
be event data (published by an event source such as Amazon S3) or custom input you provide such as an
Integer object (as in this example) or any custom data object.

For instructions to create a Lambda function using this Java code, see Step 2.3: (Optional) Create a
Lambda Function Authored in Java (p. 195).

25
AWS Lambda Developer Guide
Programming Model

Handler Overload Resolution

If your Java code contains multiple methods with same name as the handler name, then AWS Lambda
uses the following rules to pick a method to invoke:

1. Select the method with the largest number of parameters.


2. If two or more methods have the same number of parameters, AWS Lambda selects the method that
has the Context as the last parameter.

If none or all of these methods have the Context parameter, then the behavior is undened.

Additional Information

The following topics provide more information about the handler.

For more information about the handler input and output types, see Handler Input/Output Types
(Java) (p. 26).
For information about using predened interfaces to create a handler, see Leveraging Predened
Interfaces for Creating Handler (Java) (p. 30).

If you implement these interfaces, you can validate your handler method signature at compile time.
If your Lambda function throws an exception, AWS Lambda records metrics in CloudWatch indicating
that an error occurred. For more information, see Function Errors (Java) (p. 39).

Handler Input/Output Types (Java)

When AWS Lambda executes the Lambda function, it invokes the handler. The rst parameter is the
input to the handler which can be event data (published by an event source) or custom input you provide
such as a string or any custom data object.

AWS Lambda supports the following input/output types for a handler:

Simple Java types (AWS Lambda supports the String, Integer, Boolean, Map, and List types)
POJO (Plain Old Java Object) type
Stream type (If you do not want to use POJOs or if Lambda's serialization approach does not meet
your needs, you can use the byte stream implementation. For more information, see Example: Using
Stream for Handler Input/Output (Java) (p. 29).)

Handler Input/Output: String Type

The following Java class shows a handler called myHandler that uses String type for input and output.

package example;

import com.amazonaws.services.lambda.runtime.Context;

public class Hello {


public String myHandler(String name, Context context) {
return String.format("Hello %s.", name);
}
}

You can have similar handler functions for other simple Java types.

26
AWS Lambda Developer Guide
Programming Model

Note
When you invoke a Lambda function asynchronously, any return value by your Lambda function
will be ignored. Therefore you might want to set the return type to void to make this clear in
your code. For more information, see Invoke (p. 401).

To test an end-to-end example, see Step 2.3: (Optional) Create a Lambda Function Authored in
Java (p. 195).

Handler Input/Output: POJO Type


The following Java class shows a handler called myHandler that uses POJOs for input and output.

package example;

import com.amazonaws.services.lambda.runtime.Context;

public class HelloPojo {

// Define two classes/POJOs for use with Lambda function.


public static class RequestClass {
...
}

public static class ResponseClass {


...
}

public static ResponseClass myHandler(RequestClass request, Context context) {


String greetingString = String.format("Hello %s, %s.", request.getFirstName(),
request.getLastName());
return new ResponseClass(greetingString);
}
}

AWS Lambda serializes based on standard bean naming conventions (see The Java EE 6 Tutorial). You
should use mutable POJOs with public getters and setters.
Note
You shouldn't rely on any other features of serialization frameworks such as annotations. If you
need to customize the serialization behavior, you can use the raw byte stream to use your own
serialization.

If you use POJOs for input and output, you need to provide implementation of the RequestClass
and ResponseClass types. For an example, see Example: Using POJOs for Handler Input/Output
(Java) (p. 27).

Example: Using POJOs for Handler Input/Output (Java)


Suppose your application events generate data that includes rst name and last name as shown:

{ "firstName": "John", "lastName": "Doe" }

For this example, the handler receives this JSON and returns the string "Hello John Doe".

public static ResponseClass handleRequest(RequestClass request, Context context){


String greetingString = String.format("Hello %s, %s.", request.firstName,
request.lastName);
return new ResponseClass(greetingString);
}

To create a Lambda function with this handler, you must provide implementation of the input and
output types as shown in the following Java example. The HelloPojo class denes the handler method.

27
AWS Lambda Developer Guide
Programming Model

package example;

import com.amazonaws.services.lambda.runtime.Context;
import com.amazonaws.services.lambda.runtime.RequestHandler;

public class HelloPojo implements RequestHandler<RequestClass, ResponseClass>{

public ResponseClass handleRequest(RequestClass request, Context context){


String greetingString = String.format("Hello %s, %s.", request.firstName,
request.lastName);
return new ResponseClass(greetingString);
}
}

In order to implement the input type, add the following code to a separate le and name it
RequestClass.java. Place it next to the HelloPojo.java class in your directory structure:

package example;

public class RequestClass {


String firstName;
String lastName;

public String getFirstName() {


return firstName;
}

public void setFirstName(String firstName) {


this.firstName = firstName;
}

public String getLastName() {


return lastName;
}

public void setLastName(String lastName) {


this.lastName = lastName;
}

public RequestClass(String firstName, String lastName) {


this.firstName = firstName;
this.lastName = lastName;
}

public RequestClass() {
}
}

In order to implement the output type, add the following code to a separate le and name it
ResponseClass.java. Place it next to the HelloPojo.java class in your directory structure:

package example;

public class ResponseClass {


String greetings;

public String getGreetings() {


return greetings;
}

public void setGreetings(String greetings) {


this.greetings = greetings;
}

28
AWS Lambda Developer Guide
Programming Model

public ResponseClass(String greetings) {


this.greetings = greetings;
}

public ResponseClass() {
}

Note
The get and set methods are required in order for the POJOs to work with AWS Lambda's built
in JSON serializer. The constructors that take no arguments are usually not required, however
in this example we provided other constructors and therefore we need to explicitly provide the
zero argument constructors.

You can upload this code as your Lambda function and test as follows:

Using the preceding code les, create a deployment package.


Upload the deployment package to AWS Lambda and create your Lambda function. You can do this
using the console or AWS CLI.
Invoke the Lambda function manually using the console or the CLI. You can use provide sample JSON
event data when you manually invoke your Lambda function. For example:

{ "firstName":"John", "lastName":"Doe" }

For more information, see Step 2.3: (Optional) Create a Lambda Function Authored in Java (p. 195).
Note the following dierences:

When you create a deployment package, don't forget the aws-lambda-java-core library dependency.
When you create the Lambda function, specify example.HelloPojo::handleRequest
(package.class::method) as the handler value.

Example: Using Stream for Handler Input/Output (Java)


If you do not want to use POJOs or if Lambda's serialization approach does not meet your needs, you can
use the byte stream implementation. In this case, you can use the InputStream and OutputStream as the
input and output types for the handler. An example handler function is shown:

public void handler(InputStream inputStream, OutputStream outputStream, Context context) {


...
}

Note that in this case the handler function uses parameters for both the request and response streams.

The following is a Lambda function example that implements the handler that uses InputStream and
OutputStream types for the input and output parameters.
Note
The input payload must be valid JSON but the output stream does not carry such a restriction.
Any bytes are supported.

package example;

import java.io.InputStream;
import java.io.OutputStream;
import com.amazonaws.services.lambda.runtime.RequestStreamHandler;

29
AWS Lambda Developer Guide
Programming Model

import com.amazonaws.services.lambda.runtime.Context;

public class Hello implements RequestStreamHandler{


public static void handler(InputStream inputStream, OutputStream outputStream, Context
context) throws IOException {
int letter;
while((letter = inputStream.read()) != -1)
{
outputStream.write(Character.toUpperCase(letter));
}
}
}

You can do the following to test the code:

Using the preceding code, create a deployment package.


Upload the deployment package to AWS Lambda and create your Lambda function. You can do this
using the console or AWS CLI.
You can manually invoke the code by providing sample input. For example:

test

Follow instructions provided in the Getting Started. For more information, see Step 2.3: (Optional)
Create a Lambda Function Authored in Java (p. 195). Note the following dierences:

When you create a deployment package, don't forget the aws-lambda-java-core library dependency.
When you create the Lambda function, specify example.Hello::handler (package.class::method) as
the handler value.

Leveraging Predened Interfaces for Creating Handler (Java)

You can use one of the predened interfaces provided by the AWS Lambda Java core library (aws-
lambda-java-core) to create your Lambda function handler, as an alternative to writing your own
handler method with an arbitrary name and parameters. For more information about handlers, see (see
Lambda Function Handler (Java) (p. 24)).

You can implement one of the predened interfaces, RequestStreamHandler or RequestHandler and
provide implementation for the handleRequest method that the interfaces provide. You implement one
of these interfaces depending on whether you want to use standard Java types or custom POJO types for
your handler input/output (where AWS Lambda automatically serializes and deserializes the input and
output to Match your data type), or customize the serialization using the Stream type.
Note
These interfaces are available in the aws-lambda-java-core library.

When you implement standard interfaces, they help you validate your method signature at compile time.

If you implement one of the interfaces, you specify package.class in your Java code as the handler
when you create the Lambda function. For example, the following is the modied create-function CLI
command from the getting started. Note that the --handler parameter species "example.Hello" value:

aws lambda create-function \


--region us-west-2 \
--function-name getting-started-lambda-function-in-java \
--zip-file fileb://deployment-package (zip or jar)
path \
--role arn:aws:iam::account-id:role/lambda_basic_execution \
--handler example.Hello \

30
AWS Lambda Developer Guide
Programming Model

--runtime java8 \
--timeout 15 \
--memory-size 512

The following sections provide examples of implementing these interfaces.

Example 1: Creating Handler with Custom POJO Input/Output (Leverage the RequestHandler
Interface)
The example Hello class in this section implements the RequestHandler interface. The interface denes
handleRequest() method that takes in event data as input parameter of the Request type and returns an
POJO object of the Response type:

public Response handleRequest(Request request, Context context) {


...
}

The Hello class with sample implementation of the handleRequest() method is shown. For this example,
we assume event data consists of rst name and last name.

package example;

import com.amazonaws.services.lambda.runtime.RequestHandler;
import com.amazonaws.services.lambda.runtime.Context;

public class Hello implements RequestHandler<Request, Response> {

public Response handleRequest(Request request, Context context) {


String greetingString = String.format("Hello %s %s.", request.firstName,
request.lastName);
return new Response(greetingString);
}
}

For example, if the event data in the Request object is:

{
"firstName":"value1",
"lastName" : "value2"
}

The method returns a Response object as follows:

{
"greetings": "Hello value1 value2."
}

Next, you need to implement the Request and Response classes. You can use the following
implementation for testing:

The Request class:

package example;

public class Request {


String firstName;
String lastName;

public String getFirstName() {


return firstName;

31
AWS Lambda Developer Guide
Programming Model

public void setFirstName(String firstName) {


this.firstName = firstName;
}

public String getLastName() {


return lastName;
}

public void setLastName(String lastName) {


this.lastName = lastName;
}

public Request(String firstName, String lastName) {


this.firstName = firstName;
this.lastName = lastName;
}

public Request() {
}
}

The Response class:

package example;

public class Response {


String greetings;

public String getGreetings() {


return greetings;
}

public void setGreetings(String greetings) {


this.greetings = greetings;
}

public Response(String greetings) {


this.greetings = greetings;
}

public Response() {
}
}

You can create a Lambda function from this code and test the end-to-end experience as follows:

Using the preceding code, create a deployment package.


Upload the deployment package to AWS Lambda and create your Lambda function.
Test the Lambda function using either the console or CLI. You can specify any sample JSON data that
conform to the getter and setter in your Request class, for example:

{
"firstName":"John",
"lastName" : "Doe"
}

The Lambda function will return the following JSON in response.

32
AWS Lambda Developer Guide
Programming Model

"greetings": "Hello John, Doe."


}

Follow instructions provided in the getting started (see Step 2.3: (Optional) Create a Lambda Function
Authored in Java (p. 195)). Note the following dierences:

When you create a deployment package, don't forget the aws-lambda-java-core library dependency.
When you create the Lambda function specify example.Hello (package.class) as the handler value.

Example 2: Creating Handler with Stream Input/Output (Leverage the RequestStreamHandler


Interface)

The Hello class in this example implements the RequestStreamHandler interface. The interface denes
handleRequest method as follows:

public void handleRequest(InputStream inputStream, OutputStream outputStream, Context


context)
throws IOException {
...
}

The Hello class with sample implementation of the handleRequest() handler is shown. The handler
processes incoming event data (for example, a string "hello") by simply converting it to uppercase and
return it.

package example;

import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;

import com.amazonaws.services.lambda.runtime.RequestStreamHandler;
import com.amazonaws.services.lambda.runtime.Context;

public class Hello implements RequestStreamHandler {


public void handleRequest(InputStream inputStream, OutputStream outputStream, Context
context)
throws IOException {
int letter;
while((letter = inputStream.read()) != -1)
{
outputStream.write(Character.toUpperCase(letter));
}
}
}

You can create a Lambda function from this code and test the end-to-end experience as follows:

Use the preceding code to create deployment package.


Upload the deployment package to AWS Lambda and create your Lambda function.
Test the Lambda function using either the console or CLI. You can specify any sample string data, for
example:

"test"

The Lambda function will return TEST in response.

33
AWS Lambda Developer Guide
Programming Model

Follow instructions provided in the getting started (see Step 2.3: (Optional) Create a Lambda Function
Authored in Java (p. 195)). Note the following dierences:

When you create a deployment package, don't forget the aws-lambda-java-core library dependency.
When you create the Lambda function specify example.Hello (package.class) as the handler value.

The Context Object (Java)


You interact with AWS Lambda execution environment via the context parameter. The context object
allows you to access useful information available within the Lambda execution environment. For
example, you can use the context parameter to determine the CloudWatch log stream associated with
the function, or use the clientContext property of the context object to learn more about the application
calling the Lambda function (when invoked through the AWS Mobile SDK).

The context object properties are:

getMemoryLimitInMB(): Memory limit, in MB, you congured for the Lambda function.
getFunctionName(): Name of the Lambda function that is running.
getFunctionVersion(): The Lambda function version that is executing. If an alias is used to invoke the
function, then getFunctionVersion will be the version the alias points to.
getInvokedFunctionArn(): The ARN used to invoke this function. It can be function ARN or alias ARN.
An unqualied ARN executes the $LATEST version and aliases execute the function version it is pointing
to.
getAwsRequestId(): AWS request ID associated with the request. This is the ID returned to the client
that called invoke(). You can use the request ID for any follow up enquiry with AWS support. Note that
if AWS Lambda retries the function (for example, in a situation where the Lambda function processing
Kinesis records throw an exception), the request ID remains the same.
getLogStreamName(): The CloudWatch log stream name for the particular Lambda function execution.
It can be null if the IAM user provided does not have permission for CloudWatch actions.
getLogGroupName(): The CloudWatch log group name associated with the Lambda function invoked. It
can be null if the IAM user provided does not have permission for CloudWatch actions.
getClientContext(): Information about the client application and device when invoked through
the AWS Mobile SDK. It can be null. Client context provides client information such as client ID,
application title, version name, version code, and the application package name.
getIdentity(): Information about the Amazon Cognito identity provider when invoked through the
AWS Mobile SDK. It can be null.
getRemainingTimeInMillis(): Remaining execution time till the function will be terminated, in
milliseconds. At the time you create the Lambda function you set maximum time limit, at which time
AWS Lambda will terminate the function execution. Information about the remaining time of function
execution can be used to specify function behavior when nearing the timeout.
getLogger(): Returns the Lambda logger associated with the Context object. For more information,
see Logging (Java) (p. 36).

The following Java code snippet shows a handler function that prints some of the context information.

public static void handler(InputStream inputStream, OutputStream outputStream, Context


context) {

...
System.out.println("Function name: " + context.getFunctionName());
System.out.println("Max mem allocated: " + context.getMemoryLimitInMB());
System.out.println("Time remaining in milliseconds: " +
context.getRemainingTimeInMillis());

34
AWS Lambda Developer Guide
Programming Model

System.out.println("CloudWatch log stream name: " + context.getLogStreamName());


System.out.println("CloudWatch log group name: " + context.getLogGroupName());

Example: Using Context Object (Java)

The following Java code example shows how to use the Context object to retrieve runtime information
of your Lambda function, while it is running.

package example;
import java.io.InputStream;
import java.io.OutputStream;
import com.amazonaws.services.lambda.runtime.Context;

public class Hello {


public static void myHandler(InputStream inputStream, OutputStream outputStream,
Context context) {

int letter;
try {
while((letter = inputStream.read()) != -1)
{
outputStream.write(Character.toUpperCase(letter));
}
Thread.sleep(3000); // Intentional delay for testing the
getRemainingTimeInMillis() result.
}
catch (Exception e)
{
e.printStackTrace();
}

// For fun, let us get function info using the context object.
System.out.println("Function name: " + context.getFunctionName());
System.out.println("Max mem allocated: " + context.getMemoryLimitInMB());
System.out.println("Time remaining in milliseconds: " +
context.getRemainingTimeInMillis());
System.out.println("CloudWatch log stream name: " + context.getLogStreamName());
System.out.println("CloudWatch log group name: " + context.getLogGroupName());
}
}

You can do the following to test the code:

Using the preceding code, create a deployment package.


Upload the deployment package to AWS Lambda to create your Lambda function. You can do this
using the console or AWS CLI.
To test your Lambda function use the "Hello World" Sample event that the Lambda console provides.

You can type any string and the function will return the same string in uppercase. In addition, you will
also get the useful function information provided by the context object.

Follow the instructions provided in the Getting Started. For more information, see Step 2.3: (Optional)
Create a Lambda Function Authored in Java (p. 195). Note the following dierences:

When you create a deployment package, don't forget the aws-lambda-java-core library dependency.
When you create the Lambda function, specify example.Hello::myHandler (package.class::method)
as the handler value.

35
AWS Lambda Developer Guide
Programming Model

Logging (Java)
Your Lambda function can contain logging statements. AWS Lambda writes these logs to CloudWatch.
We recommend you use one of the following to write logs.

Custom Appender for Log4j 1.2

AWS Lambda supports Log4j 1.2 by providing a custom appender. You can use the custom Log4j (see
Apache log4j) appender provided by Lambda for logging from your lambda functions. Every call to
Log4j methods, such as log.debug() or log.error(), will result in a CloudWatch Logs event. The
custom appender is called LambdaAppender and must be used in the log4j.properties le. You must
include the aws-lambda-java-log4j artifact (artifactId:aws-lambda-java-log4j) in the deployment
package (.jar le). For an example, see Example 1: Writing Logs Using Log4J (Java) (p. 37).
Note
Currently, AWS Lambda supports Log4j 1.2 version.
LambdaLogger.log()

Each call to LambdaLogger.log() results in a CloudWatch Logs event, provided the event size is within
the allowed limits. For information about CloudWatch Logs limits, see CloudWatch Logs Limits in the
Amazon CloudWatch User Guide. For an example, see Example 2: Writing Logs Using LambdaLogger
(Java) (p. 38).

In addition, you can also use the following statements in your Lambda function code to generate log
entries:

System.out()
System.err()

However, note that AWS Lambda treats each line returned by System.out and System.err as a separate
event. This works well when each output line corresponds to a single log entry. When a log entry has
multiple lines of output, AWS Lambda attempts to parse them using line breaks to identify separate
events. For example, the following logs the two words ("Hello" and "world") as two separate events:

System.out.println("Hello \n world");

How to Find Logs

You can nd the logs that your Lambda function writes, as follows:

Find logs in CloudWatch Logs. The context object (in the aws-lambda-java-core library) provides the
getLogStreamName() and the getLogGroupName() methods. Using these methods, you can nd the
specic log stream where logs are written.
If you invoke a Lambda function via the console, the invocation type is always RequestResponse (that
is, synchronous execution) and the console displays the logs that the Lambda function writes using the
LambdaLogger object. AWS Lambda also returns logs from System.out and System.err methods.
If you invoke a Lambda function programmatically, you can add the LogType parameter to retrieve the
last 4 KB of log data that is written to CloudWatch Logs. For more information, see Invoke (p. 401).
AWS Lambda returns this log information in the x-amz-log-results header in the response. If you use
the AWS Command Line Interface to invoke the function, you can specify the --log-type parameter
with value Tail.

36
AWS Lambda Developer Guide
Programming Model

Logging Examples (Java)

This section provides examples of using Custom Appender for Log4j and the LambdaLogger objects for
logging information.

Example 1: Writing Logs Using Log4J (Java)

The following Java code example writes logs using both the System methods and Log4j to illustrate how
they dier when AWS Lambda logs information to CloudWatch.

package example;

import com.amazonaws.services.lambda.runtime.Context;

import org.apache.logging.log4j.Logger;

public class Hello {


// Initialize the Log4j logger.
static final Logger log = Logger.getLogger(Hello.class);

public String myHandler(String name, Context context) {


// System.out: One log statement but with a line break (AWS Lambda writes two
events to CloudWatch).
System.out.println("log data from stdout \n this is continuation of system.out");

// System.err: One log statement but with a line break (AWS Lambda writes two events
to CloudWatch).
System.err.println("log data from stderr. \n this is a continuation of
system.err");

// Use log4j to log the same thing as above and AWS Lambda will log only one event
in CloudWatch.
log.debug("log data from log4j debug \n this is continuation of log4j debug");

log.error("log data from log4j err. \n this is a continuation of log4j.err");

// Return will include the log stream name so you can look
// up the log later.
return String.format("Hello %s. log stream = %s", name,
context.getLogStreamName());
}
}

The example uses the following log4j.properties le (project-dir/src/main/resources/ directory).

log = .
log4j.rootLogger = DEBUG, LAMBDA

#Define the LAMBDA appender


log4j.appender.LAMBDA=com.amazonaws.services.lambda.runtime.log4j.LambdaAppender
log4j.appender.LAMBDA.layout=org.apache.log4j.PatternLayout
log4j.appender.LAMBDA.layout.conversionPattern=%d{yyyy-MM-dd HH:mm:ss} <%X{AWSRequestId}>
%-5p %c{1}:%m%n

The following is sample of log entries in CloudWatch Logs.

37
AWS Lambda Developer Guide
Programming Model

Note:

AWS Lambda parses the log string in each of the System.out.println() and System.err.println()
statements logs as two separate events (note the two down arrows in the screenshot) because of the
line break.
The Log4j methods (log.debug() and log.error()) produce one CloudWatch event.
AWS Lambda runtime adds the AWSRequestId in the MDC (see Class MDC). To get this value in the log
as shown, we added %X{AWSRequestId} in the conversion pattern in the log4.properties le.

You can do the following to test the code:

Using the code, create a deployment package. In your project, don't forget to add the
log4j.properties les in the project-dir/src/main/resources/ directory.
Upload the deployment package to AWS Lambda to create your Lambda function.
To test your Lambda function use a string ("this is a test") as sample event. The handler code receives
the sample event but does nothing with it. It only shows how to write logs.

Follow the instructions provided in the Getting Started. For more information, see Step 2.3: (Optional)
Create a Lambda Function Authored in Java (p. 195). Note the following dierences:

When you create a deployment package, don't forget the aws-lambda-java-log4j library dependency.
When you create the Lambda function, specify example.Hello::myHandler (package.class::method)
as the handler value.

Example 2: Writing Logs Using LambdaLogger (Java)

The following Java code example writes logs using both the System methods and the LambdaLogger
object to illustrate how they dier when AWS Lambda logs information to CloudWatch.

package example;

import com.amazonaws.services.lambda.runtime.Context;
import com.amazonaws.services.lambda.runtime.LambdaLogger;

public class Hello {


public String myHandler(String name, Context context) {

// System.out: One log statement but with a line break (AWS Lambda writes two
events to CloudWatch).
System.out.println("log data from stdout \n this is continuation of system.out");

38
AWS Lambda Developer Guide
Programming Model

// System.err: One log statement but with a line break (AWS Lambda writes two
events to CloudWatch).
System.err.println("log data from stderr \n this is continuation of system.err");

LambdaLogger logger = context.getLogger();


// Write log to CloudWatch using LambdaLogger.
logger.log("log data from LambdaLogger \n this is continuation of logger.log");

// Return will include the log stream name so you can look
// up the log later.
return String.format("Hello %s. log stream = %s", name,
context.getLogStreamName());
}
}

The following is sample of log entries in CloudWatch Logs.

Note:

AWS Lambda parses the log string in each of the System.out.println() and System.err.println()
statements logs as two separate events (note the two down arrows in the screenshot) because of the
line break.
The LambdaLogger.log() produce one CloudWatch event.

You can do the following to test the code:

Using the code, create a deployment package.


Upload the deployment package to AWS Lambda to create your Lambda function.
To test your Lambda function use a string ("this is a test") as sample event. The handler code receives
the sample event but does nothing with it. It only shows how to write logs.

Follow the instructions provided in the Getting Started. For more information, see Step 2.3: (Optional)
Create a Lambda Function Authored in Java (p. 195). Note the following dierences:

When you create a deployment package, don't forget the aws-lambda-java-core library dependency.
When you create the Lambda function, specify example.Hello::myHandler (package.class::method)
as the handler value.

Function Errors (Java)


If your Lambda function throws an exception, AWS Lambda recognizes the failure and serializes the
exception information into JSON and returns it. Following is an example error message:

39
AWS Lambda Developer Guide
Programming Model

"errorMessage": "Name John Doe is invalid. Exception occurred...",


"errorType": "java.lang.Exception",
"stackTrace": [
"example.Hello.handler(Hello.java:9)",
"sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)",
"sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)",

"sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)",
"java.lang.reflect.Method.invoke(Method.java:497)"
]
}

Note that the stack trace is returned as the stackTrace JSON array of stack trace elements.

The method in which you get the error information back depends on the invocation type that you
specied at the time you invoked the function:

RequestResponse invocation type (that is, synchronous execution): In this case, you get the error
message back.

For example, if you invoke a Lambda function using the Lambda console, the RequestResponse is
always the invocation type and the console displays the error information returned by AWS Lambda in
the Execution result section as shown in the following image.

Event invocation type (that is, asynchronous execution): In this case AWS Lambda does not return
anything. Instead, it logs the error information in CloudWatch Logs and CloudWatch metrics.

Depending on the event source, AWS Lambda may retry the failed Lambda function. For example, if
Kinesis is the event source for the Lambda function, AWS Lambda retries the failed function until the
Lambda function succeeds or the records in the stream expire.

Function Error Handling


You can create custom error handling to raise an exception directly from your Lambda function and
handle it directly (Retry or Catch) within an AWS Step Functions State Machine. For more information,
see Handling Error Conditions Using a State Machine.

Consider a CreateAccount state is a task that writes a customer's details to a database using a Lambda
function.

If the task succeeds, an account is created and a welcome email is sent.


If a user tries to create an account for a username that already exists, the Lambda function raises an
error, causing the state machine to suggest a dierent username and to retry the account-creation
process.

40
AWS Lambda Developer Guide
Programming Model

The following code samples demonstrate how to do this. Note that custom errors in Java must extend
the Exception class.

package com.example;

public static class AccountAlreadyExistsException extends Exception {


public AccountAlreadyExistsException(String message) {
super(message);
}
}

package com.example;

import com.amazonaws.services.lambda.runtime.Context;

public class Handler {


public static void CreateAccount(String name, Context context) throws
AccountAlreadyExistsException {
throw new AccountAlreadyExistsException ("Account is in use!");
}
}

You can congure Step Functions to catch the error using a Catch rule. Lambda automatically sets the
error name to the fully-qualied class name of the exception at runtime:

{
"StartAt": "CreateAccount",
"States": {
"CreateAccount": {
"Type": "Task",
"Resource": "arn:aws:lambda:us-east-1:123456789012:function:CreateAccount",
"Next": "SendWelcomeEmail",
"Catch": [
{
"ErrorEquals": ["com.example.AccountAlreadyExistsException"],
"Next": "SuggestAccountName"
}
]
},

}
}

At runtime, AWS Step Functions catches the error, transitioning to the SuggestAccountName state as
specied in the Next transition.

Custom error handling makes it easier to create serverless applications. This feature integrates with all
the languages supported by the Lambda Programming Model (p. 8), allowing you to design your
application in the programming languages of your choice, mixing and matching as you go.

To learn more about creating your own serverless applications using AWS Step Functions and AWS
Lambda, see AWS Step Functions.

Programming Model for Authoring Lambda Functions in Python


The following sections explain how common programming patterns and core concepts apply when
authoring Lambda function code in Python.

Topics
Lambda Function Handler (Python) (p. 42)

41
AWS Lambda Developer Guide
Programming Model

The Context Object (Python) (p. 43)


Logging (Python) (p. 45)
Function Errors (Python) (p. 48)

Lambda Function Handler (Python)


At the time you create a Lambda function, you specify a handler, which is a function in your code, that
AWS Lambda can invoke when the service executes your code. Use the following general syntax structure
when creating a handler function in Python.

def handler_name(event, context):


...
return some_value

In the syntax, note the following:

event AWS Lambda uses this parameter to pass in event data to the handler. This parameter is
usually of the Python dict type. It can also be list, str, int, float, or NoneType type.
context AWS Lambda uses this parameter to provide runtime information to your handler. This
parameter is of the LambdaContext type.
Optionally, the handler can return a value. What happens to the returned value depends on the
invocation type you use when invoking the Lambda function:
If you use the RequestResponse invocation type (synchronous execution), AWS Lambda returns
the result of the Python function call to the client invoking the Lambda function (in the HTTP
response to the invocation request, serialized into JSON). For example, AWS Lambda console uses
the RequestResponse invocation type, so when you invoke the function using the console, the
console will display the returned value.

If the handler returns NONE, AWS Lambda returns null.


If you use the Event invocation type (asynchronous execution), the value is discarded.

For example, consider the following Python example code.

def my_handler(event, context):


message = 'Hello {} {}!'.format(event['first_name'],
event['last_name'])
return {
'message' : message
}

This example has one function called my_handler. The function returns a message containing data from
the event it received as input.

To upload and test this code as a Lambda function

1. Save this le (for example, as hello_python.py).


2. Package the le and any dependencies into a .zip le. When creating the zip, include only the code
and its dependencies, not the containing folder.

For instructions, see Creating a Deployment Package (Python) (p. 73).


3. Upload the .zip le using either the console or AWS CLI to create a Lambda function. You specify the
function name in the Python code to be used as the handler when you create a Lambda function.
For instructions to create a Lambda function using the console, see Step 2.1: Create a Hello World

42
AWS Lambda Developer Guide
Programming Model

Lambda Function (p. 189). In this example, the handler is hello_python.my_handler (file-
name.function-name). Note that the Getting Started (p. 185) uses a blueprint that provides sample
code for a Lambda function. In this case you already have a deployment package. Therefore, in the
congure function step you choose to upload a zip.

The following create-function AWS CLI command creates a Lambda function. Among other
parameters, it species the --handler parameter to specify the handler name. Note that the --
runtime parameter species python3.6. You can also use python2.7.

aws lambda create-function \


--region us-west-2 \
--function-name HelloPython \
--zip-file fileb://deployment-package.zip \
--role arn:aws:iam::account-id:role/lambda_basic_execution \
--handler hello_python.my_handler \
--runtime python3.6 \
--timeout 15 \
--memory-size 512

The Context Object (Python)


Topics
Example (p. 43)
The Context Object Methods (Python) (p. 44)
The Context Object Attributes (Python) (p. 44)

While a Lambda function is executing, it can interact with the AWS Lambda service to get useful runtime
information such as:

How much time is remaining before AWS Lambda terminates your Lambda function (timeout is one of
the Lambda function conguration properties).
The CloudWatch log group and log stream associated with the Lambda function that is executing.
The AWS request ID returned to the client that invoked the Lambda function. You can use the request
ID for any follow up inquiry with AWS support.
If the Lambda function is invoked through AWS Mobile SDK, you can learn more about the mobile
application calling the Lambda function.

AWS Lambda provides this information via the context object that the service passes as the second
parameter to your Lambda function handler. For more information, see Lambda Function Handler
(Python) (p. 42).

The following sections provide an example Lambda function that uses the context object, and then lists
all of the available methods and attributes.

Example

Consider the following Python example. It has one function that is also the handler. The handler receives
runtime information via the context object passed as parameter.

from __future__ import print_function

import time
def get_my_log_stream(event, context):
print("Log stream name:", context.log_stream_name)

43
AWS Lambda Developer Guide
Programming Model

print("Log group name:", context.log_group_name)


print("Request ID:",context.aws_request_id)
print("Mem. limits(MB):", context.memory_limit_in_mb)
# Code will execute quickly, so we add a 1 second intentional delay so you can see that
in time remaining value.
time.sleep(1)
print("Time remaining (MS):", context.get_remaining_time_in_millis())

The handler code in this example simply prints some of the runtime information. Each print statement
creates a log entry in CloudWatch. If you invoke the function using the Lambda console, the console
displays the logs. The from __future__ statement enables you to write code that is compatible with
Python 2 or 3.

To test this code in the AWS Lambda console

1. In the console, create a Lambda function using the hello-world blueprint. In runtime,
choose Python 2.7. In Handler, replace lambda_function.lambda_handlerwith
lambda_function.get_my_log_stream. For instructions on how to do this, see Step 2.1: Create a
Hello World Lambda Function (p. 189).
2. Test the function, and then you can also update the code to get more context information.

The following sections provide a list of available context object methods and attributes that you can use
to get runtime information of your Lambda function.

The Context Object Methods (Python)

The context object provides the following methods:

get_remaining_time_in_millis()

Returns the remaining execution time, in milliseconds, until AWS Lambda terminates the function.

The Context Object Attributes (Python)

The context object provides the following attributes:

function_name

Name of the Lambda function that is executing.


function_version

The Lambda function version that is executing. If an alias is used to invoke the function, then
function_version will be the version the alias points to.
invoked_function_arn

The ARN used to invoke this function. It can be function ARN or alias ARN. An unqualied ARN
executes the $LATEST version and aliases execute the function version it is pointing to.
memory_limit_in_mb

Memory limit, in MB, you congured for the Lambda function. You set the memory limit at the time
you create a Lambda function and you can change it later.
aws_request_id

AWS request ID associated with the request. This is the ID returned to the client that called the
invoke method.

44
AWS Lambda Developer Guide
Programming Model

Note
If AWS Lambda retries the invocation (for example, in a situation where the Lambda
function that is processing Kinesis records throws an exception), the request ID remains the
same.
log_group_name

The name of the CloudWatch log group where you can nd logs written by your Lambda function.
log_stream_name

The name of the CloudWatch log stream where you can nd logs written by your Lambda function.
The log stream may or may not change for each invocation of the Lambda function.

The value is null if your Lambda function is unable to create a log stream, which can happen if
the execution role that grants necessary permissions to the Lambda function does not include
permissions for the CloudWatch Logs actions.
identity

Information about the Amazon Cognito identity provider when invoked through the AWS Mobile
SDK. It can be null.
identity.cognito_identity_id
identity.cognito_identity_pool_id
client_context

Information about the client application and device when invoked through the AWS Mobile SDK. It
can be null.
client_context.client.installation_id
client_context.client.app_title
client_context.client.app_version_name
client_context.client.app_version_code
client_context.client.app_package_name
client_context.custom

A dict of custom values set by the mobile client application.


client_context.env

A dict of environment information provided by the AWS Mobile SDK.

Logging (Python)
Your Lambda function can contain logging statements. AWS Lambda writes these logs to CloudWatch. If
you use the Lambda console to invoke your Lambda function, the console displays the same logs.

The following Python statements generate log entries:

print statements.
Logger functions in the logging module (for example, logging.Logger.info and
logging.Logger.error).

Both print and logging.* functions write logs to CloudWatch Logs but the logging.* functions write
additional information to each log entry, such as time stamp and log level.

For example, consider the following Python code example.

45
AWS Lambda Developer Guide
Programming Model

import logging
logger = logging.getLogger()
logger.setLevel(logging.INFO)
def my_logging_handler(event, context):
logger.info('got event{}'.format(event))
logger.error('something went wrong')
return 'Hello World!'

Because the code example uses the logging module to write message to the logs, you also get some
additional information in the log such as the time stamp and the log levels. The log level identies the
type of log, such as [INFO], [ERROR], and [DEBUG], as shown:

The screen shot shows an example Log output section in the Lambda console; you can also nd
these logs in CloudWatch. For more information, see Accessing Amazon CloudWatch Logs for AWS
Lambda (p. 118).

Instead of using the logging module, you can use the print statements in your code as shown in the
following Python example:

from __future__ import print_function


def lambda_handler(event, context):
print('this will also show up in cloud watch')
return 'Hello World!'

In this case only the text passed to the print method is sent to CloudWatch. The log entries will not have
additional information that the logging.* function returns. The from __future__ statement enables you
to write code that is compatible with Python 2 or 3.

46
AWS Lambda Developer Guide
Programming Model

The console uses the RequestResponse invocation type (synchronous invocation) when invoking the
function. And therefore it gets the return value ("Hello world!") back from AWS Lambda which the
console displays.

To test the preceding Python code (console)

1. In the console, create a Lambda function using the hello-world-python blueprint. In


runtime, choose Python 2.7. In Handler, replace lambda_function.lambda_handlerwith
lambda_function.my_other_logging_handler and in Role, choose Basic execution role. You
also replace the code provided by the blueprint by the code in this section. For step-by-step
instructions to create a Lambda function using the console, see Step 2.1: Create a Hello World
Lambda Function (p. 189).
2. Replace the template code with the code provided in this section.
3. Test the Lambda function using the Sample event template called Hello Worldprovided in the
Lambda console.

Finding Logs

You can nd the logs that your Lambda function writes, as follows:

In the AWS Lambda console The Log output section in AWS Lambda console shows the logs.
In the response header, when you invoke a Lambda function programmatically If you invoke a
Lambda function programmatically, you can add theLogType parameter to retrieve the last 4 KB of log
data that is written to CloudWatch Logs. AWS Lambda returns this log information in thex-amz-log-
resultsheader in the response. For more information, seeInvoke (p. 401).

If you use AWS CLI to invoke the function, you can specify the--log-typeparameter with
valueTailto retrieve the same information.
In CloudWatch Logs To nd your logs in CloudWatch you need to know the log group name and log
stream name. You can use the context.logGroupName, and context.logStreamName properties in your

47
AWS Lambda Developer Guide
Programming Model

code to get this information. When you run your Lambda function, the resulting logs in the console or
CLI will show you the log group name and log stream name.

Function Errors (Python)


If your Lambda function raises an exception, AWS Lambda recognizes the failure and serializes the
exception information into JSON and returns it. Consider the following example:

def always_failed_handler(event, context):


raise Exception('I failed!')

When you invoke this Lambda function, it will raise an exception and AWS Lambda returns the following
error message:

{
"errorMessage": "I failed!",
"stackTrace": [
[
"/var/task/lambda_function.py",
3,
"my_always_fails_handler",
"raise Exception('I failed!')"
]
],
"errorType": "Exception"
}

Note that the stack trace is returned as the stackTrace JSON array of stack trace elements.

How you get the error information back depends on the invocation type that the client species at the
time of function invocation:

If a client species the RequestResponse invocation type (that is, synchronous execution), it returns the
result to the client that made the invoke call.

For example, the console always use the RequestResponse invocation type, so the console will display
the error in the Execution result section as shown:

The same information is also sent to CloudWatch and the Log output section shows the same logs.

48
AWS Lambda Developer Guide
Programming Model

If a client species the Event invocation type (that is, asynchronous execution), AWS Lambda will not
return anything. Instead, it logs the error information to CloudWatch Logs. You can also see the error
metrics in CloudWatch Metrics.

Depending on the event source, AWS Lambda may retry the failed Lambda function. For example, if
Kinesis is the event source, AWS Lambda will retry the failed invocation until the Lambda function
succeeds or the records in the stream expire.

To test the preceding Python code (console)

1. In the console, create a Lambda function using the hello-world blueprint. In runtime, choose
either Python 3.6 or Python 2.7. In Handler, replace lambda_function.lambda_handlerwith
lambda_function.always_failed_handler. For instructions on how to do this, see Step 2.1: Create a
Hello World Lambda Function (p. 189).
2. Replace the template code with the code provided in this section.
3. Test the Lambda function using the Sample event template called Hello Worldprovided in the
Lambda console.

Function Error Handling


You can create custom error handling to raise an exception directly from your Lambda function and
handle it directly (Retry or Catch) within an AWS Step Functions State Machine. For more information,
see Handling Error Conditions Using a State Machine.

Consider a CreateAccount state is a task that writes a customer's details to a database using a Lambda
function.

If the task succeeds, an account is created and a welcome email is sent.


If a user tries to create an account for a username that already exists, the Lambda function raises an
error, causing the state machine to suggest a dierent username and to retry the account-creation
process.

The following code samples demonstrate how to do this. Note that custom errors in Python must extend
the Exception class.

class AccountAlreadyExistsException(Exception): pass

def create_account(event, context):


raise AccountAlreadyExistsException('Account is in use!')

You can congure Step Functions to catch the error using a Catch rule. Lambda automatically sets the
error name to the simple class name of the exception at runtime:

49
AWS Lambda Developer Guide
Programming Model

{
"StartAt": "CreateAccount",
"States": {
"CreateAccount": {
"Type": "Task",
"Resource": "arn:aws:lambda:us-east-1:123456789012:function:CreateAccount",
"Next": "SendWelcomeEmail",
"Catch": [
{
"ErrorEquals": ["AccountAlreadyExistsException"],
"Next": "SuggestAccountName"
}
]
},

}
}

At runtime, AWS Step Functions catches the error, transitioning to the SuggestAccountName state as
specied in the Next transition.

Custom error handling makes it easier to create serverless applications. This feature integrates with all
the languages supported by the Lambda Programming Model (p. 8), allowing you to design your
application in the programming languages of your choice, mixing and matching as you go.

To learn more about creating your own serverless applications using AWS Step Functions and AWS
Lambda, see AWS Step Functions.

Programming Model for Authoring Lambda Functions in C#


The following sections explain how common programming patterns and core concepts apply when
authoring Lambda function code in C#.

Topics
Lambda Function Handler (C#) (p. 51)
The Context Object (C#) (p. 54)
Logging (C#) (p. 55)
Function Errors (C#) (p. 56)

Additionally, note that AWS Lambda provides the following:

Amazon.Lambda.Core This library provides a static Lambda logger, serialization interfaces and a
context object. The Context object (The Context Object (C#) (p. 54)) provides runtime information
about your Lambda function.
Amazon.Lambda.Serialization.Json This an implementation of the serialization interface in
Amazon.Lambda.Core.
Amazon.Lambda.Logging.AspNetCore This provides a library for logging from ASP.NET.
Event objects (POCOs) for several AWS services, including:
Amazon.Lambda.APIGatewayEvents
Amazon.Lambda.CognitoEvents
Amazon.Lambda.CongEvents
Amazon.Lambda.DynamoDBEvents
Amazon.Lambda.KinesisEvents
Amazon.Lambda.S3Events
Amazon.Lambda.SNSEvents

50
AWS Lambda Developer Guide
Programming Model

These packages are available at Nuget Packages.

Lambda Function Handler (C#)


When you create a Lambda function, you specify a handler that AWS Lambda can invoke when the
service executes the function on your behalf.

You dene a Lambda function handler as an instance or static method in a class. If you want access to
the Lambda context object, it is available by dening a method parameter of type ILambdaContext, an
interface you can use to access information about the current execution, such as the name of the current
function, the memory limit, execution time remaining, and logging.

returnType handler-name(inputType input, ILambdaContext context) {


...
}

In the syntax, note the following:

inputType The rst handler parameter is the input to the handler, which can be event data
(published by an event source) or custom input that you provide such as a string or any custom data
object.
returnType If you plan to invoke the Lambda function synchronously (using the RequestResponse
invocation type), you can return the output of your function using any of the supported data types.
For example, if you use a Lambda function as a mobile application backend, you are invoking it
synchronously. Your output data type will be serialized into JSON.

If you plan to invoke the Lambda function asynchronously (using the Event invocation type), the
returnType should be void. For example, if you use AWS Lambda with event sources such as Amazon
S3, Kinesis, and Amazon SNS, these event sources invoke the Lambda function using the Event
invocation type.

Handling Streams
Only the System.IO.Stream type is supported as an input parameter by default.

For example, consider the following C# example code.

using System.IO;
{
namespace Example

public class Hello


{
public Stream MyHandler(Stream stream)
{
//function logic
}
}

In the example C# code, the rst handler parameter is the input to the handler (MyHandler), which can
be event data (published by an event source such as Amazon S3) or custom input you provide such as a
Stream (as in this example) or any custom data object. The output is of type Stream.

Handling Standard Data Types


All other types, as listed below, require you to specify a serializer.

Primitive .NET types (such as string or int).


Collections and maps - IList, IEnumerable, IList<T>, Array, IDictionary, IDictionary<TKey, TValue>

51
AWS Lambda Developer Guide
Programming Model

POCO types (Plain old CLR objects)


Predened AWS event types
For asynchronous invocations the return-type will be ignored by Lambda. The return type may be set
to void in such cases.
If you are using .NET asynchronous programming, the return type can be Task and Task<T> types
and use async and await keywords. For more information, see Using Async in C# Functions with AWS
Lambda (p. 53).

Unless your function input and output parameters are of type System.IO.Stream, you will need to
serialize them. AWS Lambda provides a default serializer that can be applied at the assembly or method
level of your application, or you can dene your own by implementing the ILambdaSerializer interface
provided by the Amazon.Lambda.Core library. For more information, see Creating a Deployment Package
(C#) (p. 61).

To add the default serializer attribute to a method, rst add a dependency on


Amazon.Lambda.Serialization.Json in your project.json le.

{
"version": "1.0.0-*",
"dependencies":{
"Microsoft.NETCore.App": {
"type": "platform",
"version": "1.0.1"
},
"Amazon.Lambda.Serialization.Json": "1.0.0"
},
"frameworks": {
"netcoreapp1.0": {
"imports": "dnxcore50"
}
}
}

The example below illustrates the exibility you can leverage by specifying the default Json.NET
serializer on one method and another of your choosing on a dierent method:

public class ProductService{


[LambdaSerializer(typeof(Amazon.Lambda.Serialization.Json.JsonSerializer))]
public Product DescribeProduct(DescribeProductRequest request)
{
return catalogService.DescribeProduct(request.Id);
}

[LambdaSerializer(typeof(MyJsonSerializer))]
public Customer DescribeCustomer(DescribeCustomerRequest request)
{
return customerService.DescribeCustomer(request.Id);
}
}

Handler Signatures

When creating Lambda functions, you have to provide a handler string that tells AWS Lambda where to
look for the code to invoke. In C#, the format is:

ASSEMBLY::TYPE::METHOD where:

ASSEMBLY is the name of the .NET assembly le for your application. When using the .NET Core CLI
to build your application, if you haven't set the assembly name using the buildOptions.outputName

52
AWS Lambda Developer Guide
Programming Model

setting in project.json, the ASSEMBLY name will be the name of the folder that contains your
project.json le. For more information, see .NET Core CLI (p. 61). In this case, let's assume the folder
name is HelloWorldApp.
TYPE is the full name of the handler type, which consists of the Namespace and the ClassName. In this
case Example.Hello.
METHOD is name of the function handler, in this case MyHandler.

Ultimately, the signature will be of this format: Assembly::Namespace.ClassName::MethodName

Again, consider the following example:

using System.IO;
{
namespace Example

public class Hello


{
public Stream MyHandler(Stream stream)
{
//function logic
}
}

The handler string would be: HelloWorldApp::Example.Hello::MyHandler

For instructions to create a Lambda function using this C# code, see Step 2.4: (Optional) Create a Lambda
Function Authored in C# (p. 196).
Important
If the method specied in your handler string is overloaded, you must provide the exact
signature of the method Lambda should invoke. AWS Lambda will reject an otherwise valid
signature if the resolution would require selecting among multiple (overloaded) signatures.

Lambda Function Handler Restrictions


Note that there are some restrictions on the handler signature

It may not be unsafe and use pointer types in the handler signature, though unsafe context can
be used inside the handler method and its dependencies. For more information, see unsafe (C#
Reference).
It may not pass a variable number of parameters using the params keyword, or use ArgIterator as an
input or return parameter which is used to support variable number of parameters.
The handler may not be a generic method (e.g. IList<T> Sort<T>(IList<T> input)).
Async handlers with signature async void are not supported.

Using Async in C# Functions with AWS Lambda


If you know your Lambda function will require a long-running process, such as uploading large les
to Amazon S3 or reading a large stream of records from DynamoDB, you can take advantage of the
async/await pattern. By creating a handler with this signature, Lambda will execute the function
synchronously and wait a maximum of 5 minutes for execution to complete before returning or timing
out. For example:

public async Task<Response> ProcessS3ImageResizeAsync(SimpleS3Event input)


{
var response = await client.DoAsyncWork(input);
return response;
}

53
AWS Lambda Developer Guide
Programming Model

If you use this pattern, there are some considerations you must take into account:

AWS Lambda will not support async void methods.


If you create an async Lambda function without implementing the await operator, .NET will issue a
compiler warning and you will observe unexpected behavior. For example, some async actions will
execute while others won't. Or some async actions won't complete before the function execution is
complete.

public async Task ProcessS3ImageResizeAsync(SimpleS3Event event) // Compiler warning


{
client.DoAsyncWork(input);
}

Your Lambda function can include multiple async calls, which can be invoked in parallel. You can use
the Task.WaitAll and Task.WaitAny methods to work with multiple tasks. To use the Task.WaitAll
method, you pass a list of the operations as an array to the method. Note that in the example below, if
you neglect to include any operation to the array, that call may return before its operation completes.

public async Task SaveAsync(Profile profile)


{
var s3Save = s3.SaveImage(profile.image);
var ddbSave = ddb.SaveAttributes(profile.Attributes);
var ddbSave2 = ddb.SaveConnections(profile.connections); // Lambda will return before
this call completes
// No compiler warnings
return await Task.WaitAll(new Task[]{ s3Save, ddbSave }); // Did not "await" for
ddbSave2
}

To use the Task.WaitAny method, you again pass a list of operations as an array to the method. The
call returns as soon as the rst operation completes, even if the others are still running.

public async Task<SearchResult> SearchAsync(Query q)


{
var siteSearch1 = site1.SearchAsync(q);
var siteSearch2 = site2.SearchAsync(q);
var siteSearch3 = site3.SearchAsync(q);
var tasks[] = new Task[]{siteSearch1, siteSearch2, siteSearch3};

var index = await Task.WaitAny(tasks); // Returns as soon as any of the tasks complete,
other task may run in background
return tasks[index].Result;
}

We do not recommend using Task.WaitAny for the above reasons.

The Context Object (C#)


You can gain useful information on how your Lambda function is interacting with the AWS Lambda
runtime by adding the ILambdaContext parameter to your method. In return, AWS Lambda provides
runtime details such as the CloudWatch log stream associated with the function or the id of the client
that called your functions, which you access via the properties provided by the context object.

To do this, create a method with the following signature:

public void Handler(string Input, ILambdaContext context)

The context object properties are:

54
AWS Lambda Developer Guide
Programming Model

MemoryLimitInMB: Memory limit, in MB, you congured for the Lambda function.
FunctionName: Name of the Lambda function that is running.
FunctionVersion: The Lambda function version that is executing. If an alias is used to invoke the
function, then FunctionVersion will be the version the alias points to.
InvokedFunctionArn: The ARN used to invoke this function. It can be function ARN or alias ARN. An
unqualied ARN executes the $LATEST version and aliases execute the function version it is pointing to.
AwsRequestId: AWS request ID associated with the request. This is the ID returned to the client that
invoked this Lambda function. You can use the request ID for any follow up enquiry with AWS support.
Note that if AWS Lambda retries the function (for example, in a situation where the Lambda function
processing Kinesis records throw an exception), the request ID remains the same.
LogStreamName: The CloudWatch log stream name for the particular Lambda function execution. It can
be null if the IAM user provided does not have permission for CloudWatch actions.
LogGroupName: The CloudWatch log group name associated with the Lambda function invoked. It can
be null if the IAM user provided does not have permission for CloudWatch actions.
ClientContext: Information about the client application and device when invoked through the AWS
Mobile SDK. It can be null. Client context provides client information such as client ID, application
title, version name, version code, and the application package name.
Identity: Information about the Amazon Cognito identity provider when invoked through the AWS
Mobile SDK. It can be null.
RemainingTime: Remaining execution time till the function will be terminated. At the time you create
the Lambda function you set maximum time limit, at which time AWS Lambda will terminate the
function execution. Information about the remaining time of function execution can be used to specify
function behavior when nearing the timeout. This is a TimeSpan eld.
Logger: The Lambda logger associated with the ILambdaContext object. For more information, see
Logging (C#) (p. 55).

The following C# code snippet shows a simple handler function that displays the value of the input
parameter and then prints some of the context information.

public async Task Handler(ILambdaContext context)


{
Console.Writeline("Function name: " + context.FunctionName);
Console.Writeline("RemainingTime: " + context.RemainingTime);
await Task.Delay(TimeSpan.FromSeconds(0.42));
Console.Writeline("RemainingTime after sleep: " + context.RemainingTime);
}

Logging (C#)
Your Lambda function can contain logging statements and, in turn, AWS Lambda writes these logs to
CloudWatch Logs.

In the C# programming model, there are three ways to log data in your function:

Use the static Write or WriteLine methods provided by the C# Console class. Anything written
to standard out or standard error - using Console.Write or a similar method - will be logged in
CloudWatch Logs.

public class ProductService


{
public async Task<Product> DescribeProduct(DescribeProductRequest request)
{
Console.WriteLine("DescribeProduct invoked with Id " + request.Id);
return await catalogService.DescribeProduct(request.Id);

55
AWS Lambda Developer Guide
Programming Model

}
}

Use the Log method on the Amazon.Lambda.Core.LambdaLogger class. This is a static class that can be
used anywhere in your application. To use this, you must include the Amazon.Lambda.Core library.

using Amazon.Lambda.Core;

public class ProductService


{
public async Task<Product> DescribeProduct(DescribeProductRequest request)
{
LambdaLogger.Log("DescribeProduct invoked with Id " + request.Id);
return await catalogService.DescribeProduct(request.Id);
}
}

Each call to LambdaLogger.Log results in a CloudWatch Logs event, provided the event size is within
the allowed limits. For information about CloudWatch Logs limits, see CloudWatch Logs Limits in the
Amazon CloudWatch User Guide.
Use the logger in ILambdaContext. The ILambdaContext object (if specied) in your method contains a
Logger property that represents a LambdaLogger. The following is an example of using this method:

public class ProductService


{
public async Task<Product> DescribeProduct(DescribeProductRequest request,
ILambdaContext context)
{
context.Logger.Log("DescribeProduct invoked with Id " + request.Id);
return await catalogService.DescribeProduct(request.Id);
}
}

How to Find Logs


You can nd the logs that your Lambda function writes, as follows:

Find logs in CloudWatch Logs. The ILambdaContext object provides the LogStreamName and the
LogGroupName properties. Using these properties, you can nd the specic log stream where logs are
written.
If you invoke a Lambda function via the console, the invocation type is always RequestResponse (that
is, synchronous execution) and the console displays the logs that the Lambda function writes using
the LambdaLogger object. AWS Lambda also returns logs from Console.Write and Console.WriteLine
methods.
If you invoke a Lambda function programmatically, you can add the LogType parameter to retrieve the
last 4 KB of log data that is written to CloudWatch Logs. For more information, see Invoke (p. 401).
AWS Lambda returns this log information in the x-amz-log-results header in the response. If you use
the AWS Command Line Interface to invoke the function, you can specify the --log-type parameter
with value Tail.

Function Errors (C#)


When an exception occurs in your Lambda function, Lambda will report the exception information back
to you. Exceptions can occur in two dierent places:

Initialization (Lambda loading your code, validating the handler string, and creating an instance of
your class if it is non-static).

56
AWS Lambda Developer Guide
Programming Model

The Lambda function invocation.

The serialized exception information is returned as the payload as a modeled JSON object and outputted
to CloudWatch logs.

In the initialization phase, exceptions can be thrown for invalid handler strings, a rule-breaking type or
method (see Lambda Function Handler Restrictions (p. 53)), or any other validation method (such as
forgetting the serializer attribute and having a POCO as your input or output type). These exceptions are
of type LambdaException. For example:

{
"errorType": "LambdaException",
"errorMessage": "Invalid lambda function handler: 'http://this.is.not.a.valid.handler/'.
The valid format is 'ASSEMBLY::TYPE::METHOD'."
}

If your constructor throws an exception, the error type is also of type LambdaException, but the
exception thrown during construction is provided in the cause property, which is itself a modeled
exception object:

{
"errorType": "LambdaException",
"errorMessage": "An exception was thrown when the constructor for type
'LambdaExceptionTestFunction.ThrowExceptionInConstructor'
was invoked. Check inner exception for more details.",
"cause": {
"errorType": "TargetInvocationException",
"errorMessage": "Exception has been thrown by the target of an invocation.",
"stackTrace": [
"at System.RuntimeTypeHandle.CreateInstance(RuntimeType type, Boolean publicOnly,
Boolean noCheck, Boolean&canBeCached,
RuntimeMethodHandleInternal&ctor, Boolean& bNeedSecurityCheck)",
"at System.RuntimeType.CreateInstanceSlow(Boolean publicOnly, Boolean skipCheckThis,
Boolean fillCache, StackCrawlMark& stackMark)",
"at System.Activator.CreateInstance(Type type, Boolean nonPublic)",
"at System.Activator.CreateInstance(Type type)"
],
"cause": {
"errorType": "ArithmeticException",
"errorMessage": "Sorry, 2 + 2 = 5",
"stackTrace": [
"at LambdaExceptionTestFunction.ThrowExceptionInConstructor..ctor()"
]
}
}
}

As the example shows, the inner exceptions are always preserved (as the cause property), and can be
deeply nested.

Exceptions can also occur during invocation. In this case, the exception type is preserved and the
exception is returned directly as the payload and in the CloudWatch logs. For example:

{
"errorType": "AggregateException",
"errorMessage": "One or more errors occurred. (An unknown web exception occurred!)",
"stackTrace": [
"at System.Threading.Tasks.Task.ThrowIfExceptional(Boolean
includeTaskCanceledExceptions)",

57
AWS Lambda Developer Guide
Programming Model

"at System.Threading.Tasks.Task`1.GetResultCore(Boolean waitCompletionNotification)",


"at lambda_method(Closure , Stream , Stream , ContextInfo )"
],
"cause": {
"errorType": "UnknownWebException",
"errorMessage": "An unknown web exception occurred!",
"stackTrace": [
"at LambdaDemo107.LambdaEntryPoint.<GetUriResponse>d__1.MoveNext()",
"--- End of stack trace from previous location where exception was thrown ---",
"at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)",
"at
System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task
task)",
"at System.Runtime.CompilerServices.TaskAwaiter`1.GetResult()",
"at LambdaDemo107.LambdaEntryPoint.<CheckWebsiteStatus>d__0.MoveNext()"
],
"cause": {
"errorType": "WebException",
"errorMessage": "An error occurred while sending the request. SSL peer certificate or
SSH remote key was not OK",
"stackTrace": [
"at System.Net.HttpWebRequest.EndGetResponse(IAsyncResult asyncResult)",
"at System.Threading.Tasks.TaskFactory`1.FromAsyncCoreLogic(IAsyncResult iar,
Func`2 endFunction, Action`1 endAction, Task`1 promise, Boolean requiresSynchronization)",
"--- End of stack trace from previous location where exception was thrown ---",
"at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)",
"at
System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task
task)",
"at System.Runtime.CompilerServices.TaskAwaiter`1.GetResult()",
"at LambdaDemo107.LambdaEntryPoint.<GetUriResponse>d__1.MoveNext()"
],
"cause": {
"errorType": "HttpRequestException",
"errorMessage": "An error occurred while sending the request.",
"stackTrace": [
"at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)",
"at
System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task
task)",
"at System.Net.Http.HttpClient.<FinishSendAsync>d__58.MoveNext()",
"--- End of stack trace from previous location where exception was thrown ---",
"at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)",
"at
System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task
task)",
"at System.Net.HttpWebRequest.<SendRequest>d__63.MoveNext()",
"--- End of stack trace from previous location where exception was thrown ---",
"at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)",
"at
System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task
task)",
"at System.Net.HttpWebRequest.EndGetResponse(IAsyncResult asyncResult)"
],
"cause": {
"errorType": "CurlException",
"errorMessage": "SSL peer certificate or SSH remote key was not OK",
"stackTrace": [
"at System.Net.Http.CurlHandler.ThrowIfCURLEError(CURLcode error)",
"at
System.Net.Http.CurlHandler.MultiAgent.FinishRequest(StrongToWeakReference`1 easyWrapper,
CURLcode messageResult)"
]
}
}
}

58
AWS Lambda Developer Guide
Programming Model

}
}

The method in which error information is conveyed depends on the invocation type:

RequestResponse invocation type (that is, synchronous execution): In this case, you get the error
message back.

For example, if you invoke a Lambda function using the Lambda console, the RequestResponse is
always the invocation type and the console displays the error information returned by AWS Lambda in
the Execution result section of the console.
Event invocation type (that is, asynchronous execution): In this case AWS Lambda does not return
anything. Instead, it logs the error information in CloudWatch Logs and CloudWatch metrics.

Depending on the event source, AWS Lambda may retry the failed Lambda function. For more
information, see Retries on Errors (p. 178).

Function Error Handling

You can create custom error handling to raise an exception directly from your Lambda function and
handle it directly (Retry or Catch) within an AWS Step Functions State Machine. For more information,
see Handling Error Conditions Using a State Machine.

Consider a CreateAccount state is a task that writes a customer's details to a database using a Lambda
function.

If the task succeeds, an account is created and a welcome email is sent.


If a user tries to create an account for a username that already exists, the Lambda function raises an
error, causing the state machine to suggest a dierent username and to retry the account-creation
process.

The following code samples demonstrate how to do this. Note that custom errors in C# must extend the
Exception class.

namespace Example {
public class AccountAlreadyExistsException : Exception {
public AccountAlreadyExistsException(String message) :
base(message) {
}
}
}

namespace Example {
public class Handler {
public static void CreateAccount() {
throw new AccountAlreadyExistsException("Account is in use!");
}
}
}

You can congure Step Functions to catch the error using a Catch rule. Lambda automatically sets the
error name to the simple class name of the exception at runtime:

{
"StartAt": "CreateAccount",
"States": {
"CreateAccount": {

59
AWS Lambda Developer Guide
Creating a Deployment Package

"Type": "Task",
"Resource": "arn:aws:lambda:us-east-1:123456789012:function:CreateAccount",
"Next": "SendWelcomeEmail",
"Catch": [
{
"ErrorEquals": ["AccountAlreadyExistsException"],
"Next": "SuggestAccountName"
}
]
},

}
}

At runtime, AWS Step Functions catches the error, transitioning to the SuggestAccountName state as
specied in the Next transition.

Custom error handling makes it easier to create serverless applications. This feature integrates with all
the languages supported by the Lambda Programming Model (p. 8), allowing you to design your
application in the programming languages of your choice, mixing and matching as you go.

To learn more about creating your own serverless applications using AWS Step Functions and AWS
Lambda, see AWS Step Functions.

Creating a Deployment Package


To create a Lambda function you rst create a Lambda function deployment package, a .zip or .jar le
consisting of your code and any dependencies. When creating the zip, include only the code and its
dependencies, not the containing folder.

Creating a Deployment Package (Node.js) (p. 60)


Creating a Deployment Package (Java) (p. 66)
Creating a Deployment Package (C#) (p. 61)
Creating a Deployment Package (Python) (p. 73)

Creating a Deployment Package (Node.js)


To create a Lambda function you rst create a Lambda function deployment package, a .zip le
consisting of your code and any dependencies.

You can create a deployment package yourself or write your code directly in the Lambda console, in
which case the console creates the deployment package for you and uploads it, creating your Lambda
function. Note the following to determine if you can use the console to create your Lambda function:

Simple scenario If your custom code requires only the AWS SDK library, then you can use the
inline editor in the AWS Lambda console. Using the console, you can edit and upload your code to
AWS Lambda. The console will zip up your code with the relevant conguration information into a
deployment package that the Lambda service can run.

You can also test your code in the console by manually invoking it using sample event data.
Note
The Lambda service has preinstalled the AWS SDK for Node.js.
Advanced scenario If you are writing code that uses other resources, such as a graphics library for
image processing, or you want to use the AWS CLI instead of the console, you need to rst create the
Lambda function deployment package, and then use the console or the CLI to upload the package.

60
AWS Lambda Developer Guide
Creating a Deployment Package

Note
After you create a deployment package, you may either upload it directly or upload the .zip le
rst to an Amazon S3 bucket in the same AWS region where you want to create the Lambda
function, and then specify the bucket name and object key name when you create the Lambda
function using the console or the AWS CLI.

The following is an example procedure to create a deployment package (outside the console). Suppose
you want to create a deployment package that includes a filename.js code le and your code uses the
async library.

1. Open a text editor, and write your code. Save the le (for example, filename.js).

You will use the le name to specify the handler at the time of creating the Lambda function.
2. In the same directory, use npm to install the libraries that your code depends on. For example, if your
code uses the async library, use the following npm command.

npm install async

3. Your directory will then have the following structure:

filename.js
node_modules/async
node_modules/async/lib
node_modules/async/lib/async.js
node_modules/async/package.json

4. Zip the content of the folder, that is your deployment package (for example, sample.zip).

Then, specify the .zip le name as your deployment package at the time you create your Lambda
function.

If you want to include your own binaries, including native ones, just package them in the Zip le you
upload and then reference them (including the relative path within the Zip le you created) when you
call them from Node.js or from other processes that youve previously started. Ensure that you include
the following at the start of your function code: process.env[PATH] = process.env[PATH] + : +
process.env[LAMBDA_TASK_ROOT]

For more information on including native binaries in your Lambda function package, see Running
Executables in AWS Lambda.

Creating a Deployment Package (C#)


You can create .NET-core based AWS Lambda applications and package them for deployment in the
following ways:

Use the .NET Core CLI, which you can download here to create your Lambda application.
Use the Lambda plugin to the AWS ToolKit for Microsoft Visual Studio, which can you download here.

Topics
.NET Core CLI (p. 61)
AWS Toolkit for Visual Studio (p. 64)

.NET Core CLI


The .NET Core CLI oers a cross-platform way for you to create .NET-based Lambda applications.

61
AWS Lambda Developer Guide
Creating a Deployment Package

Before You Begin

This section assumes you have done the following:

Installed the .NET Core CLI. If you haven't, do so here.

Create a .NET Project

To create an application using the .NET Core CLI, open a command prompt and navigate to the folder
where you installed the .NET Core runtime and follow these steps:

1. Make a directory where your project will be created using the following command: mkdir example
2. Navigate to that directory using the following command: cd example
3. Enter the following command: dotnet new console

This will create two les in your example directory:

Program.cs, which is where you write your Lambda function code.


project.json, which is the le is where you declare Nuget dependencies (or dependencies on
local projects). NuGet is the package manager for the .NET platform. For more information, see
Nuget.org.

Note
Lambda methods don't use the Main() entry point provided by default in .NET, so open the
project.json le and remove the "buildOptions" property. After this, your project.json should
look something like this (exact versions may dier depending on when you installed the
NetCore CLI):

{
"version": "1.0.0-*",
"dependencies": {},
"frameworks": {
"netcoreapp1.0": {
"dependencies": {
"Microsoft.NETCore.App": {
"type": "platform",
"version": "1.1.0"
}
},
"imports": "dnxcore50"
}
}
}

4. Open the Program.cs le using an editor of you choice, such as Microsoft Visual Studio.

Replace the default code that is provided with your Lambda function handler code:

At this point, your .cs le structure should resemble this:

using System;
using System.IO;

namespace CSharpLambdaFunction
{
public class LambdaHandler
{
public Stream myHandler(Stream inputStream)
{

62
AWS Lambda Developer Guide
Creating a Deployment Package

//function logic
}
}
}

Your Lambda function handler signature should be of the format


Assembly::Namespace.ClassName::MethodName. For more information, see Handler Signatures (p. 52).

Using a Serializer
For any Lambda functions that use input or output types other than a Stream object, you will need to
add a serialization library to your application. You can do this in the following ways:

Use Json.NET. Lambda will provide an implementation for JSON serializer using JSON.NET as a NuGet
package.
Create your own serialization library by implementing the ILambdaSerializer interface, which is
available as part of the Amazon.Lambda.Core library. The interface denes two methods:
T Deserialize<T>(Stream requestStream);

You implement this method to deserialize the request payload from the Invoke API into the object
that is passed to the Lambda function handler.
T Serialize<T>(T response, Stream responseStream);.

You implement this method to serialize the result returned from the Lambda function handler into
the response payload that is returned by the Invoke API.

You use whichever serializer you wish by adding it as a dependency to your project.json le.

{
"version": "1.0.0-*",
"buildOptions": {
},

"dependencies": {
"Microsoft.NETCore.App": {
"type": "platform",
"version": "1.0.1"
},

"Newtonsoft.Json": "9.0.1",

"Amazon.Lambda.Core": "1.0.0*",
"Amazon.Lambda.Serialization.Json": "1.0.0",

"Amazon.Lambda.Tools" : {
"type" :"build",
"version":"0.9.0-preview1"
}
},

"tools": {
"Amazon.Lambda.Tools" : "0.9.0-preview1"
},

"frameworks": {
"netcoreapp1.0": {
"imports": "dnxcore50"
}
}

63
AWS Lambda Developer Guide
Creating a Deployment Package

You then add it to your AssemblyInfo.cs le. For example, if you are using the default Json.NET serializer,
this is what you would add:

[assembly:LambdaSerializer(typeof(Amazon.Lambda.Serialization.Json.JsonSerializer))]

Note
You can dene a custom serialization attribute at the method level, which will override the
default serializer specied at the assembly level. For more information, see Handling Standard
Data Types (p. 51).

Create the Deployment Package

To create the deployment package, open a command prompt and navigate to the folder that contains
your project.json le and run the following commands:

dotnet restore which will restore any references to dependencies of the project that may have
changed during the development process.
dotnet publish which compiles the application and packages the source code and any dependencies
into a folder. The output of the command window will instruct you where the folder was created. For
example:

publish: Published to C:\Users\yourname\project-folder\bin\debug\netcoreapp1.1\publish

The contents of this folder represent your application and at a minimum would look something like
this:

application-name.deps.json

application-name.dll

application-name.pdb

application-name.runtimecong.json

Zip the contents of the folder (not the folder itself). This is your deployment package.

AWS Toolkit for Visual Studio


You can build .NET-based Lambda applications using the Lambda plugin to the AWS Toolkit for Visual
Studio. The plugin is available as part of a Nuget package.

Step 1: Create and Build a Project

1. Launch Microsoft Visual Studio and choose New project.

a. From the File menu, choose New, and then choose Project.
b. In the New Project window, choose AWS Lambda Project (.NET Core) and then choose OK.
c. In the Select Blueprint window, you will be presented with the option of selecting from a list of
sample applications that will provide you with sample code to get started with creating a .NET-
based Lambda application.
d. To create a Lambda application from scratch, choose Blank Function and then choose Finish.
e. Note that the libraries necessary for you to build a .NET-based Lambda application are provided
in the References node of your project.

64
AWS Lambda Developer Guide
Creating a Deployment Package

2. Open the Function.cs le. You will be provided with a template to implement your Lambda function
handler code.

3. Once you have written the code that represents your Lambda function, you can upload it by right-
clicking the Project node in your application and then choosing Publish to AWS Lambda.
4. In the Upload Lambda Function window, do the following:

Specify the Region:


Specify the Function Name:
Specify the Assembly Name:
Specify the Type Name:
Specify the Method Name:

Then choose Next


5. In the Advanced Function Details window, do the following:

Specify the Role Name:, which is the IAM role required for your Lambda function's execution. If
you have not yet created an execution role, do the following:

1. Sign in to the AWS Management Console and open the IAM console at https://
console.aws.amazon.com/iam/.
2. Follow the steps in Creating a Role to Delegate Permissions to an AWS Service in the IAM User
Guide to create an IAM role (execution role). As you follow the steps to create a role, note the
following:
In Role Name, use a name that is unique within your AWS account.

65
AWS Lambda Developer Guide
Creating a Deployment Package

In Select Role Type, choose AWS Service Roles, and then choose a service role that grants
that service permissions to assume the role.
In Attach Policy, choose a permissions policy that is suitable to execute your Lambda
function.
(Optional) In Environment:: specify any environment variables you wish to use. For more
information, see Environment Variables (p. 92).
(Optional)Specify the Memory (MB): or Timeout (Secs): congurations.
(Optional)Specify any VPC: congurations if your Lambda function needs to access resources
running inside a private VPC. For more information, see Conguring a Lambda Function to Access
Resources in an Amazon VPC (p. 103).
Choose Next and then choose Upload to deploy your application.

Creating a Deployment Package (Java)


Your deployment package can be a .zip le or a standalone jar; it is your choice. You can use any build
and packaging tool you are familiar with to create a deployment package.

We provide examples of using Maven to create standalone jars and using Gradle to create a .zip le. For
more information, see the following topics:

Topics
Creating a .jar Deployment Package Using Maven without any IDE (Java) (p. 66)
Creating a .jar Deployment Package Using Maven and Eclipse IDE (Java) (p. 68)
Creating a .zip Deployment Package (Java) (p. 70)
Authoring Lambda Functions Using Eclipse IDE and AWS SDK Plugin (Java) (p. 73)

Creating a .jar Deployment Package Using Maven without any IDE (Java)
This section shows how to package your Java code into a deployment package using Maven at the
command line.

Topics
Before You Begin (p. 66)
Project Structure Overview (p. 66)
Step 1: Create Project (p. 67)
Step 2: Build Project (Create Deployment Package) (p. 68)

Before You Begin

You will need to install the Maven command-line build tool. For more information, go to Maven. If you
are using Linux, check your package manager.

sudo apt-get install mvn

if you are using Homebrew

brew install maven

Project Structure Overview

After you set up the project, you should have the following folder structure:

66
AWS Lambda Developer Guide
Creating a Deployment Package

project-dir/pom.xml
project-dir/src/main/java/ (your code goes here)

Your code will then be in the /java folder. For example, if your package name is example and you have a
Hello.java class in it, the structure will be:

project-dir/src/main/java/example/Hello.java

After you build the project, the resulting .jar le (that is, your deployment package), will be in the
project-dir/target subdirectory.

Step 1: Create Project

Follow the steps in this section to create a Java project.

1. Create a project directory (project-dir).


2. In the project-dir directory, create the following:

Project Object Model le, pom.xml. Add the following project information and conguration
details for Maven to build the project.

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/


XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-
v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>

<groupId>doc-examples</groupId>
<artifactId>lambda-java-example</artifactId>
<packaging>jar</packaging>
<version>1.0-SNAPSHOT</version>
<name>lambda-java-example</name>

<dependencies>
<dependency>
<groupId>com.amazonaws</groupId>
<artifactId>aws-lambda-java-core</artifactId>
<version>1.1.0</version>
</dependency>
</dependencies>

<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-shade-plugin</artifactId>
<version>2.3</version>
<configuration>
<createDependencyReducedPom>false</createDependencyReducedPom>
</configuration>
<executions>
<execution>
<phase>package</phase>
<goals>
<goal>shade</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>

67
AWS Lambda Developer Guide
Creating a Deployment Package

</project>

Note
In the dependencies section, the groupId (that is, com.amazonaws) is the Amazon AWS
group ID for Maven artifacts in the Maven Central Repository. The artifactId (that is,
aws-lambda-java-core) is the AWS Lambda core library that provides denitions of the
RequestHandler, RequestStreamHandler, and the Context AWS Lambda interfaces for
use in your Java application. At the build time Maven resolves these dependencies.
In the plugins section, the Apache maven-shade-plugin is a plugin that Maven will
download and use during your build process. This plugin is used for packaging jars to
create a standalone .jar (a .zip le), your deployment package.
If you are following other tutorial topics in this guide, the specic tutorials might
require you to add more dependencies. Make sure to add those dependencies as
required.
3. In the project-dir, create the following structure:

project-dir/src/main/java

4. Under the /java subdirectory you add your Java les and folder structure, if any. For example, if you
Java package name is example, and source code is Hello.java, your directory structure looks like
this:

project-dir/src/main/java/example/Hello.java

Step 2: Build Project (Create Deployment Package)

Now you can build the project using Maven at the command line.

1. At a command prompt, change directory to the project directory (project-dir).


2. Run the following mvn command to build the project:

$ mvn package

The resulting .jar is saved as project-dir/target/lambda-java-example-1.0-SNAPSHOT.jar. The .jar


name is created by concatenating the artifactId and version in the pom.xml le.

The build creates this resulting .jar, using information in the pom.xml to do the necessary transforms.
This is a standalone .jar (.zip le) that includes all the dependencies. This is your deployment
package that you can upload to AWS Lambda to create a Lambda function.

Creating a .jar Deployment Package Using Maven and Eclipse IDE (Java)
This section shows how to package your Java code into a deployment package using Eclipse IDE and
Maven plugin for Eclipse.

Topics
Before You Begin (p. 68)
Step 1: Create and Build a Project (p. 69)

Before You Begin

Install the Maven Plugin for Eclipse.

68
AWS Lambda Developer Guide
Creating a Deployment Package

1. Start Eclipse. From the Help menu in Eclipse, choose Install New Software.
2. In the Install window, type http://download.eclipse.org/technology/m2e/releases in the Work
with: box, and choose Add.
3. Follow the steps to complete the setup.

Step 1: Create and Build a Project

In this step, you start Eclipse and create a Maven project. You will add the necessary dependencies, and
build the project. The build will produce a .jar, which is your deployment package.

1. Create a new Maven project in Eclipse.

a. From the File menu, choose New, and then choose Project.
b. In the New Project window, choose Maven Project.
c. In the New Maven Project window, choose Create a simple project, and leave other default
selections.
d. In the New Maven Project, Congure project windows, type the following Artifact information:

Group Id: doc-examples


Artifact Id: lambda-java-example
Version: 0.0.1-SNAPSHOT
Packaging: jar
Name: lambda-java-example
2. Add the aws-lambda-java-core dependency to the pom.xml le.

It provides denitions of the RequestHandler, RequestStreamHandler, and Context interfaces. This


allows you to compile code that you can use with AWS Lambda.

a. Open the context (right-click) menu for the pom.xml le, choose Maven, and then choose Add
Dependency.
b. In the Add Dependency windows, type the following values:

Group Id: com.amazonaws

Artifact Id: aws-lambda-java-core

Version: 1.1.0
Note
If you are following other tutorial topics in this guide, the specic tutorials might
require you to add more dependencies. Make sure to add those dependencies as
required.
3. Add Java class to the project.

a. Open the context (right-click) menu for the src/main/java subdirectory in the project, choose
New, and then choose Class.
b. In the New Java Class window, type the following values:

Package: example
Name: Hello
Note
If you are following other tutorial topics in this guide, the specic tutorials might
recommend dierent package name or class name.

69
AWS Lambda Developer Guide
Creating a Deployment Package

c. Add your Java code. If you are following other tutorial topics in this guide, add the provided
code.
4. Build the project.

Open the context (right-click) menu for the project in Package Explorer, choose Run As, and then
choose Maven Build .... In the Edit Conguration window, type package in the Goals box.
Note
The resulting .jar, lambda-java-example-0.0.1-SNAPSHOT.jar, is not the nal
standalone .jar that you can use as your deployment package. In the next step, you add
the Apache maven-shade-plugin to create the standalone .jar. For more information, go to
Apache Maven Shade Plugin.
5. Add the maven-shade-plugin plugin and rebuild.

The maven-shade-plugin will take artifacts (jars) produced by the package goal (produces customer
code .jar), and created a standalone .jar that contains the compiled customer code, and the resolved
dependencies from the pom.xml.

a. Open the context (right-click) menu for the pom.xml le, choose Maven, and then choose Add
Plugin.
b. In the Add Plugin window, type the following values:

Group Id: org.apache.maven.plugins


Artifact Id: maven-shade-plugin
Version: 2.3
c. Now build again.

This time we will create the jar as before, and then use the maven-shade-plugin to pull in
dependencies to make the standalone .jar.

i. Open the context (right-click) menu for the project, choose Run As, and then choose Maven
build ....
ii. In the Edit Conguration windows, type package shade:shade in the Goals box.
iii. Choose Run.

You can nd the resulting standalone .jar (that is, your deployment package), in the /target
subdirectory.

Open the context (right-click) menu for the /target subdirectory, choose Show In, choose
System Explorer, and you will nd the lambda-java-example-0.0.1-SNAPSHOT.jar.

Creating a .zip Deployment Package (Java)


This section provides examples of creating .zip le as your deployment package. You can use any build
and packaging tool you like to create this zip. Regardless of the tools you use, the resulting .zip le must
have the following structure:

All compiled class les and resource les at the root level.
All required jars to run the code in the /lib directory.

Note
You can also build a standalone .jar (also a zipped le) as your deployment package. For
examples of creating standalone .jar using Maven, see Creating a Deployment Package
(Java) (p. 66).

70
AWS Lambda Developer Guide
Creating a Deployment Package

The following examples use Gradle build and deployment tool to create the .zip.
Important
Gradle version 2.0 or later is required.

Before You Begin


You will need to download Gradle. For instructions, go to the gradle website, https://gradle.org/ .

Example 1: Creating .zip Using Gradle and the Maven Central Repository
At the end of this walkthrough, you will have a project directory (project-dir) with content having the
following structure:

project-dir/build.gradle
project-dir/src/main/java/

The /java folder will contain your code. For example, if your package name is example, and you have a
Hello.java class in it, the structure will be:

project-dir/src/main/java/example/Hello.java

After you build the project, the resulting .zip le (that is, your deployment package), will be in the
project-dir/build/distributions subdirectory.

1. Create a project directory (project-dir).


2. In the project-dir, create build.gradle le and add the following content:

apply plugin: 'java'

repositories {
mavenCentral()
}

dependencies {
compile (
'com.amazonaws:aws-lambda-java-core:1.1.0',
'com.amazonaws:aws-lambda-java-events:1.1.0'
)
}

task buildZip(type: Zip) {


from compileJava
from processResources
into('lib') {
from configurations.runtime
}
}

build.dependsOn buildZip

Note

The repositories section refers to Maven Central Repository. At the build time, it fetches
the dependencies (that is, the two AWS Lambda libraries) from Maven Central.
The buildZip task describes how to create the deployment package .zip le.

For example, if you unzip the resulting .zip le you should nd any of the compiled class
les and resource les at the root level. You should also nd a /lib directory with the
required jars for running the code.

71
AWS Lambda Developer Guide
Creating a Deployment Package

If you are following other tutorial topics in this guide, the specic tutorials might require
you to add more dependencies. Make sure to add those dependencies as required.
3. In the project-dir, create the following structure:

project-dir/src/main/java/

4. Under the /java subdirectory you add your Java les and folder structure, if any. For example, if you
Java package name is example, and source code is Hello.java, then your directory structure looks
like this:

project-dir/src/main/java/example/Hello.java

5. Run the following gradle command to build and package the project in a .zip le.

project-dir> gradle build

6. Verify the resulting project-dir.zip le in the project-dir/build/distributions subdirectory.


7. Now you can upload the .zip le, your deployment package to AWS Lambda to create a Lambda
function and test it by manually invoking it using sample event data. For instruction, see Step 2.3:
(Optional) Create a Lambda Function Authored in Java (p. 195).

Example 2: Creating .zip Using Gradle Using Local Jars

You may choose not to use the Maven Central repository. Instead have all the dependencies in the
project folder. In this case your project folder (project-dir) will have the following structure:

project-dir/jars/ (all jars go here)


project-dir/build.gradle
project-dir/src/main/java/ (your code goes here)

So if your Java code has example package and Hello.java class, the code will be in the following
subdirectory:

project-dir/src/main/java/example/Hello.java

You build.gradle le should be as follows:

apply plugin: 'java'

dependencies {
compile fileTree(dir: 'jars', include: '*.jar')
}

task buildZip(type: Zip) {


from compileJava
from processResources
into('lib') {
from configurations.runtime
}
}

build.dependsOn buildZip

Note that the dependencies specify fileTree which identies project-dir/jars as the subdirectory that
will include all the required jars.

72
AWS Lambda Developer Guide
Creating a Deployment Package

Now you build the package. Run the following gradle command to build and package the project in a .zip
le.

project-dir> gradle build

Authoring Lambda Functions Using Eclipse IDE and AWS SDK Plugin (Java)
AWS SDK Eclipse Toolkit provides an Eclipse plugin for you to both create a deployment package and
also upload it to create a Lambda function. If you can use Eclipse IDE as your development environment,
this plugin enables you to author Java code, create and upload a deployment package, and create your
Lambda function. For more information, see the AWS Toolkit for Eclipse Getting Started Guide. For an
example of using the toolkit for authoring Lambda functions, see Using AWS Lambda with the AWS
Toolkit for Eclipse.

Creating a Deployment Package (Python)


To create a Lambda function you rst create a Lambda function deployment package, a .zip le
consisting of your code and any dependencies.

You can create a deployment package yourself or write your code directly in the Lambda console, in
which case the console creates the deployment package for you and uploads it, creating your Lambda
function. Note the following to determine if you can use the console to create your Lambda function:

Simple scenario If your custom code requires only the AWS SDK library, then you can use the
inline editor in the AWS Lambda console. Using the console, you can edit and upload your code to
AWS Lambda. The console will zip up your code with the relevant conguration information into a
deployment package that the Lambda service can run.

You can also test your code in the console by manually invoking it using sample event data.
Note
The Lambda service has preinstalled the AWS SDK for Python.
Advanced scenario If you are writing code that uses other resources, such as a graphics library for
image processing, or you want to use the AWS CLI instead of the console, you need to rst create the
Lambda function deployment package, and then use the console or the CLI to upload the package.

Note
After you create a deployment package, you may either upload it directly or upload the .zip le
rst to an Amazon S3 bucket in the same AWS region where you want to create the Lambda
function, and then specify the bucket name and object key name when you create the Lambda
function using the console or the AWS CLI.

The following is an example procedure to create a deployment package (outside the console).
Note
This should work for most standard installations of Python and pip when using pure Python
modules in your Lambda function. If you are including modules that have native dependencies
or have Python installed with Homebrew on OS X, you should see the next section which
provides instructions to create a deployment package when using Virtualenv. For more
information, see Create Deployment Package Using a Python Environment Created with
Virtualenv (p. 74) and the Virtualenv website.

You will use pip to install dependencies/libraries. For information to install pip, go to Installation.

1. You create a directory, for example project-dir.


2. Save all of your Python source les (the .py les) at the root level of this directory.
3. Install any libraries using pip. Again, you install these libraries at the root level of the directory.

73
AWS Lambda Developer Guide
Creating a Deployment Package

pip install module-name -t /path/to/project-dir

For example, the following command installs the requests HTTP library in the project-dir
directory.

pip install requests -t /path/to/project-dir

If using Mac OS X and you have Python installed using Homebrew (see Homebrew), the preceding
command will not work. A simple workaround is to add a setup.cfg le in your /path/to/project-
dir with the following content.

[install]
prefix=

4. Zip the content of the project-dir directory, which is your deployment package.
Important
Zip the directory content, not the directory. The contents of the Zip le are available as the
current working directory of the Lambda function. For example: /project-dir/codele.py/lib/
yourlibraries

Note
AWS Lambda includes the AWS SDK for Python (Boto 3), so you don't need to include it in
your deployment package. However, if you want to use a version of Boto3 other than the one
included by default, you can include it in your deployment package.

Create Deployment Package Using a Python Environment Created with


Virtualenv
This section explains how to create a deployment package if you are using a Python environment that
you created with the Virtualenv tool. Consider the following example:

Created the following isolated Python environment using the Virtualenv tool and activated the
environment:

virtualenv path/to/my/virtual-env

You can activate the environment on Windows, OS X, and Linux as follows:


On Windows, you activate using the activate.bat:

path\to\my\virtual-env\Scripts\activate.bat

On OS X and Linux, you source the activate script:

source path/to/my/virtual-env/bin/activate

Also, suppose you have installed the requests package in the activated environment (assume that you
will you use these in your code). You can install these packages as follows :

pip install requests

Now, to create a deployment package you do the following:

74
AWS Lambda Developer Guide
Versioning and Aliases

1. First, create .zip le with your Python code you want to upload to AWS Lambda.
2. Add the libraries from preceding activated virtual environment to the .zip le. That is, you add
the content of the following directory to the .zip le (note again that you add the content of the
directory and not the directory itself).

For Windows the directory is:

%VIRTUAL_ENV%\Lib\site-packages

For OS X, Linux, the directory is:

$VIRTUAL_ENV/lib/python3.6/site-packages

Note
If you don't nd the packages in the site-packages directory in your virtual environment,
you might nd it in the dist-packages directory.

For an example of creating a Python deployment package, see Python (p. 210).

AWS Lambda Function Versioning and Aliases


Versioning allows you to better manage your in-production Lambda function code by enabling you to
publish one or more versions of your Lambda function. As a result, you can work with dierent variations
of your Lambda function in your development workow, such as development, beta, and production.
Each Lambda function version has a unique Amazon Resource Name (ARN). After you publish a version, it
is immutable (that is, it can't be changed).

AWS Lambda supports creating aliases for each of your Lambda function versions. Conceptually, an
AWS Lambda alias is a pointer to a specic Lambda function version, but it is also a resource similar to
a Lambda function, and each alias has a unique ARN. Each alias maintains an ARN for a function version
to which it points (note that an alias can only point to a function version, not to another alias). Unlike
versions, which are immutable, aliases are mutable (that is, they can be changed) and can be updated to
point to dierent versions

75
AWS Lambda Developer Guide
Versioning and Aliases

Aliases enable you to abstract the process of promoting new Lambda function versions into production
from the mapping of the Lambda function version and its event source. For more information, see How It
Works (p. 175).

For example, suppose Amazon S3 is the event source that invokes your Lambda function when new
objects are created in a bucket. When Amazon S3 is your event source, you store the event source
mapping information in the bucket notication conguration. In the conguration you can identify
the Lambda function ARN that Amazon S3 can invoke, but, in this case, each time you publish a new
version of your Lambda function you need to update the notication conguration so that Amazon S3
invokes the correct version. Instead of specifying the function ARN, you can specify an alias ARN in the
notication conguration (for example, PROD alias ARN). As you promote new versions of your Lambda
function into production, you only need to update the PROD alias to point to the latest stable version,
and you don't need to update the notication conguration in Amazon S3.

The same applies when you need to roll back to a previous version of your Lambda function. In this
scenario, you just update the PROD alias to point to a dierent function version, and there is no need to
update event source mappings.

We recommend you use versioning and aliases to deploy your Lambda functions when building
applications with multiple dependencies and developers involved.

For detailed information, see the following topics:

Topics
Introduction to AWS Lambda Versioning (p. 77)
Introduction to AWS Lambda Aliases (p. 80)
Versioning, Aliases, and Resource Policies (p. 88)
Managing Versioning Using the AWS Management Console, the AWS CLI, or Lambda APIs (p. 90)

76
AWS Lambda Developer Guide
Versioning and Aliases

Introduction to AWS Lambda Versioning


This section explains how to create a Lambda function and publish a version from it. It also explains how
to update function code and conguration information when you have one or more published versions.
In addition, this section includes information on how to delete function versions, either specic versions
or the entire Lambda function (with all of its versions and associated aliases).

Creating a Lambda Function (the $LATEST version)


When you create a Lambda function, there is only one version. It is the $LATEST version.

You can refer to this function using its Amazon Resource Name (ARN). There are two ARNs associated
with this initial version:

Qualied ARN The function ARN with the version sux.

arn:aws:lambda:aws-region:acct-id:function:helloworld:$LATEST

Unqualied ARN The function ARN without the version sux.

You can use this ARN in all relevant operations however you cannot use it to create an alias. For more
information, see Introduction to AWS Lambda Aliases (p. 80).

The unqualied ARN has its own resource policies.

arn:aws:lambda:aws-region:acct-id:function:helloworld

Note
Unless you choose to publish versions, the $LATEST version is the only Lambda function version
you have. You can use either the qualied or unqualied ARN in your event source mapping to
invoke this $LATEST version.

The following is an example response of a CreateFunction API call:

{
"CodeSize": 287,
"Description": "test function."
"FunctionArn": "arn:aws:lambda:aws-region:acct-id:function:helloworld",
"FunctionName": "helloworld",
"Handler": "helloworld.handler",
"LastModified": "2015-07-16T00:34:31.322+0000",
"MemorySize": 128,

77
AWS Lambda Developer Guide
Versioning and Aliases

"Role": "arn:aws:iam::acct-id:role/lambda_basic_execution",
"Runtime": "nodejs6.10",
"Timeout": 3,
"CodeSHA256": "OjRFuuHKizEE8tHFIMsI+iHR6BPAfJ5S0rW31Mh6jKg=",
"Version": "$LATEST"
}

For more information, see CreateFunction (p. 366).

In this response, AWS Lambda returns the unqualied ARN of the newly created function as well as its
version, $LATEST. The response also shows that the Versionis $LATEST. The CodeSha256is the checksum
of the deployment package that you uploaded.

Publishing a Lambda Function Version


When you publish a version, AWS Lambda makes a snapshot copy of the Lambda function code (and
conguration) in the $LATEST version. A published version is immutable. That is, you can't change the
code or conguration information. The new version has a unique ARN that includes a version number
sux as shown:

You can publish a version using any of the following methods:

Publish a version explicitly Use thePublishVersionAPI to explicitly publish a version. For more
information, see PublishVersion (p. 422). This action creates a new version using the code and
conguration in the $LATEST version.
Publish a version at the time you create or update a Lambda function Use the CreateFunction or
UpdateFunctionCode requests to also publish a version by adding the optional publish parameter in
the request:
Specify the publish parameter in your CreateFunction request to create a new Lambda function
(the $LATEST version), and then immediately publish it by creating a snapshot and assigning it to be
version 1. For more information about CreateFunction, see CreateFunction (p. 366).
Specify the publish parameter in your UpdateFunctionCode request to update the code in the
$LATEST version, and then publish a version from the $LATEST. For more information about
UpdateFunctionCode, see UpdateFunctionCode (p. 440).

If you specify the publish parameter at the time you create a Lambda function, the function
conguration information that AWS Lambda returns in response shows the version number of the
newly published version, as shown following (in the example, the version is 1):

{
"CodeSize": 287,
"Description": "test function."
"FunctionArn": "arn:aws:lambda:aws-region:acct-id:function:helloworld",
"FunctionName": "helloworld",

78
AWS Lambda Developer Guide
Versioning and Aliases

"Handler": "helloworld.handler",
"LastModified": "2015-07-16T00:34:31.322+0000",
"MemorySize": 128,
"Role": "arn:aws:iam::acct-id:role/lambda_basic_execution",
"Runtime": "nodejs6.10",
"Timeout": 3,
"CodeSHA256": "OjRFuuHKizEE8tHFIMsI+iHR6BPAfJ5S0rW31Mh6jKg=",
"Version": "1"
}

Note
Lambda will only publish a new version if the code has not yet been published or if the code
has changed when compared against the $LATEST version. If there is no change, the $LATEST
published version will be returned.

We recommend that you publish a version at the same time that you create your Lambda function or
update your Lambda function code, especially when multiple developers contribute to the same Lambda
function development. You can use the publish parameter in your request to do this. When you have
multiple developers working on a project, it is possible for developer A to create a Lambda function
($LATEST version) and before developer A publishes a version, developer B updates the code (deployment
package) associated with the $LATEST version. In this case, you lose the original code that developer A
uploaded. When both developers add the publish parameter it prevents the race condition described.
Note
The published versions are immutable. That is, you cannot change code or conguration
information associated with a version.

Each version of a Lambda function is a unique resource with a Amazon Resource Name (ARN). The
following example shows the ARN of version number 1 of the helloworldLambda function:

arn:aws:lambda:aws-region:acct-id:function:helloworld:1

Note
This is a qualied ARN, where the version number is a sux. Published versions can have only
qualied ARN.

You can publish multiple versions. Each time you publish a version, AWS Lambda copies $LATEST version
(code and conguration information) to create a new version. When you publish additional versions, AWS
Lambda assigns a monotonically increasing sequence number for versioning, even if the function was
deleted and re-created. Version numbers are never reused, even for a function that has been deleted and
re-created, so that the consumer of that version can depend on the executable of that version to never
change (except if it's deleted). If you want to re-use a qualier, use aliases with your versions. Aliases can
be deleted and re-created with the same name.

79
AWS Lambda Developer Guide
Versioning and Aliases

Updating Lambda Function Code and Conguration


AWS Lambda maintains your latest function code in the$LATESTversion. When you update your
function code, AWS Lambda replaces the code in the$LATESTversion of the Lambda function. For more
information, seeUpdateFunctionCode (p. 440).

Published versions are immutable. You cannot update code or conguration information associated with
a published version.

You have the following options of publishing a new version as you update your Lambda function code:

Publish a version in the same update code request Use the UpdateFunctionCodeAPI
(recommended).
First update the code, and then explicitly publish a version Use the PublishVersionAPI.

You can update code and conguration information (such as description, memory size, and execution
timeout) of the $LATEST version of the Lambda function. However, published versions are immutable.
That is, you cannot change code or conguration information.

Deleting a Lambda Function and a Specic Version


With versioning, you have the following choices:

Delete a specic version You can delete a Lambda function version by specifying the version you
want to delete in your DeleteFunctionrequest. If there are aliases dependent on this version, the
request will fail. AWS Lambda deletes the version only if there are no aliases dependent on this
version. For more information about aliases, see Introduction to AWS Lambda Aliases (p. 80).
Delete the entire Lambda function (all of its versions and aliases) To delete the Lambda function
and all of its versions, do not specify any version in yourDeleteFunctionrequest. This deletes the
entire function including all of its versions and aliases.

Important
You can delete a specic function version, but you cannot delete the$LATEST.

Related Topics
Introduction to AWS Lambda Aliases (p. 80)

Managing Versioning Using the AWS Management Console, the AWS CLI, or Lambda APIs (p. 90)

Introduction to AWS Lambda Aliases


You can create aliases for your Lambda function. An AWS Lambda alias is like a pointer to a specic
Lambda function version. For more information about versioning, see Introduction to AWS Lambda
Versioning (p. 77). By using aliases, you can access the Lambda function it is pointing to (for example,
to invoke the function) without the caller having to know the specic version the alias is pointing to.

AWS Lambda aliases enable the following use cases:

Easier support for promotion of new versions of Lambda functions and roll back when needed
After initially creating a Lambda function (the $LATEST version) you can rst publish a version 1 of it.
By creating an alias named PROD that points to version 1, you can now use the PROD alias to invoke
version 1 of the Lambda function.

Now, you can update the code (the $LATEST version) with all of your improvements, and then publish
another stable and improved version (version 2). You can promote version 2 to production by
remapping the PROD alias so that it points to version 2. If you nd something wrong, you can easily

80
AWS Lambda Developer Guide
Versioning and Aliases

roll back the production version to version 1 by remapping the PROD alias so that it points to version
1.
Note
In this context, the terms promotion and roll back refer to the remapping of aliases to
dierent function versions.
Simplify management of event source mappings Instead of using Lambda function ARNs in event
source mappings, by using an alias ARN you ensure that you don't need to update your event source
mappings when you promote a new version or roll back to a previous version.

An AWS Lambda alias is a resource similar to a Lambda function. However, you can't create an alias
independently. You create an alias for an existing Lambda function. If a Lambda function is a resource,
you can think of an AWS Lambda alias as a subresource that is associated with a Lambda function.

Both the Lambda function and alias are AWS Lambda resources, and like all other AWS resources they
both have unique Amazon Resource Names (ARNs). The following example shows a Lambda function (the
$LATEST version), with one published version. Each version has an alias pointing to it.

You can access the function using either the function ARN or the alias ARN.

Because the function version is $LATEST, you can access it using the qualied or unqualied function
ARN.
Qualied function ARN (with the $LATEST version sux):

arn:aws:lambda:aws-region:acct-id:function:helloworld:$LATEST

When using any of the alias ARNs, you are using a qualied ARN. Each alias ARN has an alias name
sux.

arn:aws:lambda:aws-region:acct-id:function:helloworld:PROD
arn:aws:lambda:aws-region:acct-id:function:helloworld:BETA

81
AWS Lambda Developer Guide
Versioning and Aliases

arn:aws:lambda:aws-region:acct-id:function:helloworld:DEV

AWS Lambda provides the following APIs for you to create and manages aliases:

CreateAlias (p. 358)


UpdateAlias (p. 433)
GetAlias (p. 384)
ListAliases (p. 408)
DeleteAlias (p. 374)

Example: Using Aliases to Manage Lambda Function Versions


The following is an example scenario of how to use versioning and aliases to promote new versions of
Lambda functions into production.

Initially, you create a Lambda function.

It is the $LATEST version. You also create an alias (DEV, for development) that points to the newly
created function. Developers can use this alias to test the function with the event sources in a
development environment.

Test the function version using event sources in a beta environment, in a stable way while continuing
to develop newer versions.

You publish a version from the $LATEST and have another alias (BETA) point to it. This allows you to
associate your beta event sources to this specic alias. In the event source mappings, use the BETA
alias to associate your Lambda function with the event source.

82
AWS Lambda Developer Guide
Versioning and Aliases

Promote the Lambda function version in production to work with event sources in production
environment.

After testing the BETA version you can dene the production version by creating an alias that maps
to version 1. This means you want to point your production event sources to this specic version.
You do this by creating a PROD alias and using the PROD alias ARN in all of your production event
source mappings.

83
AWS Lambda Developer Guide
Versioning and Aliases

Continue development, publish more versions, and test.

As you develop your code you can update the $LATEST version by uploading updated code and then
publish to beta testing by having the BETA alias point to it. This simple remapping of the beta alias
enables you put version 2 of your Lambda function into beta without changing any of your event
sources. This is how aliases enable you to control which versions of your function are used with
specic event sources in your development environment.

84
AWS Lambda Developer Guide
Versioning and Aliases

If you want to try creating this setup using AWS CLI, see Tutorial: Using AWS Lambda Aliases (p. 85).

Related Topics
Introduction to AWS Lambda Versioning (p. 77)

Tutorial: Using AWS Lambda Aliases (p. 85)

Managing Versioning Using the AWS Management Console, the AWS CLI, or Lambda APIs (p. 90)

Tutorial: Using AWS Lambda Aliases


This AWS CLI-based tutorial creates Lambda function versions and aliases that point to it as described in
the Example: Using Aliases to Manage Lambda Function Versions (p. 82).

This example uses the us-west-2 (US West, Oregon) region to create the Lambda function and aliases.

1. First, you need to create a deployment package that you can upload to create your Lambda function.

a. Open a text editor, and then copy the following code.

console.log('Loading function');

exports.handler = function(event, context, callback) {


console.log('value1 =', event.key1);
console.log('value2 =', event.key2);
console.log('value3 =', event.key3);
callback(null, "message");

};

b. Save the le as helloworld.js.


c. Zip the helloworld.js le as helloworld.zip.
2. Create an IAM role (execution role) that you can specify at the time you create your Lambda
function.

a. Sign in to the AWS Management Console and open the IAM console at https://
console.aws.amazon.com/iam/.
b. Follow the steps in IAM Roles in the IAM User Guide to create an IAM role (execution role). As you
follow the steps to create a role, note the following:

In Select Role Type, choose AWS Service Roles, and then choose AWS Lambda.
In Attach Policy, choose the policy named AWSLambdaBasicExecutionRole.
c. Write down the Amazon Resource Name (ARN) of the IAM role. You need this value when you
create your Lambda function in the next step.
3. Create a Lambda function (helloworld).

aws lambda create-function \


--region us-west-2 \
--function-name helloworld \
--zip-file fileb://file-path/helloworld.zip \
--role arn:aws:iam::account-id:role/lambda_basic_execution \
--handler helloworld.handler \
--runtime nodejs6.10 \
--profile adminuser

The response returns the conguration information showing $LATEST as the function version as
shown in the following example response:

85
AWS Lambda Developer Guide
Versioning and Aliases

{
"CodeSha256": "OjRFuuHKizEE8tHFIMsI+iHR6BPAfJ5S0rW31Mh6jKg=",
"FunctionName": "helloworld",
"CodeSize": 287,
"MemorySize": 128,
"FunctionArn": "arn:aws:lambda:us-west-2:account-id:function:helloworld",
"Version": "$LATEST",
"Role": "arn:aws:iam::account-id:role/lambda_basic_execution",
"Timeout": 3,
"LastModified": "2015-09-30T18:39:53.873+0000",
"Handler": "helloworld.handler",
"Runtime": "nodejs6.10",
"Description": ""
}

4. Create an alias (DEV) that points to the $LATEST version of the helloworld Lambda function:

aws lambda create-alias \


--region us-west-2 \
--function-name helloworld \
--description "sample alias" \
--function-version "\$LATEST" \
--name DEV \
--profile adminuser

The response returns the alias information, including the function version it is pointing to and the
alias ARN. The ARN is the same as the function ARN with an alias name sux. The following is an
example response:

{
"AliasArn": "arn:aws:lambda:us-west-2:account-id:function:helloworld:DEV",
"FunctionVersion": "$LATEST",
"Name": "DEV",
"Description": "sample alias"
}

5. Publish a version of the helloworld Lambda function.

aws lambda publish-version \


--region us-west-2 \
--function-name helloworld \
--profile adminuser

The response returns conguration information of the function version, including the version
number, and the function ARN with the version sux. The following is an example response:

{
"CodeSha256": "OjRFuuHKizEE8tHFIMsI+iHR6BPAfJ5S0rW31Mh6jKg=",
"FunctionName": "helloworld",
"CodeSize": 287,
"MemorySize": 128,
"FunctionArn": "arn:aws:lambda:us-west-2:account-id:function:helloworld:1",
"Version": "1",
"Role": "arn:aws:iam::account-id:role/lambda_basic_execution",
"Timeout": 3,
"LastModified": "2015-10-03T00:48:00.435+0000",
"Handler": "helloworld.handler",
"Runtime": "nodejs6.10
",
"Description": ""

86
AWS Lambda Developer Guide
Versioning and Aliases

6. Create an alias (BETA) for the for the helloworld Lambda function version 1.

aws lambda create-alias \


--region us-west-2 \
--function-name helloworld \
--description "sample alias" \
--function-version 1 \
--name BETA \
--profile adminuser

Now you have two aliases for the helloworld function. The DEV alias points to the $LATEST function
version, and the BETA alias points to version 1 of the Lambda function.
7. Now suppose you want to put the version 1 of the helloworld function in production. Create
another alias (PROD) that points to version 1.

aws lambda create-alias \


--region us-west-2 \
--function-name helloworld \
--description "sample alias" \
--function-version 1 \
--name PROD \
--profile adminuser

At this time you have both the BETA and PROD aliases pointing to version 1 of the Lambda function.
8. You can now publish a newer version (for example, version 2), but rst you need to update your
code and upload a modied deployment package. If the $LATEST version is not changed, you cannot
publish more than one version of it. Assuming you updated the deployment package, uploaded it,
and published version 2, you can now change the BETA alias to point to version 2 of the Lambda
function.

aws lambda update-alias \


--region us-west-2 \
--function-name helloworld \
--function-version 2 \
--name BETA \
--profile adminuser

Now you have three aliases pointing to a dierent version of the Lambda function (DEV alias points
to the $LATEST version, BETA alias points to version 2, and the PROD alias points to version 1 of the
Lambda function.

For information about using the AWS Lambda console to manage versioning, see Managing Versioning
Using the AWS Management Console, the AWS CLI, or Lambda APIs (p. 90).

Granting Permissions in a Push Model

In a push model (see Event Source Mapping (p. 127)), event sources such as Amazon S3 invoke your
Lambda function. These event sources maintain a mapping that identies a function version or alias they
will invoke when events occur. Note the following:

We recommend that you specify an existing Lambda function alias in the mapping conguration (see
Introduction to AWS Lambda Aliases (p. 80)). For example, if the event source is Amazon S3, you
specify the alias ARN in the bucket notication conguration so that Amazon S3 can invoke the alias
when it detects specic events.

87
AWS Lambda Developer Guide
Versioning and Aliases

In the push model, you grant event sources permissions using a resource policy that you attach to your
Lambda function. In versioning, the permissions you add are specic to the qualier that you specify in
the AddPermission request (see Versioning, Aliases, and Resource Policies (p. 88)).

For example, the following AWS CLI command grants Amazon S3 permissions to invoke the PROD alias
of the helloworld Lambda function (note that the --qualifier parameter species the alias name).

aws lambda add-permission \


--region us-west-2 \
--function-name helloworld \
--qualifier PROD \
--statement-id 1 \
--principal s3.amazonaws.com \
--action lambda:InvokeFunction \
--source-arn arn:aws:s3:::examplebucket \
--source-account 111111111111 \
--profile adminuser

In this case, Amazon S3 is now able to invoke the PROD alias and AWS Lambda can then execute the
helloworld Lambda function version that the PROD alias points to. For this to work, you must use the
PROD alias ARN in the S3 bucket's notication conguration.

For information about how to handle Amazon S3 events, see Tutorial: Using AWS Lambda with
Amazon S3 (p. 202).
Note
If you use the AWS Lambda console to add an event source for your Lambda function, the
console adds the necessary permissions for you.

Versioning, Aliases, and Resource Policies


With versioning and aliases you can access a Lambda function using various ARNs. For example, consider
the following scenario:

88
AWS Lambda Developer Guide
Versioning and Aliases

You can invoke for example the helloworld function version 1 using any of the following two ARNs:

Using the qualied function ARN:

arn:aws:lambda:aws-region:acct-id:function:helloworld:1

Note
An unqualied function ARN (function ARN without a version or alias sux), maps to the
$LATEST version.
Using the BETA alias ARN:

arn:aws:lambda:aws-region:acct-id:function:helloworld:BETA

In a push model, event sources (such as Amazon S3 and custom applications) can invoke any of the
Lambda function versions as long you grant the necessary permissions to these event sources by using
an access policy associated with the Lambda function. For more information about the push model, see
Event Source Mapping (p. 127).

Assuming that you grant permission, the next question is, "can an event source invoke a function version
using any of the associated ARNs?" The answer is, it depends on how you identied function in your add
permissions request (see AddPermission (p. 354)). The key to understanding this is that the permission
you grant apply only to the ARN used in the add permission request:

If you use a qualied function name (such as helloworld:1), the permission is valid for invoking
the helloworld function version 1 only using its qualied ARN (using any other ARNs will result in a
permission error).
If you use an alias name (such as helloworld:BETA), the permission is valid only for invoking the
helloworld function using the BETA alias ARN (using any other ARNs will result in a permission error,
including the function version ARN to which the alias points).

89
AWS Lambda Developer Guide
Versioning and Aliases

If you use an unqualied function name (such as helloworld), the permission is valid only for invoking
the helloworld function using the unqualied function ARN (using any other ARNs will result in a
permission error).
Note
Note that even though the access policy is only on the unqualied ARN, the code and
conguration of the invoked Lambda function is still from function version $LATEST. The
unqualied function ARN maps to the $LATEST version but the permissions you add are ARN-
specic.
If you use a qualied function name using the $LATEST version (helloworld:$LATEST), the permission
is valid for invoking the helloworld function version $LATEST only using its qualied ARN (using
unqualied ARN will result in a permission error).

Managing Versioning Using the AWS Management Console, the


AWS CLI, or Lambda APIs
You can manage Lambda function versioning programmatically using AWS SDKs (or make the AWS
Lambda API calls directly, if you need to), using AWS Command Line Interface (AWS CLI), or the AWS
Lambda console.

AWS Lambda provides the following APIs to manage versioning and aliases:

PublishVersion (p. 422)

ListVersionsByFunction (p. 419)

CreateAlias (p. 358)

UpdateAlias (p. 433)

DeleteAlias (p. 374)

GetAlias (p. 384)

ListAliases (p. 408)

In addition to these APIs, existing relevant APIs also support versioning related operations.

For an example of how you can use the AWS CLI, see Tutorial: Using AWS Lambda Aliases (p. 85).

This section explains how you can use the AWS Lambda console to manage versioning. In the AWS
Lambda console, choose a function and then choose Qualiers.

90
AWS Lambda Developer Guide
Versioning and Aliases

The expanded Qualiers menu displays a Versions and Aliases tab, as shown in the following screen
shot. In the Versions pane, you can see a list of versions for the selected function. If you have not
previously published a version for the selected function, the Versions pane lists only the $LATEST version,
as shown:

Choose the Aliases tab to see a list of aliases for the function. Initially, you won't have any aliases, as
shown following:

91
AWS Lambda Developer Guide
Environment Variables

Now, you can publish a version or create aliases for the selected Lambda function using the Actions
menu.

To learn about versioning and aliases, see AWS Lambda Function Versioning and Aliases (p. 75).

Environment Variables
Environment variables for Lambda functions enable you to dynamically pass settings to your function
code and libraries, without making changes to your code. Environment variables are key-value pairs that
you create and modify as part of your function conguration, using either the AWS Lambda Console, the
AWS Lambda CLI or the AWS Lambda SDK. AWS Lambda then makes these key value pairs available to
your Lambda function code using standard APIs supported by the language, like process.env for Node.js
functions.

You can use environment variables to help libraries know what directory to install les in, where to
store outputs, store connection and logging settings, and more. By separating these settings from the
application logic, you don't need to update your function code when you need to change the function
behavior based on dierent settings.

92
AWS Lambda Developer Guide
Environment Variables

Setting Up
Suppose you want a Lambda function to behave dierently as it moves through lifecycle stages from
development to deployment. For example, the dev, test, and production stages can contain databases
that the function needs to connect to that require dierent connection information and use dierent
table names. You can create environment variables to reference the database names, connection
information or table names and set the value for the function based on the stage in which its executing
(for example, development, test, production) while your function code remains unchanged.

The following screenshots show how to modify your function's conguration using the AWS console. The
rst screenshot congures the settings for the function corresponding to a test stage. The second one
congures settings for a production stage.

Note the Enable encryption helpers checkbox. You will learn more about using this in the Create a
Lambda Function Using Environment Variables To Store Sensitive Information (p. 97) tutorial.

You can also use the AWS CLI to create Lambda functions that contain environment variables. For more
details, see the CreateFunction (p. 366) and UpdateFunctionConguration (p. 446) APIs. Environment
variables are also supported when creating and updating functions using AWS CloudFormation.
Environment variables can also be used to congure settings specic to the language runtime or a library
included in your function. For example, you can modify PATH to specify a directory where executables
are stored. You can also set runtime-specic environment variables, such as PYTHONPATH for Python or
NODE_PATH for Node.js.

The following example creates a new Lambda function that sets the LD_LIBRARY_PATH environment
variable, which is used to specify a directory where shared libraries are dynamically loaded at runtime. In
this example, the Lambda function code uses the shared library in the /usr/bin/test/lib64 directory.
Note that the Runtime parameter uses nodejs6.10 but you can also specify nodejs4.3.

aws lambda create-function \


--region us-east-1
--function-name myTestFunction
--zip-file fileb://path/package.zip
--role role-arn
--environment Variables="{LD_LIBRARY_PATH=/usr/bin/test/lib64}"
--handler index.handler

93
AWS Lambda Developer Guide
Environment Variables

--runtime nodejs6.10
--profile default

Rules for Naming Environment Variables


There is no limit to the number of environment variables you can create as long as the total size of the
set does not exceed 4 KB.

Other requirements include:

Must start with letters [a-zA-Z].


Can only contain alphanumeric characters and underscores ([a-zA-Z0-9_].

In addition, there are a specic set of keys that AWS Lambda reserves. If you try to set values for any of
these reserved keys, you will receive an error message indicating that the action is not allowed. For more
information on these keys, see Environment Variables Available to Lambda Functions (p. 182).

Environment Variables and Function Versioning


Function versioning provides a way to manage your Lambda function code by enabling you to publish
one or more versions of your Lambda function as it proceeds from development to test to production.
For each version of a Lambda function that you publish, the environment variables (as well as other
function-specic congurations such as MemorySize and Timeout limit) are saved as a snapshot of that
version and those settings are immutable (cannot be changed).

As application and conguration requirements evolve, you can create new versions of your Lambda
function and update the environment variables to meet those requirements prior to the newest version
being published. The current version of your function is $LATEST.

In addition, you can create aliases, which are pointers to a particular version of your function. The
advantage of aliases is that if you need to roll back to a previous function version, you point the alias to
that version, which contains the environment variables required for that version. For more information,
see AWS Lambda Function Versioning and Aliases (p. 75).

Environment Variable Encryption


When you create or update Lambda functions that use environment variables, AWS Lambda encrypts
them using the AWS Key Management Service. When your Lambda function is invoked, those values are
decrypted and made available to the Lambda code.

The rst time you create or update Lambda functions that use environment variables in a region,
a default service key is created for you automatically within AWS KMS. This key is used to encrypt
environment variables. However, should you wish to use encryption helpers and use KMS to encrypt
environment variables after your Lambda function is created, then you must create your own AWS KMS
key and choose it instead of the default key. The default key will give errors when chosen. Creating
your own key gives you more exibility, including the ability to create, rotate, disable, and dene access
controls, and to audit the encryption keys used to protect your data. For more information, see the AWS
Key Management Service Developer Guide.

94
AWS Lambda Developer Guide
Environment Variables

If you use your own key, you will be billed per AWS Key Management Service Pricing guidelines. You will
not be billed if you use the default service key provided by AWS Lambda.

If youre using the default KMS service key for Lambda, then no additional IAM permissions are required
in your function execution role your role will just work automatically without changes. If youre
supplying your own (custom) KMS key, then youll need to add kms:Decrypt to your execution role. In
addition, the user that will be creating and updating the Lambda function must have permissions to use
the KMS key. For more information on KMS keys, see the Using Key Policies in AWS KMS.

Storing Sensitive Information


As mentioned in the previous section, when you deploy your Lambda function, all the environment
variables you've specied are encrypted by default. They are then decrypted automatically by AWS
Lambda when the function is invoked. However, if you need to store sensitive information in an
environment variable, we strongly suggest you encrypt that information before deploying your Lambda
function.

Fortunately, the Lambda console makes that easier for you by providing encryption helpers that leverage
AWS Key Management Service to store that sensitive information as Ciphertext. The Lambda console
also provides decryption helper code to decrypt that information for use in your in Lambda function
code. For more information, see Create a Lambda Function Using Environment Variables To Store
Sensitive Information (p. 97).

Error scenarios
If your function conguration exceeds 4KB, or you use environment variable keys reserved by AWS
Lambda, then your update or create operation will fail with a conguration error. During execution time,
it's possible that the encryption/decryption of environment variables can fail. If AWS Lambda is unable
to decrypt the environment variables due to an AWS KMS service exception, AWS KMS will return an
exception message explaining what the error conditions are and what, if any, remedies you can apply
to address the issue. These will be logged to your function log stream in Amazon CloudWatch logs. For
example, if the KMS key you are using to access the environment variables is disabled, you will see the
following error:

Lambda was unable to configure access to your environment variables because the KMS key
used is disabled.
Please check your KMS key settings.

Next Step
Create a Lambda Function Using Environment Variables (p. 95)

Create a Lambda Function Using Environment Variables


This section will illustrate how you can modify a Lambda function's behavior through conguration
changes that require no changes to the Lambda function code.

In this tutorial, you will do the following:

Create a deployment package with sample code that returns the value of an environment variable that
species the name of an Amazon S3 bucket.
Invoke a Lambda function and verify that the Amazon S3 bucket name that is returned matches the
value set by the environment variable.
Update the Lambda function by changing the Amazon S3 bucket name specied by the environment
variable.
Invoke the Lambda function again and verify that the Amazon S3 bucket name that is returned
matches the updated value.

95
AWS Lambda Developer Guide
Environment Variables

Step 1: Prepare
Make sure you have completed the following steps:

Signed up for an AWS account and created an administrator user in the account.
Installed and set up the AWS CLI.

For instructions, see Step 1: Set Up an AWS Account and the AWS CLI (p. 185).

Step 2: Set Up the Lambda Environment


In this section, you do the following:

Create the Lambda function deployment package using the sample code provided.
Create a Lambda execution role.
Create the Lambda function by uploading the deployment package, and then test it by invoking it
manually.

Step 2.1: Create the Deployment Package

The code sample below reads the environment variable of a Lambda function that returns the name of
an Amazon S3 bucket.

1. Open a text editor and copy the following code:

var AWS = require('aws-sdk');

exports.handler = function(event, context, callback) {

var bucketName = process.env.S3_BUCKET;


callback(null, bucketName);
}

2. Save the le as index.js.


3. Zip the index.js. le as Test_Environment_Variables.zip.

Step 2.2: Create an Execution Role

Create an IAM role (execution role) that you can specify at the time you create your Lambda function.

1. Sign in to the AWS Management Console and open the IAM console at https://
console.aws.amazon.com/iam/.
2. Follow the steps in IAM Roles in the IAM User Guide to create an IAM role (execution role). As you
follow the steps to create a role, note the following:

In Select Role Type, choose AWS Service Roles, and then choose AWS Lambda.
In Attach Policy, choose the policy named AWSLambdaBasicExecutionRole.
3. Write down the Amazon Resource Name (ARN) of the IAM role. You need this value when you create
your Lambda function in the next step.

Step 2.3 Create the Lambda function and Test It

In this section, you create a Lambda function containing an environment variable that species an
Amazon S3 bucket named Test. When invoked, the function simply returns the name of the Amazon S3

96
AWS Lambda Developer Guide
Environment Variables

bucket. Then you update the conguration by changing the Amazon S3 bucket name to Prod and when
invoked again, the function returns the updated name of the Amazon S3 bucket.

To create the Lambda function, open a command prompt and run the following Lambda AWS CLI
create-function command. You need to provide the .zip le path and the execution role ARN. Note that
the Runtime parameter uses nodejs6.10 but you can also specify nodejs4.3.

aws lambda create-function \


--region us-east-1 \
--function-name ReturnBucketName \
--zip-file fileb://file-path/Test_Environment_Variables.zip \
--role role-arn \
--environment Variables={S3_BUCKET=Test} \
--handler index.handler \
--runtime nodejs6.10 \
--version version \
--profile default

Note
Optionally, you can upload the .zip le to an Amazon S3 bucket in the same AWS region, and
then specify the bucket and object name in the preceding command. You need to replace the --
zip-file parameter with the --code parameter. For example:

--code S3Bucket=bucket-name,S3Key=zip-file-object-key

Next, run the following Lambda CLI invoke command to invoke the function. Note that the
command requests asynchronous execution. You can optionally invoke it synchronously by specifying
RequestResponse as the invocation-type parameter value.

aws lambda invoke \


--invocation-type Event \
--function-name ReturnBucketName \
--region us-east-1 \
--profile default \
outputfile.txt

The Lambda function will return the name of the Amazon S3 bucket as "Test".

Next, run the following Lambda CLI update-function-configuration command to update the Amazon
S3 environment variable by pointing it to the Prod bucket.

aws lambda update-function-configuration


--function-name ReturnBucketName \
--region us-east-1 \
--environment Variables={S3_BUCKET=Prod} \

Run the aws lambda invoke command again using the same parameters. This time, the Lambda function
will return the Amazon S3 bucket name as Prod.

Create a Lambda Function Using Environment Variables To


Store Sensitive Information
Along with specifying conguration settings for your Lambda function, you can also use environment
variables to store sensitive information, such as a database password, using AWS Key Management
Service and the Lambda console's encryption helpers. For more information, see Environment Variable
Encryption (p. 94). The following example shows you how to do this and also how to use KMS to
decrypt that information.

97
AWS Lambda Developer Guide
Tagging Lambda Functions

This tutorial will demonstrate how you can use the Lambda console to encrypt an environment variable
containing sensitive information and provides sample code for decrypting that information to use in your
Lambda function.

Create the Lambda Function


1. Sign in to the AWS Management Console and open the AWS Lambda console at https://
console.aws.amazon.com/lambda/.
2. Choose Create a Lambda function.
3. In Select blueprint, choose the Blank Function blueprint.
4. On the Congure triggers page, you can optionally choose a service that automatically triggers your
Lambda function by choosing the gray box with ellipses (...) to display a list of available services. For
this example, do not congure a trigger and choose Next.
5. In Congure function, do the following:

In Name*, specify your Lambda function name.


In Runtime, specify nodejs6.10 or nodejs4.3.

Note that in Lambda function code section you can take advantage of the Edit code inline option
to do the following:
Replace the Lambda function handler code with your custom code.
Implement the decryption helper code that Lambda provides, which you will learn about later in
this exercise.
Check the Enable encryption helpers checkbox.
If you already have a KMS key associated with your user account, the Encryption key eld will
be auto-populated with that key. If you haven't created a KMS key for your account, you will
be provided a link to the AWS IAM console to create one. The account must have encrypt and
decrypt permissions for that key.

Note
You cannot use the default Lambda service key for encrypting sensitive information on
the client side.
In Environment variables, enter your key-value pair. If the value you provided is sensitive, choose
the Encrypt button. This masks the value you entered and results in a call to AWS KMS to encrypt
the value and return it as Ciphertext. Note that the Encrypt button toggles to Decrypt after you
choose it. This aords you the option to update the information. Once you have done that, choose
the Encrypt button.

The Code button provides sample decrypt code specic to the runtime of your Lambda function
that you can use with your application.
In Role*, choose Choose an existing role.
In Existing role*, choose lambda_basic_execution.
Note
If the policy of the execution role does not have the decrypt permission, you will need to
add it.
6. In Review, review the conguration and then choose Create Function.

Tagging Lambda Functions


Lambda functions can span multiple applications across separate regions. To simplify the process
of tracking the frequency and cost of each function invocation, you can use tags. Tags are key-value
pairs that you attach to AWS resources to better organize them. They are particularly useful when you
have many resources of the same type, which in the case of AWS Lambda, is a function. By using tags,

98
AWS Lambda Developer Guide
Tagging Lambda Functions

customers with hundreds of Lambda functions can easily access and analyze a specic set by ltering on
those that contain the same tag. Two of the key advantages of tagging your Lambda functions are:

Grouping and Filtering: By applying tags, you can use the Lambda console or CLI to isolate a list of
Lambda functions contained within a specic application or billing department. For more information,
see Filtering on Tagged Lambda Functions (p. 101).
Cost allocation: Because Lambda's support for tagging is integrated with AWS Billing, you can
break down bills into dynamic categories and map functions to specic cost centers. For example,
if you tag all Lambda functions with a "Department" key, then all AWS Lambda costs can be broken
down by department. You can then provide an individual department value, such "Department 1" or
"Department 2" to direct the function invocation cost to the appropriate cost center. Cost allocation is
surfaced via detailed billing reports, making it easier for you to categorize and track your AWS costs.

Topics
Tagging Lambda Functions for Billing (p. 99)
Applying Tags to Lambda Functions (p. 99)
Filtering on Tagged Lambda Functions (p. 101)
Tag Restrictions (p. 102)

Tagging Lambda Functions for Billing


You can use tags to organize your AWS bill to reect your own cost structure. To do this, you can add tag
keys whose values will be included in the cost allocation report. For more information about setting up a
cost allocation report that includes the tag keys you select to be included as line items in the report, see
The Monthly Cost Allocation Report in About AWS Account Billing.

To see the cost of your combined resources, you can organize your billing information based on functions
that have the same tag key values. For example, you can tag several Lambda functions with a specic
application name, and then organize your billing information to see the total cost of that application
across several services. For more information, see Using Cost Allocation Tags in the AWS Billing and Cost
Management User Guide.
Important
In AWS Lambda the only resource that can be tagged is a function. You cannot tag an alias or
a specic function version. Any invocation of a function's alias or version will be billed as an
invocation of the original function.

Applying Tags to Lambda Functions


How you tag your Lambda functions depends on how you create the function. You can apply them using
the Lambda console or CLI, as explained in the following sections:

Applying Tags to Lambda Functions Using the Console (p. 99)


Applying Tags to Lambda Functions Using the CLI (p. 100)

Applying Tags to Lambda Functions Using the Console


When you create a new Lambda function, you can add tags under the Tags section of the Congure
function section.

99
AWS Lambda Developer Guide
Tagging Lambda Functions

To apply or add more tags to an existing function, open the function, choose the Tags tab and then enter
your tag keys and values.

To remove tags from an existing function, open the function, choose the Tags tab and then choose the X
next to key-value pair.

Applying Tags to Lambda Functions Using the CLI


When you create a new Lambda function using the CreateFunction (p. 366) command, you can add tags
by populating the Tags parameter. Specify multiple tag values by enclosing them in quotation marks, as
shown below:

$ aws lambda create-function \


--region region \
--function-name function-name
--role role-arn \
--handler handler-name \
--runtime runtime-value \
--runtime runtime \
--tags "DEPARTMENT=Department A, Department B" \
--profile adminuser \
--timeout 10 \
--memory-size 1024

To apply or add more tags to an existing function, you can use the TagResource (p. 429) API and supply
it with the Lambda function ARN (Amazon Resource Name) along with the key-value pairs that comprise
your tags.

100
AWS Lambda Developer Guide
Tagging Lambda Functions

$ aws lambda tag-resource \


--resource function arn \
--tags DEPARTMENT="Department C, Department D"

Conversely, if you want to remove any or all tags from a Lambda function, you use the
UntagResource (p. 431) API and again supply the function ARN (Amazon Resource Name), along with a
list of tag keys to be removed from the function.

$ aws lambda untag-resource \


--resource function arn \
--tagkeys list of tag keys to be removed

Filtering on Tagged Lambda Functions


Once you have grouped your Lambda functions by using tags, you can leverage the ltering capabilities
provided by the Lambda console or the AWS CLI to view them based on your specic requirements.

Filtering Lambda Functions Using the Console


The Lambda console contains a search eld that allows you to lter the list of functions based on a
specied set of function attributes, including Tags. Suppose you have two functions named MyFunction
and MyFunction2 that have a Tags key called Department. To view those functions, choose the search
eld and notice the automatic ltering that includes a list of the Tags keys:

Choose the Department key. Lambda will return any function that contains that key.

Now suppose that the key value of the MyFunction tag is "Department A" and the key value of
MyFunction2 is "Department B". You can narrow your search by choosing the value of the Department
key, in this case Department A, as shown below.

101
AWS Lambda Developer Guide
Tagging Lambda Functions

This will return only MyFunction.

You can further narrow your search by including the other accepted Function attributes, including
Description, Function name or Runtime.
Note
You are limited to a maximum of 50 tags per Lambda function. If you delete the Lambda
function, the associated tags will also be deleted.

Filtering Lambda Functions Using the CLI


If you want to view the tags that are applied to a specic Lambda function, you can use either of the
following Lambda API commands:

ListTags (p. 417): You supply your Lambda function ARN (Amazon Resource Name) to view a list of
the tags associated with this function:

$ aws lambda list-tags \


--resource function arn \
--region region \
--profile adminuser

GetFunction (p. 390): You supply your Lambda function name to a view a list of the tags associated
with this function:

$ aws lambda get-function \


--function-name function name \
--region region \
--profile adminuser

You can also use the AWS Tagging Services GetResources API to lter your resources by tags. The
GetResources API receives up to 10 lters, with each lter containing a tag key and up to 10 tag values.
You provide GetResources with a ResourceType to lter by specic resource types. For more information
about the AWS Tagging Service, see Working with Resource Groups.

Tag Restrictions
The following restrictions apply to tags:

Maximum number of tags per resource50


Maximum key length127 Unicode characters in UTF-8

102
AWS Lambda Developer Guide
VPC Support

Maximum value length255 Unicode characters in UTF-8


Tag keys and values are case sensitive.
Do not use the aws: prex in your tag names or values because it is reserved for AWS use. You can't
edit or delete tag names or values with this prex. Tags with this prex do not count against your tags
per resource limit.
If your tagging schema will be used across multiple services and resources, remember that other
services may have restrictions on allowed characters. Generally allowed characters are: letters, spaces,
and numbers representable in UTF-8, plus the following special characters: + - = . _ : / @.

Conguring a Lambda Function to Access


Resources in an Amazon VPC
Typically, you create resources inside Amazon Virtual Private Cloud (Amazon VPC) so that they cannot
be accessed over the public Internet. These resources could be AWS service resources, such as Amazon
Redshift data warehouses, Amazon ElastiCache clusters, or Amazon RDS instances. They could also
be your own services running on your own EC2 instances. By default, resources within a VPC are not
accessible from within a Lambda function.

AWS Lambda runs your function code securely within a VPC by default. However, to enable your
Lambda function to access resources inside your private VPC, you must provide additional VPC-specic
conguration information that includes VPC subnet IDs and security group IDs. AWS Lambda uses this
information to set up elastic network interfaces (ENIs) that enable your function to connect securely to
other resources within your private VPC.
Important
AWS Lambda does not support connecting to resources within Dedicated Tenancy VPCs. For
more information, see Dedicated VPCs.

Conguring a Lambda Function for Amazon VPC


Access
You add VPC information to your Lambda function conguration using the VpcConfig parameter,
either at the time you create a Lambda function (see CreateFunction (p. 366)), or you can add it to the
existing Lambda function conguration (see UpdateFunctionConguration (p. 446)). Following are AWS
CLI examples:

The create-function CLI command species the --vpc-config parameter to provide VPC information
at the time you create a Lambda function. Note that the --runtime parameter species python3.6. You
can also use python2.7.

$ aws lambda create-function \


--function-name ExampleFunction \
--runtime python3.6 \
--role execution-role-arn \
--zip-file fileb://path/app.zip \
--handler app.handler \
--vpc-config SubnetIds=comma-separated-vpc-subnet-ids,SecurityGroupIds=comma-separated-
security-group-ids \
--memory-size 1024

Note
The Lambda function execution role must have permissions to create, describe and delete
ENIs. AWS Lambda provides a permissions policy, AWSLambdaVPCAccessExecutionRole,

103
AWS Lambda Developer Guide
Internet Access for Lambda Functions

with permissions for the necessary EC2 actions (ec2:CreateNetworkInterface,


ec2:DescribeNetworkInterfaces, and ec2:DeleteNetworkInterface) that you can use
when creating a role. You can review the policy in the IAM console. Do not delete this role
immediately after your Lambda function execution. There is a delay between the time your
Lambda function executes and ENI deletion. If you do delete the role immediately after
function execution, you are responsible for deleting the ENIs.
The update-function-configuration CLI command species the --vpc-config parameter to add VPC
information to an existing Lambda function conguration.

$ aws lambda update-function-configuration \


--function-name ExampleFunction \
--vpc-config SubnetIds=comma-separated-vpc-subnet-ids,SecurityGroupIds=security-group-ids

To remove VPC-related information from your Lambda function conguration, use the
UpdateFunctionConfiguration API by providing an empty list of subnet IDs and security group IDs as
shown in the following example CLI command.

$ aws lambda update-function-configuration \


--function-name ExampleFunction \
--vpc-config SubnetIds=[],SecurityGroupIds=[]

Note the following additional considerations:

We recommend that you avoid DNS resolution of public host names for your VPC. This can take several
seconds to resolve, which adds several seconds of billable time on your request. For example, if your
Lambda function accesses an Amazon RDS instance in your VPC, launch the instance with the no-
publicly-accessible option.


When you add VPC conguration to a Lambda function, it can only access resources in that VPC. If a
Lambda function needs to access both VPC resources and the public Internet, the VPC needs to have a
Network Address Translation (NAT) instance inside the VPC.


When a Lambda function is congured to run within a VPC, it incurs an additional ENI start-up penalty.
This means address resolution may be delayed when trying to connect to network resources.

Internet Access for Lambda Functions


AWS Lambda uses the VPC information you provide to set up ENIs that allow your Lambda function
to access VPC resources. Each ENI is assigned a private IP address from the IP address range within the
Subnets you specify, but is not assigned any public IP addresses. Therefore, if your Lambda function
requires Internet access (for example, to access AWS services that don't have VPC endpoints, such as
Kinesis), you can congure a NAT instance inside your VPC or you can use the Amazon VPC NAT gateway.
For more information, see NAT Gateways in the Amazon VPC User Guide. You cannot use an Internet
gateway attached to your VPC, since that requires the ENI to have public IP addresses.
Important
If your Lambda function needs Internet access, do not attach it to a public subnet or to a private
subnet without Internet access. Instead, attach it only to private subnets with Internet access
through a NAT instance or an Amazon VPC NAT gateway.

104
AWS Lambda Developer Guide
Guidelines for Setting Up VPC-Enabled Lambda Functions

Guidelines for Setting Up VPC-Enabled Lambda


Functions
Your Lambda function automatically scales based on the number of events it processes. The following
are general guidelines for setting up VPC-enabled Lambda functions to support the scaling behavior.

If your Lambda function accesses a VPC, you must make sure that your VPC has sucient ENI capacity
to support the scale requirements of your Lambda function. You can use the following formula to
approximately determine the ENI capacity.

Projected peak concurrent executions * (Memory in GB / 1.5GB)

Where:
Projected peak concurrent execution Use the information in Lambda Function Concurrent
Executions (p. 176) to determine this value.
Memory The amount of memory you congured for your Lambda function.


The subnets you specify should have sucient available IP addresses to match the number of ENIs.

We also recommend that you specify at least one subnet in each Availability Zone in your Lambda
function conguration. By specifying subnets in each of the Availability Zones, your Lambda function
can run in another Availability Zone if one goes down or runs out of IP addresses.

Note
If your VPC does not have sucient ENIs or subnet IPs, your Lambda function will not scale as
requests increase, and you will see an increase in function failures. AWS Lambda currently does
not log errors to CloudWatch Logs that are caused by insucient ENIs or IP addresses. If you
see an increase in errors without corresponding CloudWatch Logs, you can invoke the Lambda
function synchronously to get the error responses (for example, test your Lambda function in
the AWS Lambda console because the console invokes your Lambda function synchronously and
displays errors).

Tutorials: Conguring a Lambda Function to Access


Resources in an Amazon VPC
This section provides end-to-end example tutorials where you create and congure a Lambda function to
access resources in an Amazon VPC, such as an Amazon ElastiCache cluster or an Amazon RDS database
instance.

Topics
Tutorial: Conguring a Lambda Function to Access Amazon ElastiCache in an Amazon VPC (p. 105)
Tutorial: Conguring a Lambda Function to Access Amazon RDS in an Amazon VPC (p. 109)

Tutorial: Conguring a Lambda Function to Access Amazon


ElastiCache in an Amazon VPC
In this tutorial, you do the following:

105
AWS Lambda Developer Guide
Tutorials: Accessing Resources in an Amazon VPC

Create an Amazon ElastiCache cluster in your default Amazon Virtual Private Cloud (Amazon VPC) in
the us-east-1 region. For more information about Amazon ElastiCache, see Amazon ElastiCache.
Create a Lambda function to access the ElastiCache cluster. When you create the Lambda function,
you provide subnet IDs in your Amazon VPC and a VPC security group to allow the Lambda function
to access resources in your VPC. For illustration in this tutorial, the Lambda function generates a UUID,
writes it to the cache, and retrieves it from the cache.
Invoke the Lambda function manually and verify that it accessed the ElastiCache cluster in your VPC.

Important
This tutorial uses the default Amazon VPC in the us-east-1 region in your account. For more
information about Amazon VPC, see How to Get Started with Amazon VPC in the Amazon VPC
User Guide.

Next Step

Step 1: Create an ElastiCache Cluster (p. 106)

Step 1: Create an ElastiCache Cluster


In this step, you create an ElastiCache cluster in the default Amazon VPC in us-east-1 region in your
account.

1. Run the following AWS CLI command to create a Memcached cluster in the default VPC in the us-
east-1 region in your account.

aws elasticache create-cache-cluster \


--cache-cluster-id ClusterForLambdaTest \
--cache-node-type cache.m3.medium \
--engine memcached \
--security-group-ids your-default-vpc-security-group \
--num-cache-nodes 1

You can look up the default VPC security group in the VPC console under Security Groups. Your
example Lambda function will add and retrieve an item from this cluster.

You can also launch a cache cluster using the Amazon ElastiCache console. For instructions, see
Getting Started with Amazon ElastiCache in the Amazon ElastiCache User Guide.
2. Write down the conguration endpoint for the cache cluster that you launched. You can get this
from the Amazon ElastiCache console. You will specify this value in your Lambda function code in
the next section.

Next Step

Step 2: Create a Lambda Function (p. 106)

Step 2: Create a Lambda Function


In this step, you do the following:

Create a Lambda function deployment package using the sample code provided.
Create an IAM role (execution role). At the time you upload the deployment package, you need to
specify this role so that Lambda can assume the role and then execute the function on your behalf.

The permissions policy grants AWS Lambda permissions to set up elastic network interfaces (ENIs) to
enable your Lambda function to access resources in the VPC. In this example, your Lambda function
accesses an ElastiCache cluster in the VPC.
Create the Lambda function by uploading the deployment package.

106
AWS Lambda Developer Guide
Tutorials: Accessing Resources in an Amazon VPC

Topics
Step 2.1: Create a Deployment Package (p. 107)
Step 2.2: Create the Execution Role (IAM Role) (p. 108)
Step 2.3: Create the Lambda Function (Upload the Deployment Package) (p. 108)

Step 2.1: Create a Deployment Package


Note
At this time, example code for the Lambda function is provided only in Python.

Python

The following example Python code reads and writes an item to your ElastiCache cluster.

1. Open a text editor, and then copy the following code.


Note
The from __future__ statement enables you to write code that is compatible with Python 2
or 3. If you are using runtime version 3.6, it is not necessary to include it.

from __future__ import print_function


import time
import uuid
import sys
import socket
import elasticache_auto_discovery
from pymemcache.client.hash import HashClient

#elasticache settings
elasticache_config_endpoint = "your-elasticache-cluster-endpoint:port"
nodes = elasticache_auto_discovery.discover(elasticache_config_endpoint)
nodes = map(lambda x: (x[1], int(x[2])), nodes)
memcache_client = HashClient(nodes)

def handler(event, context):


"""
This function puts into memcache and get from it.
Memcache is hosted using elasticache
"""

#Create a random UUID... this will the sample element we add to the cache.
uuid_inserted = uuid.uuid4().hex
#Put the UUID to the cache.
memcache_client.set('uuid', uuid_inserted)
#Get item (UUID) from the cache.
uuid_obtained = memcache_client.get('uuid')
if uuid_obtained == uuid_inserted:
# this print should go to the CloudWatch Logs and Lambda console.
print ("Success: Fetched value %s from memcache" %(uuid_inserted))
else:
raise Exception("Value is not the same as we put :(. Expected %s got %s"
%(uuid_inserted, uuid_obtained))

return "Fetched value from memcache: " + uuid_obtained

2. Save the le as app.py.


3. Install the following library dependencies using pip:

pymemcache The Lambda function code uses this library to create a HashClient object to set and
get items from memcache (see pymemcache).

107
AWS Lambda Developer Guide
Tutorials: Accessing Resources in an Amazon VPC

elasticache-auto-discovery The Lambda function uses this library to get the nodes in your
Amazon ElastiCache cluster (see elasticache-auto-discovery).
4. Zip all of these les into a le named app.zip to create your deployment package. For step-by-step
instructions, see Creating a Deployment Package (Python) (p. 73).

Next Step

Step 2.2: Create the Execution Role (IAM Role) (p. 108)

Step 2.2: Create the Execution Role (IAM Role)


In this step, you create an AWS Identity and Access Management (IAM) role using the following
predened role type and access permissions policy:

AWS Lambda (AWS service role) This role grants AWS Lambda permissions to assume the role.
AWSLambdaVPCAccessExecutionRole (access permissions policy) This is the policy that you attach
to the role. The policy grants permissions for the EC2 actions that AWS Lambda needs to manage ENIs.
You can view this AWS managed policy in IAM console.

For more information about IAM roles, see IAM Roles in the IAM User Guide. Use the following procedure
to create the IAM role.

To create an IAM role (execution role)

1. Sign in to the AWS Management Console and open the IAM console at https://
console.aws.amazon.com/iam/.
2. Follow the steps in Creating a Role to Delegate Permissions to an AWS Service in the IAM User Guide
to create an IAM role (execution role). As you follow the steps to create a role, note the following:

In Role Name, use a name that is unique within your AWS account (for example, lambda-vpc-
execution-role).
In Select Role Type, choose AWS Service Roles, and then choose AWS Lambda. This grants the
AWS Lambda service permissions to assume the role.
In Attach Policy, choose AWSLambdaVPCAccessExecutionRole. The permissions in this policy are
sucient for the Lambda function in this tutorial.
3. Write down the role ARN. You will need it in the next step when you create your Lambda function.

Next Step

Step 2.3: Create the Lambda Function (Upload the Deployment Package) (p. 108)

Step 2.3: Create the Lambda Function (Upload the Deployment Package)
In this step, you create the Lambda function (AccessMemCache) using the create-function AWS CLI
command.

At the command prompt, run the following Lambda CLI create-function command using the
adminuser prole.

You need to update the following create-function command by providing the .zip le path and the
execution role ARN. The --runtime parameter value can be python3.6, python2.7, nodejs and java8,
depending on the language you used to author your code.
Note
At this time, example code for the Lambda function is provided only in Python.

$ aws lambda create-function \

108
AWS Lambda Developer Guide
Tutorials: Accessing Resources in an Amazon VPC

--function-name AccessMemCache \
--region us-east-1 \
--zip-file fileb://path-to/app.zip \
--role execution-role-arn \
--handler app.handler \
--runtime python3.6 \
--timeout 30 \
--vpc-config SubnetIds=comma-separated-vpc-subnet-ids,SecurityGroupIds=default-security-
group-id \
--memory-size 1024

You can nd the subnet IDs and the default security group ID of your VPC from the VPC console.

Optionally, you can upload the .zip le to an Amazon S3 bucket in the same AWS region, and then
specify the bucket and object name in the preceding command. You need to replace the --zip-file
parameter by the --code parameter, as shown following:

--code S3Bucket=bucket-name,S3Key=zip-file-object-key

Note
You can also create the Lambda function using the AWS Lambda console. When creating the
function, choose a VPC for the Lambda and then select the subnets and security groups from
the provided elds.

Next Step

Step 3: Test the Lambda Function (Invoke Manually) (p. 109)

Step 3: Test the Lambda Function (Invoke Manually)


In this step, you invoke the Lambda function manually using the invoke command. When the Lambda
function executes, it generates a UUID and writes it to the ElastiCache cluster that you specied in your
Lambda code. The Lambda function then retrieves the item from the cache.

1. Invoke the Lambda function (AccessMemCache) using the AWS Lambda invoke command.

$ aws lambda invoke \


--function-name AccessMemCache \
--region us-east-1 \
--profile adminuser \
output.txt

2. Verify that the Lambda function executed successfully as follows:

Review the output.txt le.


Review the results in the AWS Lambda console.
Verify the results in CloudWatch Logs.

What Next?

Now that you have created a Lambda function that accesses an ElastiCache cluster in your VPC, you can
have the function invoked in response to events. For information about conguring event sources and
examples, see Use Cases (p. 200).

Tutorial: Conguring a Lambda Function to Access Amazon RDS


in an Amazon VPC
In this tutorial, you do the following:

109
AWS Lambda Developer Guide
Tutorials: Accessing Resources in an Amazon VPC

Launch an Amazon RDS MySQL database engine instance in your default Amazon VPC. In the
MySQL instance, you create a database (ExampleDB) with a sample table (Employee) in it. For more
information about Amazon RDS, see Amazon RDS.
Create a Lambda function to access the ExampleDB database, create a table (Employee), add a few
records, and retrieve the records from the table.
Invoke the Lambda function manually and verify the query results. This is how you verify that your
Lambda function was able to access the RDS MySQL instance in the VPC.

Important
This tutorial uses the default Amazon VPC in the us-east-1 region in your account. For more
information about Amazon VPC, see How to Get Started with Amazon VPC in the Amazon VPC
User Guide.

Next Step

Step 1: Create an Amazon RDS MySQL Instance and ExampleDB Database (p. 110)

Step 1: Create an Amazon RDS MySQL Instance and ExampleDB Database


In this tutorial, the example Lambda function creates a table (Employee), inserts a few records, and then
retrieves the records. The table that the Lambda function creates has the following schema:

Employee(EmpID, Name)

Where EmpID is the primary key. Now, you need to add a few records to this table.

First, you launch an RDS MySQL instance in your default VPC with ExampleDB database. If you already
have an RDS MySQL instance running in your default VPC, skip this step.
Important
This tutorial uses the RDS MySQL DB engine launched in the default VPC in the us-east-1 region.

You can launch an RDS MySQL instance using one of the following methods:

Follow the instructions at Creating a MySQL DB Instance and Connecting to a Database on a MySQL DB
Instance in the Amazon Relational Database Service User Guide.
Use the following AWS CLI command:

$ aws rds create-db-instance \


--db-instance-identifier MySQLForLambdaTest \
--db-instance-class db.t2.micro \
--engine MySQL \
--allocated-storage 5 \
--no-publicly-accessible \
--db-name ExampleDB \
--master-username username \
--master-user-password password \
--backup-retention-period 3

Write down the database name, user name, and password. You also need the host address (endpoint)
of the DB instance, which you can get from the RDS console (you might need to wait until the instance
status is available and the Endpoint value appears in the console).

Next Step

Step 2: Create a Lambda Function (p. 111)

110
AWS Lambda Developer Guide
Tutorials: Accessing Resources in an Amazon VPC

Step 2: Create a Lambda Function


In this step, you do the following:

Create a Lambda function deployment package using the sample code provided.
Create an IAM role (execution role) that you specify at the time of creating your Lambda function. This
is the role AWS Lambda assumes when executing the Lambda function.

The permissions policy associated with this role grants AWS Lambda permissions to set up elastic
network interfaces (ENIs) to enable your Lambda function to access resources in the VPC.
Create the Lambda function by uploading the deployment package.

Topics
Step 2.1: Create a Deployment Package (p. 111)
Step 2.2: Create the Execution Role (IAM Role) (p. 112)
Step 2.3: Create the Lambda Function (Upload the Deployment Package) (p. 113)

Step 2.1: Create a Deployment Package


Note
At this time, example code for the Lambda function is provided only in Python.

Python

The following example Python code runs a SELECT query against the Employee table in the MySQL RDS
instance that you created in the VPC. The code creates a table in the ExampleDB database, adds sample
records, and retrieves those records.

1. Open a text editor, and then copy the following code.

import sys
import logging
import rds_config
import pymysql
#rds settings
rds_host = "rds-instance-endpoint"
name = rds_config.db_username
password = rds_config.db_password
db_name = rds_config.db_name

logger = logging.getLogger()
logger.setLevel(logging.INFO)

try:
conn = pymysql.connect(rds_host, user=name, passwd=password, db=db_name,
connect_timeout=5)
except:
logger.error("ERROR: Unexpected error: Could not connect to MySql instance.")
sys.exit()

logger.info("SUCCESS: Connection to RDS mysql instance succeeded")


def handler(event, context):
"""
This function fetches content from mysql RDS instance
"""

item_count = 0

111
AWS Lambda Developer Guide
Tutorials: Accessing Resources in an Amazon VPC

with conn.cursor() as cur:


cur.execute("create table Employee3 ( EmpID int NOT NULL, Name varchar(255)
NOT NULL, PRIMARY KEY (EmpID))")
cur.execute('insert into Employee3 (EmpID, Name) values(1, "Joe")')
cur.execute('insert into Employee3 (EmpID, Name) values(2, "Bob")')
cur.execute('insert into Employee3 (EmpID, Name) values(3, "Mary")')
conn.commit()
cur.execute("select * from Employee3")
for row in cur:
item_count += 1
logger.info(row)
#print(row)

return "Added %d items from RDS MySQL table" %(item_count)

Note
We recommend that pymysql.connect() is executed outside the handler, as shown, for
better performance.
2. Save the le as app.py.
3. Install the following library dependencies using pip:

pymysql The Lambda function code uses this library to access your MySQL instance (see
PyMySQL) .
4. Create a cong le that contains the following information and save it as rds_config.py:

#config file containing credentials for rds mysql instance


db_username = "username"
db_password = "password"
db_name = "databasename"

5. Zip all of these les into a le named app.zip to create your deployment package. For step-by-step
instructions, see Creating a Deployment Package (Python) (p. 73).

Next Step

Step 2.2: Create the Execution Role (IAM Role) (p. 112)

Step 2.2: Create the Execution Role (IAM Role)

In this step, you create an execution role (IAM role) for your Lambda function using the following
predened role type and access permissions policy:

AWS Lambda (AWS service role) This role grants AWS Lambda permissions to assume the role.
AWSLambdaVPCAccessExecutionRole (access permissions policy) This role grants AWS Lambda
permissions for EC2 actions to create ENIs and your Lambda function can access VPC resources and
CloudWatch Logs actions to write logs.

For more information about IAM roles, see IAM Roles in the IAM User Guide. Use the following procedure
to create the IAM role.

To create an IAM role (execution role)

1. Sign in to the AWS Management Console and open the IAM console at https://
console.aws.amazon.com/iam/.
2. Follow the steps in Creating a Role to Delegate Permissions to an AWS Service in the IAM User Guide
to create an IAM role (execution role). As you follow the steps to create a role, note the following:

112
AWS Lambda Developer Guide
Tutorials: Accessing Resources in an Amazon VPC

In Role Name, use a name that is unique within your AWS account (for example, lambda-vpc-
execution-role).
In Select Role Type, choose AWS Service Roles, and then choose AWS Lambda. This grants the
AWS Lambda service permissions to assume the role.
In Attach Policy, choose AWSLambdaVPCAccessExecutionRole. The permissions in this policy are
sucient for the Lambda function in this tutorial.
3. Write down the role ARN. You will need it in the next step when you create your Lambda function.

Next Step

Step 2.3: Create the Lambda Function (Upload the Deployment Package) (p. 113)

Step 2.3: Create the Lambda Function (Upload the Deployment Package)
In this step, you create the Lambda function (ReadMySqlTable) using the create-function AWS CLI
command.

At the command prompt, run the following Lambda CLI create-function command using the
adminuser prole.

You need to update the following create-function command by providing the .zip le path and the
execution role ARN. The --runtime parameter value can be python2.7, nodejs, or java8, depending on
the language you used to author your code.
Note
At this time, example code for the Lambda function is provided only in Python. You can use
either python3.6 or python2.7 for the --runtime parameter.

$ aws lambda create-function \


--region us-east-1 \
--function-name CreateTableAddRecordsAndRead \
--zip-file fileb://file-path/app.zip \
--role execution-role-arn \
--handler app.handler \
--runtime python3.6 \
--vpc-config SubnetIds=comma-separated-subnet-ids,SecurityGroupIds=default-vpc-security-
group-id \
--profile adminuser

Optionally, you can upload the .zip le to an Amazon S3 bucket in the same AWS region, and then
specify the bucket and object name in the preceding command. You need to replace the --zip-file
parameter by the --code parameter, as shown following:

--code S3Bucket=bucket-name,S3Key=zip-file-object-key

Note
You can also create the Lambda function using the AWS Lambda console (use the parameter
values shown in the preceding CLI command).

Next Step

Step 3: Test the Lambda Function (Invoke Manually) (p. 113)

Step 3: Test the Lambda Function (Invoke Manually)


In this step, you invoke the Lambda function manually using the invoke command. When the Lambda
function executes, it runs the SELECT query against the Employee table in the RDS MySQL instance and
prints the results (these results also go to the CloudWatch Logs).

113
AWS Lambda Developer Guide
Troubleshooting and Monitoring

1. Invoke the Lambda function (ReadMySqlTable) using the AWS Lambda invoke command.

$ aws lambda invoke \


--function-name CreateTableAddRecordsAndRead \
--region us-east-1 \
--profile adminuser \
output.txt

2. Verify that the Lambda function executed successfully as follows:

Review the output.txt le.


Review the results in the AWS Lambda console.
Verify the results in CloudWatch Logs.

Troubleshooting and Monitoring AWS Lambda


Functions with Amazon CloudWatch
AWS Lambda automatically monitors Lambda functions on your behalf, reporting metrics through
Amazon CloudWatch. To help you monitor your code as it executes, Lambda automatically tracks the
number of requests, the latency per request, and the number of requests resulting in an error and
publishes the associated CloudWatch metrics. You can leverage these metrics to set CloudWatch custom
alarms. For more information about CloudWatch, see the Amazon CloudWatch User Guide.

You can view request rates and error rates for each of your Lambda functions by using the AWS Lambda
console, the CloudWatch console, and other Amazon Web Services (AWS) resources. The following topics
describe Lambda CloudWatch metrics and how to access them.

Accessing Amazon CloudWatch Metrics for AWS Lambda (p. 116)


AWS Lambda Metrics (p. 119)

You can insert logging statements into your code to help you validate that your code is working as
expected. Lambda automatically integrates with Amazon CloudWatch Logs and pushes all logs from
your code to a CloudWatch Logs group associated with a Lambda function (/aws/lambda/<function
name>). To learn more about log groups and accessing them through the CloudWatch console, see
the Monitoring System, Application, and Custom Log Files in the Amazon CloudWatch User Guide. For
information about how to access CloudWatch log entries, see Accessing Amazon CloudWatch Logs for
AWS Lambda (p. 118).
Note
If your Lambda function code is executing, but you don't see any log data being generated
after several minutes, this could mean your execution role for the Lambda function did not
grant permissions to write log data to CloudWatch Logs. For information about how to make
sure that you have set up the execution role correctly to grant these permissions, see Manage
Permissions: Using an IAM Role (Execution Role) (p. 180).

AWS Lambda Troubleshooting Scenarios


This sections describes examples of how to monitor and troubleshoot your Lambda functions using the
logging and monitoring capabilities of CloudWatch.

114
AWS Lambda Developer Guide
Troubleshooting Scenarios

Troubleshooting Scenario 1: Lambda Function Not Working as


Expected
In this scenario, you have just nished Tutorial: Using AWS Lambda with Amazon S3 (p. 202). However,
the Lambda function you created to upload a thumbnail image to Amazon S3 when you create an S3
object is not working as expected. When you upload objects to Amazon S3, you see that the thumbnail
images are not being uploaded. You can troubleshoot this issue in the following ways.

To determine why your Lambda function is not working as expected

1. Check your code and verify that it is working correctly. An increased error rate would indicate that it
is not.

You can test your code locally as you would any other Node.js function, or you can test it within the
Lambda console using the console's test invoke functionality, or you can use the AWS CLI Invoke
command. Each time the code is executed in response to an event, it writes a log entry into the log
group associated with a Lambda function, which is /aws/lambda/<function name>.

Following are some examples of errors that might show up in the logs:

If you see a stack trace in your log, there is probably an error in your code. Review your code and
debug the error that the stack trace refers to.
If you see a permissions denied error in the log, the IAM role you have provided as an execution
role may not have the necessary permissions. Check the IAM role and verify that it has all of the
necessary permissions to access any AWS resources that your code references. To ensure that you
have correctly set up the execution role, see Manage Permissions: Using an IAM Role (Execution
Role) (p. 180).
If you see a timeout exceeded error in the log, your timeout setting exceeds the run time of
your function code. This may be because the timeout is too low, or the code is taking too long to
execute.
If you see a memory exceeded error in the log, your memory setting is too low. Set it to a higher
value. For information about memory size limits, see CreateFunction (p. 366). When you change
the memory setting, it can also change how you are charged for duration. For information about
pricing, see the AWS Lambda product website.
2. Check your Lambda function and verify that it is receiving requests.

Even if your function code is working as expected and responding correctly to test invokes, the
function may not be receiving requests from Amazon S3. If Amazon S3 is able to invoke the
function, you should see an increase in your CloudWatch requests metrics. If you do not see an
increase in your CloudWatch requests, check the access permissions policy associated with the
function.

Troubleshooting Scenario 2: Increased Latency in Lambda


Function Execution
In this scenario, you have just nished Tutorial: Using AWS Lambda with Amazon S3 (p. 202). However,
the Lambda function you created to upload a thumbnail image to Amazon S3 when you create an
S3 object is not working as expected. When you upload objects to Amazon S3, you can see that the
thumbnail images are being uploaded, but your code is taking much longer to execute than expected.
You can troubleshoot this issue in a couple of dierent ways. For example, you could monitor the latency
CloudWatch metric for the Lambda function to see if the latency is increasing. Or you could see an
increase in the CloudWatch errors metric for the Lambda function, which might be due to timeout errors.

115
AWS Lambda Developer Guide
Accessing CloudWatch Metrics

To determine why there is increased latency in the execution of a Lambda function

1. Test your code with dierent memory settings.

If your code is taking too long to execute, it could be that it does not have enough compute
resources to execute its logic. Try increasing the memory allocated to your function and testing the
code again, using the Lambda console's test invoke functionality. You can see the memory used,
code execution time, and memory allocated in the function log entries. Changing the memory
setting can change how you are charged for duration. For information about pricing, see AWS
Lambda.
2. Investigate the source of the execution bottleneck that is using logs.

You can test your code locally, as you would with any other Node.js function, or you can test it within
Lambda using the test invoke capability on the Lambda console, or using the asyncInvoke command
by using AWS CLI. Each time the code is executed in response to an event, it writes a log entry into
the log group associated with a Lambda function, which is named aws/lambda/<function name>.
Add logging statements around various parts of your code, such as callouts to other services, to see
how much time it takes to execute dierent parts of your code.

Accessing Amazon CloudWatch Metrics for AWS


Lambda
AWS Lambda automatically monitors functions on your behalf, reporting metrics through Amazon
CloudWatch. These metrics include total requests, latency, and error rates. For more information about
Lambda metrics, see AWS Lambda Metrics (p. 119). For more information about CloudWatch, see the
Amazon CloudWatch User Guide.

You can monitor metrics for Lambda and view logs by using the Lambda console, the CloudWatch
console, the AWS CLI, or the CloudWatch API. The following procedures show you how to access metrics
using these dierent methods.

To access metrics using the Lambda console

1. Sign in to the AWS Management Console and open the AWS Lambda console at https://
console.aws.amazon.com/lambda/.
2. If you have not created a Lambda function before, see Getting Started (p. 185).
3. On the Functions page, choose the function name and then choose the Monitoring tab.

116
AWS Lambda Developer Guide
Accessing CloudWatch Metrics

A graphical representation of the metrics for the Lambda function are shown.
4. Choose View logs in CloudWatch to view the logs.

To access metrics using the CloudWatch console

1. Open the CloudWatch console at https://console.aws.amazon.com/cloudwatch/.


2. From the navigation bar, choose a region.
3. In the navigation pane, choose Metrics.
4. In the CloudWatch Metrics by Category pane, choose Lambda Metrics.
5. (Optional) In the graph pane, choose a statistic and a time period, and then create a CloudWatch
alarm using these settings.

To access metrics using the AWS CLI

Use the list-metrics and get-metric-statistics commands.

To access metrics using the CloudWatch CLI

Use the mon-list-metrics and mon-get-stats commands.

To access metrics using the CloudWatch API

117
AWS Lambda Developer Guide
Accessing CloudWatch Logs

Use the ListMetrics and GetMetricStatistics operations.

Accessing Amazon CloudWatch Logs for AWS Lambda


AWS Lambda automatically monitors Lambda functions on your behalf, reporting metrics through
Amazon CloudWatch. To help you troubleshoot failures in a function, Lambda logs all requests
handled by your function and also automatically stores logs generated by your code through Amazon
CloudWatch Logs.

You can insert logging statements into your code to help you validate that your code is working as
expected. Lambda automatically integrates with CloudWatch Logs and pushes all logs from your code to
a CloudWatch Logs group associated with a Lambda function, which is named /aws/lambda/<function
name>. To learn more about log groups and accessing them through the CloudWatch console, see the
Monitoring System, Application, and Custom Log Files in the Amazon CloudWatch User Guide.

You can view logs for Lambda by using the Lambda console, the CloudWatch console, the AWS CLI,
or the CloudWatch API. The following procedure show you how to view the logs by using the Lambda
console.
Note
There is no additional charge for using Lambda logs; however, standard CloudWatch Logs
charges apply. For more information, see CloudWatch Pricing.

To view logs using the Lambda console

1. Sign in to the AWS Management Console and open the AWS Lambda console at https://
console.aws.amazon.com/lambda/.
2. If you have not created a Lambda function before, see Getting Started (p. 185).
3. On the Functions page, choose the function name and then choose the Monitoring tab.

118
AWS Lambda Developer Guide
Metrics

A graphical representation of the metrics for the Lambda function are shown.
4. Choose View logs in CloudWatch to view the logs.

For more information on accessing CloudWatch Logs, see the following guides:

Amazon CloudWatch User Guide


Amazon CloudWatch Logs API Reference
Monitoring Log Files in the Amazon CloudWatch User Guide

AWS Lambda Metrics


This topic describes the AWS Lambda namespace, metrics, and dimensions. AWS Lambda automatically
monitors functions on your behalf, reporting metrics through Amazon CloudWatch. These metrics
include total invocations, errors, duration, throttles, DLQ errors and Iterator age for stream-based
invocations.

CloudWatch is basically a metrics repository. A metric is the fundamental concept in CloudWatch and
represents a time-ordered set of data points. You (or AWS services) publish metrics data points into
CloudWatch and you retrieve statistics about those data points as an ordered set of time-series data.

Metrics are uniquely dened by a name, a namespace, and one or more dimensions. Each data point has
a time stamp, and, optionally, a unit of measure. When you request statistics, the returned data stream is

119
AWS Lambda Developer Guide
Metrics

identied by namespace, metric name, and dimension. For more information about CloudWatch, see the
Amazon CloudWatch User Guide.

AWS Lambda CloudWatch Metrics


The AWS/Lambda namespace includes the following metrics.

Metric Description

Invocations Measures the number of times a function is invoked in response to an


event or invocation API call. This replaces the deprecated RequestCount
metric. This includes successful and failed invocations, but does not include
throttled attempts. This equals the billed requests for the function. Note
that AWS Lambda only sends these metrics to CloudWatch if they have a
nonzero value.

Units: Count

Errors Measures the number of invocations that failed due to errors in the function
(response code 4XX). This replaces the deprecated ErrorCount metric. Failed
invocations may trigger a retry attempt that succeeds. This includes:

Handled exceptions (for example, context.fail(error))


Unhandled exceptions causing the code to exit
Out of memory exceptions
Timeouts
Permissions errors

This does not include invocations that fail due to invocation rates exceeding
default concurrent limits (error code 429) or failures due to internal service
errors (error code 500).

Units: Count

Dead Letter Error Incremented when Lambda is unable to write the failed event payload to
your congured Dead Letter Queues. This could be due to the following:

Permissions errors
Throttles from downstream services
Miscongured resources
Timeouts

Units: Count

Duration Measures the elapsed wall clock time from when the function code starts
executing as a result of an invocation to when it stops executing. This
replaces the deprecated Latency metric. The maximum data point value
possible is the function timeout conguration. The billed duration will be
rounded up to the nearest 100 millisecond. Note that AWS Lambda only
sends these metrics to CloudWatch if they have a nonzero value.

Units: Milliseconds

Throttles Measures the number of Lambda function invocation attempts that were
throttled due to invocation rates exceeding the customers concurrent

120
AWS Lambda Developer Guide
Dead Letter Queues

Metric Description
limits (error code 429). Failed invocations may trigger a retry attempt that
succeeds.

Units: Count

IteratorAge Emitted for stream-based invocations only (functions triggered by an


Amazon DynamoDB stream or Kinesis stream). Measures the age of the last
record for each batch of records processed. Age is the dierence between
the time Lambda received the batch, and the time the last record in the
batch was written to the stream.

Units: Milliseconds

Errors/Invocations Ratio
When calculating the error rate on Lambda function invocations, its important to distinguish
between an invocation request and an actual invocation. It is possible for the error rate to
exceed the number of billed Lambda function invocations. Lambda reports an invocation metric
only if the Lambda function code is executed. If the invocation request yields a throttling or
other initialization error that prevents the Lambda function code from being invoked, Lambda
will report an error, but it does not log an invocation metric.

Lambda emits Invocations=1 when the function is executed. If the Lambda function is not
executed, nothing is emitted.
Lambda emits a data point for Errors for each invoke request. Errors=0 means that there is
no function execution error. Errors=1 means that there is a function execution error.
Lambda emits a data point for Throttles for each invoke request. Throttles=0 means there is
no invocation throttle. Throttles=1 means there is an invocation throttle.

AWS Lambda CloudWatch Dimensions


You can use the dimensions in the following table to rene the metrics returned for your Lambda
functions.

Dimension Description

FunctionName Filters the metric data by Lambda function.

Resource Filters the metric data by Lambda function resource.

Version Filters the metric data by Lambda version.

Alias Filters the metric data by Lambda alias.

Dead Letter Queues


By default, a failed Lambda function invoked asynchronously is retried twice, and then the event is
discarded. Using Dead Letter Queues (DLQ), you can indicate to Lambda that unprocessed events should
be sent to an Amazon SQS queue or Amazon SNS topic instead, where you can take further action.

You congure a DLQ by specifying a target Amazon Resource Name (ARN) on a Lambda function's
DeadLetterConfig parameter of an Amazon SNS topic or an Amazon SQS queue where you want the
event payload delivered, as shown in the following code. For more information about creating an

121
AWS Lambda Developer Guide
Dead Letter Queues

Amazon SNS topic, see Create an SNS Topic. For more information about creating an Amazon SQS
queue, see Tutorial: Creating an Amazon SQS Queue.

{
"Code": {
"ZipFile": blob,
"S3Bucket": string,
"S3Key": string,
"S3ObjectVersion": string
},
"Description": "string",
"FunctionName": "string",
"Handler": "string",
"MemorySize": number,
"Role": "string",
"Runtime": "string",
"Timeout": number
"Publish": bool,
"DeadLetterConfig": {
"TargetArn": "string"
}
}

Lambda directs events that cannot be processed to the Amazon SNS topic or Amazon SQS queue
that youve congured for the Lambda function. Functions without an associated DLQ discard events
after they have exhausted their retries. For more information about retry policies, see Retries on
Errors (p. 178). You need to explicitly provide read/publish/sendMessage access to your DLQ resource
as part of the execution role for your Lambda function. The payload written to the DLQ target ARN is
the original event payload with no modications to the message body. The attributes of the message,
described below, contain information to help you understand why the event wasnt processed:

Name Type Value

RequestID String Unique request identier

ErrorCode Number 3-digit HTTP error code

ErrorMessage String Error message (truncated to


1 KB)

If for some reason, the event payload consistently fails to reach the target ARN, Lambda increments a
CloudWatch metric called DeadLetterErrors and then deletes the event payload.

122
AWS Lambda Developer Guide

Building Applications with AWS


Lambda

When building applications on AWS Lambda, including serverless applications, the core components
are Lambda functions and event sources. An event source is the AWS service or custom application that
publishes events, and a Lambda function is the custom code that processes the events. To illustrate,
consider the following scenarios:

File processing Suppose you have a photo sharing application. People use your application to upload
photos, and the application stores these user photos in an Amazon S3 bucket. Then, your application
creates a thumbnail version of each user's photos and displays them on the user's prole page. In this
scenario, you may choose to create a Lambda function that creates a thumbnail automatically. Amazon
S3 is one of the supported AWS event sources that can publish object-created events and invoke your
Lambda function. Your Lambda function code can read the photo object from the S3 bucket, create a
thumbnail version, and then save it in another S3 bucket.
Data and analytics Suppose you are building an analytics application and storing raw data in a
DynamoDB table. When you write, update, or delete items in a table, DynamoDB streams can publish
item update events to a stream associated with the table. In this case, the event data provides the
item key, event name (such as insert, update, and delete), and other relevant details. You can write a
Lambda function to generate custom metrics by aggregating raw data.
Websites Suppose you are creating a website and you want to host the backend logic on Lambda.
You can invoke your Lambda function over HTTP using Amazon API Gateway as the HTTP endpoint.
Now, your web client can invoke the API, and then API Gateway can route the request to Lambda.
Mobile applications Suppose you have a custom mobile application that produces events. You can
create a Lambda function to process events published by your custom application. For example, in
this scenario you can congure a Lambda function to process the clicks within your custom mobile
application.

Each of these event sources uses a specic format for the event data. For more information, see Sample
Events Published by Event Sources (p. 136). When a Lambda function is invoked, it receives the event as
a parameter for the Lambda function.

AWS Lambda supports many AWS services as event sources. For more information, see Supported Event
Sources (p. 131). When you congure these event sources to trigger a Lambda function, the Lambda

123
AWS Lambda Developer Guide
Example 1

function is invoked automatically when events occur. You dene event source mapping, which is how you
identify what events to track and which Lambda function to invoke.

In addition to the supported AWS services, user applications can also generate eventsyou can build
your own custom event sources. Custom event sources invoke a Lambda function using the AWS Lambda
Invoke (p. 401) operation. User applications, such as client, mobile, or web applications, can publish
events and invoke Lambda functions on demand using the AWS SDKs or AWS Mobile SDKs, such as the
AWS Mobile SDK for Android.

The following are introductory examples of event sources and how the end-to-end experience works.

Example 1: Amazon S3 Pushes Events and Invokes


a Lambda Function
Amazon S3 can publish events of dierent types, such as PUT, POST, COPY, and DELETE object events on
a bucket. Using the bucket notication feature, you can congure an event source mapping that directs
Amazon S3 to invoke a Lambda function when a specic type of event occurs, as shown in the following
illustration.

The diagram illustrates the following sequence:

1. The user creates an object in a bucket.


2. Amazon S3 detects the object created event.
3. Amazon S3 invokes your Lambda function using the permissions provided by the execution
role. For more information on execution roles, see Authentication and Access Control for AWS
Lambda (p. 320). Amazon S3 knows which Lambda function to invoke based on the event source
mapping that is stored in the bucket notication conguration.
4. AWS Lambda executes the Lambda function, specifying the event as a parameter.

Note the following:

The event source mapping is maintained within the event source service, Amazon S3 in this scenario.
This is true for all supported AWS event sources except the stream-based sources (Kinesis and
DynamoDB streams). The next example explains stream-based event sources.
The event source (Amazon S3) invokes the Lambda function (referred to as the push model). Again, this
is true for all supported AWS services except the stream-based event sources.

124
AWS Lambda Developer Guide
Example 2

In order for the event source (Amazon S3) to invoke your Lambda function, you must grant
permissions using the permissions policy attached to the Lambda function.

Example 2: AWS Lambda Pulls Events from an


Kinesis Stream and Invokes a Lambda Function
For stream-based event sources, AWS Lambda polls the stream and invokes the Lambda function when
records are detected on the stream. These stream sources are special in that event source mapping
information is stored in Lambda. AWS Lambda provides an API for you to create and manage these event
source mappings.

The following diagram shows how a custom application writes records to an Kinesis stream.

The diagram illustrates the following sequence:

1. The custom application writes records to an Kinesis stream.


2. AWS Lambda continuously polls the stream, and invokes the Lambda function when the service
detects new records on the stream. AWS Lambda knows which stream to poll and which Lambda
function to invoke based on the event source mapping you create in Lambda.
3. The Lambda function is invoked with the incoming event.

Note the following:

When working with stream-based event sources, the following is true:


You create event source mappings in AWS Lambda.
AWS Lambda invokes the Lambda function (referred to as the pull model).
AWS Lambda does not need permission to invoke your Lambda function, therefore you don't need to
add any permissions to the permissions policy attached to your Lambda function.
Your Lambda role needs permission to read from the stream.

Example 3: Custom Application Publishes Events


and Invokes a Lambda Function
The following diagram shows how a custom application in your account invokes your Lambda function.

125
AWS Lambda Developer Guide
Example 3: Custom Application Publishes
Events and Invokes a Lambda Function

The diagram illustrates the following sequence:

1. The custom application invokes your Lambda function using the AWS SDK.
2. The Lambda function is invoked with the incoming event.

The following diagram shows how a custom mobile application invokes a Lambda function.

1. The mobile application sends a request to Amazon Cognito with an identity pool ID in the request (you
create the identity pool as part of the setup).
2. Amazon Cognito returns temporary security credentials to the application.

Amazon Cognito assumes the role associated with the identity pool to generate temporary
credentials.
3. The mobile application invokes the Lambda function using the temporary credentials (Cognito
Identity).
4. AWS Lambda assumes the execution role to execute your Lambda function on your behalf.
5. The Lambda function executes.
6. AWS Lambda returns results to the mobile application, assuming the app invoked the Lambda
function using the RequestResponse invocation type (referred to as synchronous invocation).

126
AWS Lambda Developer Guide
Suggested Reading

Note the following:

This is an example of an on-demand invocation of a Lambda function. For on-demand invocations, you
don't need to precongure an event source mapping like you do for AWS services.
In this example, because the custom application is using the same account credentials as the account
that owns the Lambda function, it does not require additional permissions to invoke the function.

Suggested Reading
If you are new to AWS Lambda, we recommend that you read all of the topics in this section for details.
You might also consider exploring the Getting Started (p. 185) exercise rst to get hands-on experience
creating and testing a Lambda function, and then read the topics in this chapter.

Additionally, the Building Lambda Functions (p. 5) also provides introductory information that you might
nd useful, before you dive deep into the technology.

Event Source Mapping


In AWS Lambda, Lambda functions and event sources are the core components in AWS Lambda. For
more information, see AWS Lambda: How It Works (p. 175). An event source is the entity that publishes
events, and a Lambda function is the custom code that processes the events. Supported event sources
refer to those AWS services that can be precongured to work with AWS Lambda. The conguration
is referred to as event source mapping, which maps an event source to a Lambda function. It enables
automatic invocation of your Lambda function when events occur.

Each event source mapping identies the type of events to publish and the Lambda function to invoke
when events occur. The specic Lambda function then receives the event information as a parameter,
your Lambda function code can then process the event.

Note the following about the event sources. These event sources can be any of the following:

AWS services These are the supported AWS services that can be precongured to work with AWS
Lambda. You can group these services as regular AWS services or stream-based services. Amazon
Kinesis Streams and Amazon DynamoDB Streams are stream-based event sources, all others AWS
services do not use stream-based event sources. Where you maintain the event source mapping and
how the Lambda function is invoked depends on whether or not you're using a stream-based event
source.
Custom applications You can have your custom applications publish events and invoke a Lambda
function.

You may be wonderingwhere do I keep the event mapping information? Do I keep it within the event
source or within AWS Lambda? The following sections explain event source mapping for each of these
event source categories. These sections also explain how the Lambda function is invoked and how you
manage permissions to allow invocation of your Lambda function.

Topics
Event Source Mapping for AWS Services (p. 128)
Event Source Mapping for AWS Stream-Based Services (p. 129)
Event Source Mapping for Custom Applications (p. 130)

127
AWS Lambda Developer Guide
Event Source Mapping for AWS Services

Event Source Mapping for AWS Services


Except for the stream-based AWS services (Amazon Kinesis Streams and DynamoDB streams), other
supported AWS services publish events and can also invoke your Lambda function (referred to as the
push model). In the push model, note the following:

Event source mappings are maintained within the event source. Relevant API support in the event
sources enables you to create and manage event source mappings. For example, Amazon S3 provides
the bucket notication conguration API. Using this API, you can congure an event source mapping
that identies the bucket events to publish and the Lambda function to invoke.
Because the event sources invoke your Lambda function, you need to grant the event source the
necessary permissions using a resource-based policy (referred to as the Lambda function policy). For
more information, see AWS Lambda Permissions Model (p. 179).

The following example illustrates how this model works.

Example Amazon S3 Pushes Events and Invokes a Lambda Function

Suppose that you want your AWS Lambda function invoked for each object created bucket event. You add
the necessary event source mapping in the bucket notication conguration.

The diagram illustrates the ow:

1. The user creates an object in a bucket.


2. Amazon S3 detects the object created event.
3. Amazon S3 invokes your Lambda function according to the event source mapping described in the
bucket notication conguration.
4. AWS Lambda veries the permissions policy attached to the Lambda function to ensure that Amazon
S3 has the necessary permissions. For more information on permissions policies, see Authentication
and Access Control for AWS Lambda (p. 320)
5. Once AWS Lambda veries the attached permissions policy, it executes the Lambda function.
Remember that your Lambda function receives the event as a parameter.

128
AWS Lambda Developer Guide
Event Source Mapping for AWS Stream-Based Services

Event Source Mapping for AWS Stream-Based


Services
The Amazon Kinesis Streams and DynamoDB streams are the stream-based services that you can
precongure to use with AWS Lambda. After you do the necessary event source mapping, AWS Lambda
polls the streams and invokes your Lambda function (referred to as the pull model). In the pull model,
note the following:

The event source mappings are maintained within the AWS Lambda. AWS Lambda provides
the relevant APIs to create and manage event source mappings. For more information, see
CreateEventSourceMapping (p. 361).
AWS Lambda needs your permission to poll the stream and read records. You grant these permissions
via the execution role, using the permissions policy associated with role that you specify when you
create your Lambda function. AWS Lambda does not need any permissions to invoke your Lambda
function.

The following example illustrates how this model works.

Example AWS Lambda Pulls Events from an Kinesis Stream and Invokes a Lambda Function

The following diagram shows a custom application that writes records to an Kinesis stream and how
AWS Lambda polls the stream. When AWS Lambda detects a new record on the stream, it invokes your
Lambda function.

Suppose you have a custom application that writes records to an Kinesis stream. You want to invoke a
Lambda function when new records are detected on the stream. You create a Lambda function and the
necessary event source mapping in AWS Lambda.

The diagram illustrates the following sequence:

1. The custom application writes records to an Kinesis stream.


2. AWS Lambda continuously polls the stream, and invokes the Lambda function when the service
detects new records on the stream. AWS Lambda knows which stream to poll and which Lambda
function to invoke based on the event source mapping you create in AWS Lambda.
3. Assuming the attached permission policy, which allows AWS Lambda to poll the stream, is veried,
AWS Lambda then executes the Lambda function. For more information on permissions policies, see
Authentication and Access Control for AWS Lambda (p. 320)

The example uses an Kinesis stream but the same applies when working with a DynamoDB stream.

129
AWS Lambda Developer Guide
Event Source Mapping for Custom Applications

Event Source Mapping for Custom Applications


If you have custom applications that publish and process events, you can create a Lambda function to
process these events. In this case, there is no preconguration requiredyou don't have to set up an
event source mapping. Instead, the event source uses the AWS Lambda Invoke API. If the application and
Lambda function are owned by dierent AWS accounts, the AWS account that owns the Lambda function
must allow cross-account permissions in the permissions policy associated with the Lambda function.

The following example illustrates how this works.

Example Custom Application Publishes Events and Invokes a Lambda Function

The following diagram shows how a custom application in your account can invoke a Lambda function. In
this example, the custom application is using the same account credentials as the account that owns the
Lambda function, and, therefore, does not require additional permissions to invoke the function.

In the following example, the user application and Lambda function are owned by dierent AWS
accounts. In this case, the AWS account that owns the Lambda function must have cross-account
permissions in the permissions policy associated with the Lambda function. For more information, see
AWS Lambda Permissions Model (p. 179).

Suggested Reading
If you are new to AWS Lambda, we suggest you read through all of the topics in the How It Works section
to familiarize yourself with Lambda. The next topic is Supported Event Sources (p. 131).

130
AWS Lambda Developer Guide
Supported Event Sources

After you read all of the topics in the How it Works section, we recommend that you review Building
Lambda Functions (p. 5), try the Getting Started (p. 185) exercise, and then explore the Use
Cases (p. 200). Each use case provides step-by-step instructions for you to set up the end-to-end
experience.

Supported Event Sources


This topic lists the supported AWS services that you can congure as event sources for AWS Lambda
functions. After you precongure the event source mapping, your Lambda function gets invoked
automatically when these event sources detect events. For more information about invocation modes,
see Event Source Mapping (p. 127).

For all of the event sources listed in this topic, note the following:

Event sources maintain the event source mapping, except for the stream-based services (Amazon
Kinesis Streams and Amazon DynamoDB Streams). For the stream-based services, AWS Lambda
maintains the event source mapping. AWS Lambda provides the CreateEventSourceMapping (p. 361)
operation for you to create and manage the event source mapping. For more information, see Event
Source Mapping (p. 127).


The invocation type that these event sources use when invoking a Lambda function is also
precongured. For example, Amazon S3 always invokes a Lambda function asynchronously and
Amazon Cognito invokes a Lambda function synchronously. The only time you can control the
invocation type is when you are invoking the Lambda function yourself using the Invoke (p. 401)
operation (for example, invoking a Lambda function on demand from your custom application).

You can also invoke a Lambda function on demand. For details, see Other Event Sources: Invoking a
Lambda Function On Demand (p. 136).

For examples of events that are published by these event sources, see Sample Events Published by Event
Sources (p. 136).

Topics
Amazon S3 (p. 132)
Amazon DynamoDB (p. 132)
Amazon Kinesis Streams (p. 132)
Amazon Simple Notication Service (p. 132)
Amazon Simple Email Service (p. 133)
Amazon Cognito (p. 133)
AWS CloudFormation (p. 134)
Amazon CloudWatch Logs (p. 134)
Amazon CloudWatch Events (p. 134)
AWS CodeCommit (p. 134)
Scheduled Events (powered by Amazon CloudWatch Events) (p. 135)
AWS Cong (p. 135)
Amazon Alexa (p. 135)
Amazon Lex (p. 136)
Amazon API Gateway (p. 136)
Other Event Sources: Invoking a Lambda Function On Demand (p. 136)
Sample Events Published by Event Sources (p. 136)

131
AWS Lambda Developer Guide
Amazon S3

Amazon S3
You can write Lambda functions to process S3 bucket events, such as the object-created or object-
deleted events. For example, when a user uploads a photo to a bucket, you might want Amazon S3 to
invoke your Lambda function so that it reads the image and creates a thumbnail for the photo.

You can use the bucket notication conguration feature in Amazon S3 to congure the event source
mapping, identifying the bucket events that you want Amazon S3 to publish and which Lambda function
to invoke.

For an example Amazon S3 event, see Event Message Structure, Amazon S3 Put Sample Event (p. 142),
and Amazon S3 Delete Sample Event (p. 143). For an example use case, see Using AWS Lambda with
Amazon S3 (p. 200).

Error handling for a given event source depends on how Lambda is invoked. Amazon S3 invokes your
Lambda function asynchronously. For more information on how errors are retried, see Retries on
Errors (p. 178).

Amazon DynamoDB
You can use Lambda functions as triggers for your Amazon DynamoDB table. Triggers are custom actions
you take in response to updates made to the DynamoDB table. To create a trigger, rst you enable
Amazon DynamoDB Streams for your table. AWS Lambda polls the stream and your Lambda function
processes any updates published to the stream.

This is a stream-based event source. For stream-based service, you create event source mapping in AWS
Lambda, identifying the stream to poll and which Lambda function to invoke.

For an example DynamoDB event, see Step 2.3.2: Test the Lambda Function (Invoke Manually) (p. 234)
and Amazon DynamoDB Update Sample Event (p. 140). For general format, see GetRecord in the
Amazon DynamoDB API Reference. For an example use case, see Using AWS Lambda with Amazon
DynamoDB (p. 227).

Error handling for a given event source depends on how Lambda is invoked. DynamoDB is a stream-
based event source. For more information on how errors are retried, see Retries on Errors (p. 178).

Amazon Kinesis Streams


You can congure AWS Lambda to automatically poll your stream and process any new records such as
website click streams, nancial transactions, social media feeds, IT logs, and location-tracking events.
Then, AWS Lambda polls the stream periodically (once per second) for new records.

For stream-based service, you create event source mapping in AWS Lambda, identifying the stream to
poll and which Lambda function to invoke.

For an example event, see Step 2.3: Create the Lambda Function and Test It Manually (p. 223) and
Amazon Kinesis Streams Sample Event (p. 142). For an example use case, see Using AWS Lambda with
Kinesis (p. 217).

Error handling for a given event source depends on how Lambda is invoked. Amazon Kinesis Streams
is a stream-based event source. For more information on how errors are retried, see Retries on
Errors (p. 178).

Amazon Simple Notication Service


You can write Lambda functions to process Amazon Simple Notication Service notications. When a
message is published to an Amazon SNS topic, the service can invoke your Lambda function by passing

132
AWS Lambda Developer Guide
Amazon Simple Email Service

the message payload as parameter. Your Lambda function code can then process the event, for example
publish the message to other Amazon SNS topics, or send the message to other AWS services.

This also enables you to trigger a Lambda function in response to Amazon CloudWatch alarms and other
AWS services that use Amazon SNS.

You congure the event source mapping in Amazon SNS via topic subscription conguration. For more
information, see Invoking Lambda functions using Amazon SNS notications in the Amazon Simple
Notication Service Developer Guide.

For an example event, see Appendix: Message and JSON Formats and Amazon SNS Sample
Event (p. 139). For an example use case, see Using AWS Lambda with Amazon SNS from Dierent
Accounts (p. 253).

When a user calls the SNS Publish API on a topic that your Lambda function is subscribed to, Amazon
SNS will call Lambda to invoke your function asynchronously. Lambda will then return a delivery status.
If there was an error calling Lambda, Amazon SNS will retry invoking the Lambda function up to three
times. After three tries, if Amazon SNS still could not successfully invoke the Lambda function, then
Amazon SNS will send a delivery status failure message to CloudWatch.

Error handling for a given event source depends on how Lambda is invoked. Amazon SNS invokes
your Lambda function asynchronously. For more information on how errors are retried, see Retries on
Errors (p. 178).

Amazon Simple Email Service


Amazon Simple Email Service (Amazon SES) is a cost-eective email service. With Amazon SES, in
addition to sending emails, you can also use the service to receive messages. For more information about
Amazon SES, see Amazon Simple Email Service. When you use Amazon SES to receive messages, you can
congure Amazon SES to call your Lambda function when messages arrive. The service can then invoke
your Lambda function by passing in the incoming email event as parameter. For example scenarios, see
Considering Your Use Case for Amazon SES Email Receiving.

You congure event source mapping using the rule conguration in Amazon SES. The following topics
provide additional information in the Amazon Simple Email Service Developer Guide:

For sample events, see Lambda Action and Amazon SES Email Receiving Sample Event (p. 137).
For Lambda function examples, see Lambda Function Examples.

Error handling for a given event source depends on how Lambda is invoked. Amazon SES invokes
your Lambda function asynchronously. For more information on how errors are retried, see Retries on
Errors (p. 178).

Amazon Cognito
The Amazon Cognito Events feature enables you to run Lambda function in response to events in
Amazon Cognito. For example, you can invoke a Lambda function for the Sync Trigger events, that
is published each time a dataset is synchronized. To learn more and walk through an example, see
Introducing Amazon Cognito Events: Sync Triggers in the Mobile Development blog.

You congure event source mapping using Amazon Cognito event subscription conguration. For
information about event source mapping and a sample event, see Amazon Cognito Events in the
Amazon Cognito Developer Guide. For another example event, see Amazon Cognito Sync Trigger Sample
Event (p. 141)

Error handling for a given event source depends on how Lambda is invoked. Amazon Cognito is
congured to invoke a Lambda function synchronously. For more information on how errors are retried,
see Retries on Errors (p. 178).

133
AWS Lambda Developer Guide
AWS CloudFormation

AWS CloudFormation
As part of deploying AWS CloudFormation stacks, you can specify a Lambda function as a custom
resource to execute any custom commands. Associating a Lambda function with a custom
resource enables you to invoke your Lambda function whenever you create, update, or delete AWS
CloudFormation stacks.

You congure event source mapping in AWS CloudFormation using stack denition. For more
information, see AWS Lambda-backed Custom Resources in the AWS CloudFormation User Guide.

For an example event, see AWS CloudFormation Create Request Sample Event (p. 137).

Error handling for a given event source depends on how Lambda is invoked. AWS CloudFormation
invokes your Lambda function asynchronously. For more information on how errors are retried, see
Retries on Errors (p. 178).

Amazon CloudWatch Logs


You can use AWS Lambda functions to perform custom analysis on Amazon CloudWatch Logs using
CloudWatch Logs subscriptions. CloudWatch Logs subscriptions provide access to a real-time feed of
log events from CloudWatch Logs and deliver it to your AWS Lambda function for custom processing,
analysis, or loading to other systems. For more information about CloudWatch Logs, see Monitoring Log
Files.

You maintain event source mapping in Amazon CloudWatch Logs using the log subscription
conguration. For more information, see Real-time Processing of Log Data with Subscriptions (Example
2: AWS Lambda) in the Amazon CloudWatch User Guide.

For an example event, see Amazon CloudWatch Logs Sample Event (p. 139).

Error handling for a given event source depends on how Lambda is invoked. Amazon CloudWatch
Logs invokes your Lambda function asynchronously (invoking a Lambda function does not block write
operation into the logs). For more information on how errors are retried, see Retries on Errors (p. 178).

Amazon CloudWatch Events


Amazon CloudWatch Events help you to respond to state changes in your AWS resources. When your
resources change state, they automatically send events into an event stream. You can create rules that
match selected events in the stream and route them to your AWS Lambda function to take action. For
example, you can automatically invoke an AWS Lambda function to log the state of an EC2 instance or
AutoScaling Group.

You maintain event source mapping in Amazon CloudWatch Events by using a rule target denition. For
more information, see the PutTargets operation in the Amazon CloudWatch Events API Reference.

For sample events, see Supported Event Types in the Amazon CloudWatch User Guide.

Error handling for a given event source depends on how Lambda is invoked. Amazon CloudWatch Events
invokes your Lambda function asynchronously. For more information on how errors are retried, see
Retries on Errors (p. 178).

AWS CodeCommit
You can create a trigger for an AWS CodeCommit repository so that events in the repository will invoke
a Lambda function. For example, you can invoke a Lambda function when a branch or tag is created
or when a push is made to an existing branch. For more information, see Manage Triggers for an AWS
CodeCommit Repository.

134
AWS Lambda Developer Guide
Scheduled Events (powered by
Amazon CloudWatch Events)

You maintain the event source mapping in AWS CodeCommit by using a repository trigger. For more
information, see the PutRepositoryTriggers operation.

Error handling for a given event source depends on how Lambda is invoked. AWS CodeCommit invokes
your Lambda function asynchronously. For more information on how errors are retried, see Retries on
Errors (p. 178).

Scheduled Events (powered by Amazon CloudWatch


Events)
You can also set up AWS Lambda to invoke your code on a regular, scheduled basis using the schedule
event capability in Amazon CloudWatch Events. To set a schedule you can specify a xed rate (number
of hours, days, or weeks) or specify a cron expression (see Schedule Expression Syntax for Rules in the
Amazon CloudWatch User Guide).

You maintain event source mapping in Amazon CloudWatch Events by using a rule target denition. For
more information, see the PutTargets operation in the Amazon CloudWatch Events API Reference.

For an example use case, see Using AWS Lambda with Scheduled Events (p. 284).

For an example event, see Scheduled Event Sample Event (p. 139).

Error handling for a given event source depends on how Lambda is invoked. Amazon CloudWatch Events
is congured to invoke a Lambda function asynchronously. For more information on how errors are
retried, see Retries on Errors (p. 178).

AWS Cong
You can use AWS Lambda functions to evaluate whether your AWS resource congurations comply
with your custom Cong rules. As resources are created, deleted, or changed, AWS Cong records these
changes and sends the information to your Lambda functions. Your Lambda functions then evaluate
the changes and report results to AWS Cong. You can then use AWS Cong to assess overall resource
compliance: you can learn which resources are noncompliant and which conguration attributes are the
cause of noncompliance.

You maintain event source mapping in AWS Cong by using a rule target denition. For more
information, see the PutCongRule operation in the AWS Cong API reference.

For more information, see Evaluating Resources With AWS Cong Rules. For an example of setting a
custom rule, see Developing a Custom Rule for AWS Cong. For example Lambda functions, see Example
AWS Lambda Functions for AWS Cong Rules (Node.js).

Error handling for a given event source depends on how Lambda is invoked. AWS Cong is congured to
invoke a Lambda function asynchronously. For more information on how errors are retried, see Retries on
Errors (p. 178).

Amazon Alexa
You can use Lambda functions to build services that give new skills to Alexa, the Voice assistant on
Amazon Echo. The Alexa Skills Kit provides the APIs, tools, and documentation to create these new skills,
powered by your own services running as Lambda functions. Amazon Echo users can access these new
skills by asking Alexa questions or making requests. For more information, see Getting Started with Alexa
Skills Kit.

Error handling for a given event source depends on how Lambda is invoked. Amazon Echo is congured
to invoke a Lambda function synchronously. For more information on how errors are retried, see Retries
on Errors (p. 178).

135
AWS Lambda Developer Guide
Amazon Lex

Amazon Lex
Amazon Lex is an AWS service for building conversational interfaces into applications using voice and
text. Amazon Lex provides pre-build integration with AWS Lambda, allowing you to create Lambda
functions for use as code hook with your Amazon Lex bot. In your intent conguration, you can identify
your Lambda function to perform initialization/validation, fulllment, or both.

For more information, see Using Lambda Functions. For an example use case, see Exercise 1: Create
Amazon Lex Bot Using a Blueprint.

Error handling for a given event source depends on how Lambda is invoked. Amazon Lex is congured to
invoke a Lambda function synchronously. For more information on how errors are retried, see Retries on
Errors (p. 178).

Amazon API Gateway


You can invoke a Lambda function over HTTPS. You can do this by dening a custom REST API and
endpoint using Amazon API Gateway. You map individual API operations, such as GET and PUT, to specic
Lambda functions. When you send an HTTPS request to the API endpoint, the Amazon API Gateway
service invokes the corresponding Lambda function.

For more information, see Make Synchronous Calls to Lambda Functions. For an example use case, see
Using AWS Lambda with Amazon API Gateway (On-Demand Over HTTPS) (p. 258).

Error handling for a given event source depends on how Lambda is invoked. Amazon API Gateway is
congured to invoke a Lambda function synchronously. For more information on how errors are retried,
see Retries on Errors (p. 178).

In addition, you can also use Lambda functions with other AWS services that publish data to one of the
supported AWS event sources listed in this topic. For example, you can:

Trigger Lambda functions in response to CloudTrail updates because it records all API access events to
an Amazon S3 bucket.
Trigger Lambda functions in response to CloudWatch alarms because it publishes alarm events to an
Amazon SNS topic.

Other Event Sources: Invoking a Lambda Function On


Demand
In addition to invoking Lambda functions using event sources, you can also invoke your Lambda function
on demand. You don't need to precongure any event source mapping in this case. However, make sure
that the custom application has the necessary permissions to invoke your Lambda function.

For example, user applications can also generate events (build your own custom event sources). User
applications such as client, mobile, or web applications can publish events and invoke Lambda functions
using the AWS SDKs or AWS Mobile SDKs such as the AWS Mobile SDK for Android.

For more information, see Tools for Amazon Web Services. For an example tutorial, see Using AWS
Lambda with Amazon API Gateway (On-Demand Over HTTPS) (p. 258).

Sample Events Published by Event Sources


The following is a list of example events published by the supported AWS services. For more information
about the supported AWS event sources, see Supported Event Sources (p. 131).

136
AWS Lambda Developer Guide
Sample Event Data

Sample Events

AWS CloudFormation Create Request Sample Event (p. 137)


Amazon SES Email Receiving Sample Event (p. 137)
Scheduled Event Sample Event (p. 139)
Amazon CloudWatch Logs Sample Event (p. 139)
Amazon SNS Sample Event (p. 139)
Amazon DynamoDB Update Sample Event (p. 140)
Amazon Cognito Sync Trigger Sample Event (p. 141)
Amazon Kinesis Streams Sample Event (p. 142)
Amazon S3 Put Sample Event (p. 142)
Amazon S3 Delete Sample Event (p. 143)
Mobile Backend Sample Event (p. 143)
Amazon Lex Sample Event (p. 144)

AWS CloudFormation Create Request Sample Event

{
"StackId": stackidarn,
"ResponseURL": "http://pre-signed-S3-url-for-response",
"ResourceProperties": {
"StackName": "stack-name",
"List": [
"1",
"2",
"3"
]
},
"RequestType": "Create",
"ResourceType": "Custom::TestResource",
"RequestId": "unique id for this create request",
"LogicalResourceId": "MyTestResource"
}

Amazon SES Email Receiving Sample Event

"Records": [
{
"eventVersion": "1.0",
"ses": {
"mail": {
"commonHeaders": {
"from": [
"Jane Doe <janedoe@example.com>"
],
"to": [
"johndoe@example.com"
],
"returnPath": "janedoe@example.com",
"messageId": "<0123456789example.com>",
"date": "Wed, 7 Oct 2015 12:34:56 -0700",
"subject": "Test Subject"
},
"source": "janedoe@example.com",

137
AWS Lambda Developer Guide
Sample Event Data

"timestamp": "1970-01-01T00:00:00.000Z",
"destination": [
"johndoe@example.com"
],
"headers": [
{
"name": "Return-Path",
"value": "<janedoe@example.com>"
},
{
"name": "Received",
"value": "from mailer.example.com (mailer.example.com
[203.0.113.1]) by inbound-smtp.us-west-2.amazonaws.com with SMTP id
o3vrnil0e2ic28trm7dfhrc2v0cnbeccl4nbp0g1x for johndoe@example.com; Wed, 07 Oct 2015
12:34:56 +0000 (UTC)"
},
{
"name": "DKIM-Signature",
"value": "v=1; a=rsa-sha256; c=relaxed/relaxed; d=example.com;
s=example; h=mime-version:from:date:message-id:subject:to:content-type;
bh=jX3F0bCAI7sIbkHyy3mLYO28ieDQz2R0P8HwQkklFj4x=; b=sQwJ+LMe9RjkesGu
+vqU56asvMhrLRRYrWCbVt6WJulueecwfEwRf9JVWgkBTKiL6m2hr70xDbPWDhtLdLO
+jB3hzjVnXwK3pYIOHw3vxG6NtJ6o61XSUwjEsp9tdyxQjZf2HNYee873832l3K1EeSXKzxYk9Pwqcpi3dMC74ct9GukjIevf1H
+k6khpurTQQ4sp4PZPRlgHtnj3Zzv7nmpTo7dtPG5z5S9J+L+Ba7dixT0jn3HuhaJ9b
+VThboo4YfsX9PMNhWWxGjVksSFOcGluPO7QutCPyoY4gbxtwkN9W69HA=="
},
{
"name": "MIME-Version",
"value": "1.0"
},
{
"name": "From",
"value": "Jane Doe <janedoe@example.com>"
},
{
"name": "Date",
"value": "Wed, 7 Oct 2015 12:34:56 -0700"
},
{
"name": "Message-ID",
"value": "<0123456789example.com>"
},
{
"name": "Subject",
"value": "Test Subject"
},
{
"name": "To",
value": "johndoe@example.com"
},
{
"name": "Content-Type",
"value": "text/plain; charset=UTF-8"
}
],
"headersTruncated": false,
"messageId": "o3vrnil0e2ic28trm7dfhrc2v0clambda4nbp0g1x"
},
"receipt": {
"recipients": [
"johndoe@example.com"
],
"timestamp": "1970-01-01T00:00:00.000Z",
"spamVerdict": {
"status": "PASS"
},

138
AWS Lambda Developer Guide
Sample Event Data

"dkimVerdict": {
"status": "PASS"
},
"processingTimeMillis": 574,
"action": {
"type": "Lambda",
"invocationType": "Event",
"functionArn": functionarn
},
"spfVerdict": {
"status": "PASS"
},
"virusVerdict": {
"status": "PASS"
}
}
},
"eventSource": "aws:ses"
}
]
}]}

Scheduled Event Sample Event

{
"account": "123456789012",
"region": "us-east-1",
"detail": {},
"detail-type": "Scheduled Event",
"source": "aws.events",
"time": "1970-01-01T00:00:00Z",
"id": "cdc73f9d-aea9-11e3-9d5a-835b769c0d9c",
"resources": [
"arn:aws:events:us-east-1:123456789012:rule/my-schedule"
]
}

Amazon CloudWatch Logs Sample Event

{
"awslogs": {
"data": "H4sIAAAAAAAAAHWPwQqCQBCGX0Xm7EFtK
+smZBEUgXoLCdMhFtKV3akI8d0bLYmibvPPN3wz00CJxmQnTO41whwWQRIctmEcB6sQbFC3CjW3XW8kxpOpP
+OC22d1Wml1qZkQGtoMsScxaczKN3plG8zlaHIta5KqWsozoTYw3/djzwhpLwivWFGHGpAFe7DL68JlBUk
+l7KSN7tCOEJ4M3/qOI49vMHj+zCKdlFqLaU2ZHV2a4Ct/an0/ivdX8oYc1UVX860fQDQiMdxRQEAAA=="
}
}

Amazon SNS Sample Event

{
"Records": [
{
"EventVersion": "1.0",
"EventSubscriptionArn": eventsubscriptionarn,
"EventSource": "aws:sns",
"Sns": {
"SignatureVersion": "1",
"Timestamp": "1970-01-01T00:00:00.000Z",
"Signature": "EXAMPLE",
"SigningCertUrl": "EXAMPLE",
"MessageId": "95df01b4-ee98-5cb9-9903-4c221d41eb5e",

139
AWS Lambda Developer Guide
Sample Event Data

"Message": "Hello from SNS!",


"MessageAttributes": {
"Test": {
"Type": "String",
"Value": "TestString"
},
"TestBinary": {
"Type": "Binary",
"Value": "TestBinary"
}
},
"Type": "Notification",
"UnsubscribeUrl": "EXAMPLE",
"TopicArn": topicarn,
"Subject": "TestInvoke"
}
}
]
}

Amazon DynamoDB Update Sample Event

{
"Records": [
{
"eventID": "1",
"eventVersion": "1.0",
"dynamodb": {
"Keys": {
"Id": {
"N": "101"
}
},
"NewImage": {
"Message": {
"S": "New item!"
},
"Id": {
"N": "101"
}
},
"StreamViewType": "NEW_AND_OLD_IMAGES",
"SequenceNumber": "111",
"SizeBytes": 26
},
"awsRegion": "us-west-2",
"eventName": "INSERT",
"eventSourceARN": eventsourcearn,
"eventSource": "aws:dynamodb"
},
{
"eventID": "2",
"eventVersion": "1.0",
"dynamodb": {
"OldImage": {
"Message": {
"S": "New item!"
},
"Id": {
"N": "101"
}
},
"SequenceNumber": "222",
"Keys": {

140
AWS Lambda Developer Guide
Sample Event Data

"Id": {
"N": "101"
}
},
"SizeBytes": 59,
"NewImage": {
"Message": {
"S": "This item has changed"
},
"Id": {
"N": "101"
}
},
"StreamViewType": "NEW_AND_OLD_IMAGES"
},
"awsRegion": "us-west-2",
"eventName": "MODIFY",
"eventSourceARN": sourcearn,
"eventSource": "aws:dynamodb"
},
{
"eventID": "3",
"eventVersion": "1.0",
"dynamodb": {
"Keys": {
"Id": {
"N": "101"
}
},
"SizeBytes": 38,
"SequenceNumber": "333",
"OldImage": {
"Message": {
"S": "This item has changed"
},
"Id": {
"N": "101"
}
},
"StreamViewType": "NEW_AND_OLD_IMAGES"
},
"awsRegion": "us-west-2",
"eventName": "REMOVE",
"eventSourceARN": sourcearn,
"eventSource": "aws:dynamodb"
}
]
}

Amazon Cognito Sync Trigger Sample Event

{
"datasetName": "datasetName",
"eventType": "SyncTrigger",
"region": "us-east-1",
"identityId": "identityId",
"datasetRecords": {
"SampleKey2": {
"newValue": "newValue2",
"oldValue": "oldValue2",
"op": "replace"
},
"SampleKey1": {

141
AWS Lambda Developer Guide
Sample Event Data

"newValue": "newValue1",
"oldValue": "oldValue1",
"op": "replace"
}
},
"identityPoolId": "identityPoolId",
"version": 2
}

Amazon Kinesis Streams Sample Event

"Records": [
{
"eventID":
"shardId-000000000000:49545115243490985018280067714973144582180062593244200961",
"eventVersion": "1.0",
"kinesis": {
"partitionKey": "partitionKey-3",
"data": "SGVsbG8sIHRoaXMgaXMgYSB0ZXN0IDEyMy4=",
"kinesisSchemaVersion": "1.0",
"sequenceNumber": "49545115243490985018280067714973144582180062593244200961"
},
"invokeIdentityArn": identityarn,
"eventName": "aws:kinesis:record",
"eventSourceARN": eventsourcearn,
"eventSource": "aws:kinesis",
"awsRegion": "us-east-1"
}
]
}

Amazon S3 Put Sample Event

{
"Records": [
{
"eventVersion": "2.0",
"eventTime": "1970-01-01T00:00:00.000Z",
"requestParameters": {
"sourceIPAddress": "127.0.0.1"
},
"s3": {
"configurationId": "testConfigRule",
"object": {
"eTag": "0123456789abcdef0123456789abcdef",
"sequencer": "0A1B2C3D4E5F678901",
"key": "HappyFace.jpg",
"size": 1024
},
"bucket": {
"arn": bucketarn,
"name": "sourcebucket",
"ownerIdentity": {
"principalId": "EXAMPLE"
}
},
"s3SchemaVersion": "1.0"
},
"responseElements": {

142
AWS Lambda Developer Guide
Sample Event Data

"x-amz-id-2": "EXAMPLE123/5678abcdefghijklambdaisawesome/
mnopqrstuvwxyzABCDEFGH",
"x-amz-request-id": "EXAMPLE123456789"
},
"awsRegion": "us-east-1",
"eventName": "ObjectCreated:Put",
"userIdentity": {
"principalId": "EXAMPLE"
},
"eventSource": "aws:s3"
}
]
}

Amazon S3 Delete Sample Event

{
"Records": [
{
"eventVersion": "2.0",
"eventTime": "1970-01-01T00:00:00.000Z",
"requestParameters": {
"sourceIPAddress": "127.0.0.1"
},
"s3": {
"configurationId": "testConfigRule",
"object": {
"sequencer": "0A1B2C3D4E5F678901",
"key": "HappyFace.jpg"
},
"bucket": {
"arn": bucketarn,
"name": "sourcebucket",
"ownerIdentity": {
"principalId": "EXAMPLE"
}
},
"s3SchemaVersion": "1.0"
},
"responseElements": {
"x-amz-id-2": "EXAMPLE123/5678abcdefghijklambdaisawesome/
mnopqrstuvwxyzABCDEFGH",
"x-amz-request-id": "EXAMPLE123456789"
},
"awsRegion": "us-east-1",
"eventName": "ObjectRemoved:Delete",
"userIdentity": {
"principalId": "EXAMPLE"
},
"eventSource": "aws:s3"
}
]
}

Mobile Backend Sample Event

{
"operation": "echo",
"message": "Hello world!"

143
AWS Lambda Developer Guide
Deploying Lambda-based Applications

Amazon Lex Sample Event

{
"messageVersion": "1.0",
"invocationSource": "FulfillmentCodeHook or DialogCodeHook",
"userId": "user-id specified in the POST request to Amazon Lex.",
"sessionAttributes": {
"key1": "value1",
"key2": "value2",
},
"bot": {
"name": "bot-name",
"alias": "bot-alias",
"version": "bot-version"
},
"outputDialogMode": "Text or Voice, based on ContentType request header in runtime
API request",
"currentIntent": {
"name": "intent-name",
"slots": {
"slot-name": "value",
"slot-name": "value",
"slot-name": "value"
},
"confirmationStatus": "None, Confirmed, or Denied
(intent confirmation, if configured)"
}
}

Deploying Lambda-based Applications


Lambda-based applications (also referred to as serverless applications) are composed of functions
triggered by events. A typical serverless application consists of one or more functions triggered by events
such as object uploads to Amazon S3, Amazon SNS notications, and API actions. Those functions can
stand alone or leverage other resources such as DynamoDB tables or Amazon S3 buckets. The most basic
serverless application is simply a function.

AWS Lambda provides API operations that you can use to create and update Lambda functions by
providing a deployment package as a ZIP le. However, this mechanism might not be convenient for
automating deployment steps for functions, or coordinating deployments and updates to other elements
of a serverless application (like event sources and downstream resources). For example, in order to
deploy an Amazon SNS trigger, you need to update the function, the Amazon SNS topic, the mapping
between the function and the topic, and any other downstream resources required by your function such
as a DynamoDB table.

Deploying Serverless Applications Using AWS


CloudFormation
You can use AWS CloudFormation to specify, deploy, and congure serverless applications. AWS
CloudFormation is a service that helps you model and set up your AWS resources so that you can spend
less time managing those resources and more time focusing on your applications that run in AWS.
You create a template that describes all of the AWS resources that you want (like Lambda functions
and DynamoDB tables), and AWS CloudFormation takes care of provisioning and conguring those

144
AWS Lambda Developer Guide
Using the AWS Serverless Application Model (AWS SAM)

resources for you. You don't need to individually create and congure AWS resources and gure out
what's dependent on whatAWS CloudFormation handles all of that. For more information, see AWS
CloudFormation Concepts in the AWS CloudFormation User Guide.

Using the AWS Serverless Application Model (AWS


SAM)
The AWS Serverless Application Model (AWS SAM) is a model to dene serverless applications. AWS SAM
is natively supported by AWS CloudFormation and denes simplied syntax for expressing serverless
resources. The specication currently covers APIs, Lambda functions and Amazon DynamoDB tables. The
specication is available under Apache 2.0 for AWS partners and customers to adopt and extend within
their own toolsets. For details on the specication, see the AWS Serverless Application Model.

Serverless Resources Within AWS CloudFormation


AWS SAM supports special resource types that simplify how to express functions, APIs, mappings,
and DynamoDB tables for serverless applications, as well as some features for these services like
environment variables. The AWS CloudFormation description of these resources conforms to the AWS
Serverless Application Model. In order to deploy your application, simply specify the resources you need
as part of your application, along with their associated permissions policies in an AWS CloudFormation
template le (written in either JSON or YAML), package your deployment artifacts, and deploy the
template.

An AWS CloudFormation template with serverless resources conforming to the AWS SAM model is
referred to as a SAM le or template.

The examples following illustrate how to leverage AWS SAM to declare common components of a
serverless application. Note that the Handler and Runtime parameter values should match the ones you
used when you created the function in the previous section.

Lambda function
The following shows the notation you use to describe a Lambda function:

AWSTemplateFormatVersion: '2010-09-09'
Transform: AWS::Serverless-2016-10-31
Resources:

FunctionName:
Type: AWS::Serverless::Function
Properties:
Handler: index.handler
Runtime: runtime
CodeUri: s3://bucketName/codepackage.zip

The handler value of the Handler property points to the module containing the code your Lambda
function will execute when invoked. The index value of the Handler property indicates the name of the
le containing the code. You can declare as many functions as your serverless application requires.

You can also declare environment variables, which are conguration settings you can set for your
application. The following shows an example of a serverless app with two Lambda functions and an
environment variable that points to a DynamoDB table. You can update environment variables without
needing to modify, repackage, or redeploy your Lambda function code. For more information, see
Environment Variables (p. 92).

AWSTemplateFormatVersion: '2010-09-09'

145
AWS Lambda Developer Guide
Using the AWS Serverless Application Model (AWS SAM)

Transform: AWS::Serverless-2016-10-31
Resources:
PutFunction:
Type: AWS::Serverless::Function
Properties:
Handler: index.handler
Runtime: nodejs6.10
Policies: AWSLambdaDynamoDBExecutionRole
CodeUri: s3://bucketName/codepackage.zip
Environment:
Variables:
TABLE_NAME: !Ref Table
DeleteFunction:
Type: AWS::Serverless::Function
Properties:
Handler: index.handler
Runtime: nodejs6.10
Policies: AWSLambdaDynamoDBExecutionRole
CodeUri: s3://bucketName/codepackage.zip
Environment:
Variables:
TABLE_NAME: !Ref Table
Events:
Stream:
Type: DynamoDB
Properties:
Stream: !GetAtt DynamoDBTable.StreamArn
BatchSize: 100
StartingPosition: TRIM_HORIZON

DynamoDBTable:
Type: AWS::DynamoDB::Table
Properties:
AttributeDefinitions:
- AttributeName: id
AttributeType: S
KeySchema:
- AttributeName: id
KeyType: HASH
ProvisionedThroughput:
ReadCapacityUnits: 5
WriteCapacityUnits: 5
StreamSpecification:
StreamViewType: streamview type

Note the notation at the top:

AWSTemplateFormatVersion: '2010-09-09'
Transform: AWS::Serverless-2016-10-31

This is required in order to include objects dened by the AWS Serverless Application Model within an
AWS CloudFormation template.

SimpleTable
SimpleTable is a resource that creates a DynamoDB table with a single-attribute primary key. You can
use this simplied version if the data your serverless application is interacting with only needs to be
accessed by a single-valued key. You could update the previous example to use a SimpleTable, as shown
following:

AWSTemplateFormatVersion: '2010-09-09'

146
AWS Lambda Developer Guide
Using the AWS Serverless Application Model (AWS SAM)

Transform: AWS::Serverless-2016-10-31
Resources:
TableName:
Type: AWS::Serverless::SimpleTable
Properties:
PrimaryKey:
Name: id
Type: String
ProvisionedThroughput:
ReadCapacityUnits: 5
WriteCapacityUnits: 5

Events
Events are AWS resources that trigger the Lambda function, such as an Amazon API Gateway endpoint
or an Amazon SNS notication. The Events property is an array, which allows you to set multiple events
per function. The following shows the notation you use to describe a Lambda function with a DynamoDB
table as an event source:

AWSTemplateFormatVersion: '2010-09-09'
Transform: AWS::Serverless-2016-10-31
Resources:
FunctionName:
Type: AWS::Serverless::Function
Properties:
Handler: index.handler
Runtime: nodejs6.10
Events:
Stream:
Type: DynamoDB
Properties:
Stream: !GetAtt DynamoDBTable.StreamArn
BatchSize: 100
StartingPosition: TRIM_HORIZON
TableName:
Type: AWS::DynamoDB::Table
Properties:
AttributeDefinitions:
- AttributeName: id
AttributeType: S
KeySchema:
- AttributeName: id
KeyType: HASH
ProvisionedThroughput:
ReadCapacityUnits: 5
WriteCapacityUnits: 5

As mentioned preceding, you can set multiple event sources that will trigger the Lambda function. The
example following shows a Lambda function that can be triggered by either an HTTP PUT or POST event.

API
There are two ways to dene an API using AWS SAM. The following uses Swagger to congure the
underlying Amazon API Gateway resources:

AWSTemplateFormatVersion: '2010-09-09'
Transform: AWS::Serverless-2016-10-31
Resources:
Api:
Type: AWS::Serverless::Api

147
AWS Lambda Developer Guide
Using the AWS Serverless Application Model (AWS SAM)

Properties:
StageName: prod
DefinitionUri: swagger.yml

In the next example, the AWS::Serverless::Api resource type is implicity added from the union of API
events dened on AWS::Serverless::Function resources.

AWSTemplateFormatVersion: '2010-09-09'
Transform: AWS::Serverless-2016-10-31
Resources:
GetFunction:
Type: AWS::Serverless::Function
Properties:
Handler: index.get
Runtime: nodejs6.10
CodeUri: s3://bucket/api_backend.zip
Policies: AmazonDynamoDBReadOnlyAccess
Environment:
Variables:
TABLE_NAME: !Ref Table
Events:
GetResource:
Type: Api
Properties:
Path: /resource/{resourceId}
Method: get

PutFunction:
Type: AWS::Serverless::Function
Properties:
Handler: index.put
Runtime: nodejs6.10
CodeUri: s3://bucket/api_backend.zip
Policies: AmazonDynamoDBFullAccess
Environment:
Variables:
TABLE_NAME: !Ref Table
Events:
PutResource:
Type: Api
Properties:
Path: /resource/{resourceId}
Method: put

DeleteFunction:
Type: AWS::Serverless::Function
Properties:
Handler: index.delete
Runtime: nodejs6.10
CodeUri: s3://bucket/api_backend.zip
Policies: AmazonDynamoDBFullAccess
Environment:
Variables:
TABLE_NAME: !Ref Table
Events:
DeleteResource:
Type: Api
Properties:
Path: /resource/{resourceId}
Method: delete

Table:
Type: AWS::Serverless::SimpleTable

148
AWS Lambda Developer Guide
Create Your Own Serverless Application

In the example preceding, AWS CloudFormation will automatically generate an Amazon API Gateway API
with the path "/resource/{resourceId}" and with the methods GET, PUT and DELETE.

Permissions
You can supply an Amazon Resource Name (ARN) for an AWS Identity and Access Management (IAM) role
be used as this function's execution role, as shown following:

AWSTemplateFormatVersion: '2010-09-09'
Transform: AWS::Serverless-2016-10-31
Resources:
FunctionName:
Type: AWS::Serverless::Function
Properties:
Role:role arn

Alternatively, you could supply one or more managed policies to the Lambda function resource. AWS
CloudFormation will then create a new role with the managed policies plus the default Lambda basic
execution policy.

AWSTemplateFormatVersion: '2010-09-09'
Transform: AWS::Serverless-2016-10-31
Resources:
FunctionName:
Type: AWS::Serverless::Function
Properties:
Policies: AmazonDynamoDBFullAccess

If none of these are supplied, a default execution role is created with Lambda basic execution
permissions.
Note
In addition to using the serverless resources, you can also use conventional AWS
CloudFormation syntax for expressing resources in the same template. Any resources not
included in the current SAM model can still be created in the AWS CloudFormation template
using AWS CloudFormation syntax. In addition, you can use AWS CloudFormation syntax to
express serverless resources as an alternative to using the SAM model. For information about
specifying a Lambda function using conventional CloudFormation syntax as part of your SAM
template, see AWS::Lambda::Function in the AWS CloudFormation User Guide.

For a list of complete serverless application examples, see Examples of How to Use AWS
Lambda (p. 200).

Next Step
Create Your Own Serverless Application (p. 149)

Create Your Own Serverless Application


In the following tutorial, you create a simple serverless application that consists of a single function that
returns the name of an Amazon S3 bucket you specify as an environment variable. Follow these steps:

1. Copy and paste the following into a text le and save it as index.js

149
AWS Lambda Developer Guide
Create Your Own Serverless Application

var AWS = require('aws-sdk');

exports.handler = function(event, context, callback) {


var bucketName = process.env.S3_BUCKET;
callback(null, bucketName);
}

2. Paste the following into a text le and save it as example.yaml. Note that the Runtime parameter uses
nodejs6.10 but you can specify nodejs4.3.

AWSTemplateFormatVersion: '2010-09-09'
Transform: AWS::Serverless-2016-10-31
Resources:
TestFunction:
Type: AWS::Serverless::Function
Properties:
Handler: index.handler
Runtime: nodejs6.10
Environment:
Variables:
S3_BUCKET: bucket-name

3. Create a folder called examplefolder and place the example.yaml le and the index.js le inside the
folder.

Your example folder now contains the following two les that you can then use to package the
serverless application:
example.yaml
index.js

Packaging and Deployment


After you create your Lambda function handler and your example.yaml le, you can use the AWS CLI to
package and deploy your serverless application.

Packaging
To package your application, create an Amazon S3 bucket that the package command will use to upload
your ZIP deployment package (if you haven't specied one in your example.yaml le). You can use the
following command to create the Amazon S3 bucket:

aws s3 mb s3://bucket-name --region region

Next, open a command prompt and type the following:

aws cloudformation package \


--template-file example.yaml \
--output-template-file serverless-output.yaml \
--s3-bucket s3-bucket-name

The package command returns an AWS SAM template, in this case serverless-output.yaml that
contains the CodeUri that points to the deployment zip in the Amazon S3 bucket that you specied. This
template represents your serverless application. You are now ready to deploy it.

150
AWS Lambda Developer Guide
Create Your Own Serverless Application

Deployment
To deploy the application, run the following command:

aws cloudformation deploy \


--template-file serverless-output.yaml \
--stack-name new-stack-name \
--capabilities CAPABILITY_IAM

Note that the value you specify for the --template-file parameter is the name of the SAM template
that was returned by the package command. In addition, the --capabilities parameter is optional. The
AWS::Serverless::Function resource will implicitly create a role to execute the Lambda function if one
is not specied in the template. You use the --capabilities parameter to explicitly acknowledge that
AWS CloudFormation is allowed to create roles on your behalf.

When you run the aws cloudformation deploy command, it creates an AWS CloudFormation
ChangeSet, which is a list of changes to the AWS CloudFormation stack, and then deploys it. Some stack
templates might include resources that can aect permissions in your AWS account, for example, by
creating new AWS Identity and Access Management (IAM) users. For those stacks, you must explicitly
acknowledge their capabilities by specifying the --capabilities parameter. For more information, see
CreateChangeSet in the AWS CloudFormation API Reference.

To verify your results, open the AWS CloudFormation console to view the newly created AWS
CloudFormation stack and the Lambda console to view your function.

For a list of complete serverless application examples, see Examples of How to Use AWS
Lambda (p. 200).

Exporting a Serverless Application


You can export a serverless application and re-deploy it to, for example, a dierent AWS region
or development stage, using the Lambda console. When you export a Lambda function, you will
be provided with a ZIP deployment package and a SAM template that represents your serverless
application. You can then use the package and deploy commands described in the previous section for
re-deployment.

You can also select one of Lambda blueprints to create a ZIP package for you to package and deploy.
Follow the steps following to do this:

To export a serverless application using the Lambda console

1. Sign in to the AWS Management Console and open the AWS Lambda console at https://
console.aws.amazon.com/lambda/.
2. Do any of the following:

Create a function using a Lambda blueprint Choose a blueprint and follow the steps to create a
Lambda function. For an example, see Step 2.1: Create a Hello World Lambda Function (p. 189).
When you reach the Review page, choose Export function.
Create a function Choose Create function, and then create your function. After your Lambda
function is created, you can export it by selecting the function. Choose Actions, then choose
Export function.
Open an existing Lambda function Open the function by choosing the Function name, choose
Actions, choose Export function.
3. In the Export your function window, you have the following options:

Choose Download AWS SAM le, which denes the Lambda function and other resources that
comprise your serverless application.

151
AWS Lambda Developer Guide
Automating Deployment of Lambda-based Applications

Choose Download deployment package, which contains your Lambda function code and any
dependent libraries.

Use the AWS SAM le and the ZIP deployment package and follow the steps in Packaging and
Deployment (p. 150) to re-deploy the serverless application.

Automating Deployment of Lambda-based


Applications
In the previous section, you learned how to create a SAM template, generate your deployment package,
and use the AWS CLI to manually deploy your serverless application. In this section, you will leverage the
following AWS services to fully automate the deployment process.

CodePipeline: You use CodePipeline to model, visualize, and automate the steps required to release
your serverless application. For more information, see What is AWS CodePipeline?
CodeBuild: You use CodeBuild to build, locally test, and package your serverless application. For more
information, see What is AWS CodeBuild?
AWS CloudFormation: You use AWS CloudFormation to deploy your application. For more
information, see What is AWS CloudFormation?

Building a Pipeline for Your Serverless Application


In the following tutorial, you will create an AWS CodePipeline that automates the deployment of your
serverless application. First, you will need to set up a source stage to trigger your pipeline. For the
purposes of this tutorial:

We will use GitHub. For instructions on how to create a GitHub repository, see Create a Repository in
GitHub.
You will need to create an AWS CloudFormation role and add the AWSLambdaExecute policy to that
role, as outlined below:

1. Sign in to the AWS Management Console and open the IAM console at https://
console.aws.amazon.com/iam/.
2. Follow the steps in Creating a Role to Delegate Permissions to an AWS Service in the IAM User
Guide to create an IAM role (execution role) and go to the To create a role for an AWS service
section. As you follow the steps to create a role, note the following:
In Select Role Type, choose AWS Service Roles, and then choose AWS CloudFormation. This
grants the AWS CloudFormation service permissions to assume the role.
In Attach Policy, choose AWSLambdaExecute.
In Role Name, use a name that is unique within your AWS account (for example,
cloudformation-lambda-execution-role) and then choose Create role.
Open the role you just created and under the Permissions tab, expand Inline Policies and then
choose the click here link.
Choose Custom Policy and then choose Select.
In Policy Name enter a name for your custom policy and then paste the following into the
Policy Document eld:

{
"Statement": [
{
"Action": [

152
AWS Lambda Developer Guide
Automating Deployment of Lambda-based Applications

"s3:GetObject",
"s3:GetObjectVersion",
"s3:GetBucketVersioning"
],
"Resource": "*",
"Effect": "Allow"
},
{
"Action": [
"s3:PutObject"
],
"Resource": [
"arn:aws:s3:::codepipeline*"
],
"Effect": "Allow"
},
{
"Action": [
"lambda:*"
],
"Resource": [
"arn:aws:lambda:region:account-id:function:*"
],
"Effect": "Allow"
},
{
"Action": [
"apigateway:*"
],
"Resource": [
"arn:aws:apigateway:region::*"
],
"Effect": "Allow"
},
{
"Action": [
"iam:GetRole",
"iam:CreateRole",
"iam:DeleteRole"
],
"Resource": [
"arn:aws:iam::account-id:role/*"
],
"Effect": "Allow"
},
{
"Action": [
"iam:AttachRolePolicy",
"iam:DetachRolePolicy"
],
"Resource": [
"arn:aws:iam::account-id:role/*"
],
"Effect": "Allow"
},
{
"Action": [
"iam:PassRole"
],
"Resource": [
"*"
],
"Effect": "Allow"
},
{
"Action": [

153
AWS Lambda Developer Guide
Automating Deployment of Lambda-based Applications

"cloudformation:CreateChangeSet"
],
"Resource": [
"arn:aws:cloudformation:region:aws:transform/Serverless-2016-10-31"
],
"Effect": "Allow"
}
],
"Version": "2012-10-17"
}

Choose Validate Policy and then choose Apply Policy.

Step 1: Set Up Your Repository


To set up your repository, do the following:

Add an index.js le containing the code following:

var time = require('time');


exports.handler = (event, context, callback) => {
var currentTime = new time.Date();
currentTime.setTimezone("America/Los_Angeles");
callback(null, {
statusCode: '200',
body: 'The time in Los Angeles is: ' + currentTime.toString(),
});
};

Add a samTemplate.yaml le, containing the content following. This is the SAM template that denes
the resources in your application. This SAM template denes a Lambda function that is triggered by
API Gateway. Note that the runtime parameter uses nodejs6.10 but you can also specify nodejs4.3.
For more information about AWS SAM see AWS Serverless Application Model.

AWSTemplateFormatVersion: '2010-09-09'
Transform: AWS::Serverless-2016-10-31
Description: Outputs the time
Resources:
TimeFunction:
Type: AWS::Serverless::Function
Properties:
Handler: index.handler
Runtime: nodejs6.10
CodeUri: ./
Events:
MyTimeApi:
Type: Api
Properties:
Path: /TimeResource
Method: GET

Add a buildspec.yml le. A build spec is a collection of build commands and related settings, in
YAML format, that AWS CodeBuild uses to run a build. For more information, see Build Specication
Reference for AWS CodeBuild. In this example, the build action will be:
Use npm to install the time package.
Running the Package command to prepare your deployment package for subsequent deployment
steps in your pipeline. For more information on the package command, see Uploading Local
Artifacts to an S3 Bucket

154
AWS Lambda Developer Guide
Automating Deployment of Lambda-based Applications

version: 0.1
phases:
install:
commands:
- npm install time
- aws cloudformation package --template-file samTemplate.yaml --s3-bucket bucket-
name
--output-template-file NewSamTemplate.yaml
artifacts:
type: zip
files:
- NewSamTemplate.yaml

Note that you need to supply the --s3-bucket parameter value with the name of the your Amazon
S3 bucket, similar to the step you would take if you were manually going to package the deployment
package with SAM, as discussed in the Packaging (p. 150) step of the previous tutorial.

Step 2: Create Your Pipeline

Follow the steps following to create your AWS CodePipeline.

1. Sign in to the AWS Management Console and open the AWS CodePipeline console.
2. Choose Get Started Now.
3. In Pipeline name: enter a name for your pipeline and then choose Next step.
4. In Source provider: choose GitHub.
5. Choose Connect to GitHub: and then choose the Repository and Branch you want to connect to.
Every git push to the branch you select will trigger your pipeline. Choose Next step.
6. Choose AWS CodeBuild as your Build provider.
7. Choose Create a new build project and enter a project name.
8. Choose Ubuntu as the operating system.
9. Choose Node.js as the runtime.
10. In Version choose aws/codebuild/nodejs:4.3.2
11. Choose Save build project.
Note
A service role for AWS CodeBuild will automatically be created on your behalf.

Choose Next step.


12. In Deployment provider: choose AWS CloudFormation.

By selecting this option, AWS CloudFormation commands will be used to deploy the SAM template.
For more information see Serverless Resources Within AWS CloudFormation (p. 145).
13. In Action mode: choose create or replace a change set.
14. In Stack name: enter MyBetaStack.
15. In Change set name: enter MyChangeSet.
16. In Template le: enter NewSamTemplate.yaml.
17. In Capabilities: choose CAPABILITY_IAM.
18. In Role select the AWS CloudFormation role you created at the beginning of this tutorial and then
choose Next step.
19. Choose Create role. Choose Next and then choose Allow. Choose Next step.

155
AWS Lambda Developer Guide
Automating Deployment of Lambda-based Applications

20. Review your pipeline and then choose Create pipeline.

Step 3: Update the Generated Service Policy

Follow the steps following to allow CodeBuild to upload build artifacts to your Amazon S3 bucket.

1. Go to the IAM Management Console.


2. Choose Roles.
3. Open the service role that was generated for your project, typically code-build-project-name-
service-role.
4. Under the Permissions tab, choose Attach Policy.
5. Under the Permissions tab, choose Create Role Policy.
6. Choose Policy Generator and then choose Select.
7. In the AWS Service list, choose Amazon S3.
8. In Actions, choose PutObject.
9. In Amazon Resource Name (ARN), enter arn:aws:s3:::bucket-name*.
10. Choose Add Statement and then choose Next Step.
11. In Review Policy choose Validate Policy and then choose Apply Policy.

Step 4: Complete Your Beta Deployment Stage

Follow the steps following to complete your Beta stage.

1. Choose Edit.
2. Choose the

icon for your beta stage.


3. In the beta stage, choose the + Action icon that is located following your existing action.
4. In Category: choose Deploy.
5. In Action: enter execute_cs.
6. In Deployment provider: choose AWS CloudFormation.
7. In Action mode: choose execute a changeset. This is similar to the step you would take if you
were manually going to deploy the package, as discussed in the Deployment (p. 151) step of the
previous tutorial. CreateChangeSet transforms the SAM template to the full AWS CloudFormation
format and deployChangeSet deploys the AWS CloudFormation template.
8. In Stack name: enter MyBetaStack.
9. In Change set name: enter MyChangeSet.
10. Choose Add action.
11. Choose Save pipeline changes.
12. Choose Save and continue.

Your pipeline is ready. Any git push to the branch you connected to this pipeline is going to trigger a
deployment. To test your pipeline and deploy your application for the rst time, do one of the following:

Perform a git push to the branch connected to your pipeline.

156
AWS Lambda Developer Guide
Test Your Serverless Applications
Locally Using SAM Local (Public Beta)

Go the AWS CodePipeline console, choose the name of the pipeline you created and then choose
Release change.

Test Your Serverless Applications Locally Using


SAM Local (Public Beta)
This feature is available as part of a public beta and is subject to change at any time.

Described preceding, AWS SAM is a fast and easy way of deploying your serverless applications, allowing
you to write simple templates to describe your functions and their event sources (Amazon API Gateway,
Amazon S3, Kinesis, and so on). Based on AWS SAM, SAM Local is an AWS CLI tool that provides an
environment for you to develop, test, and analyze your serverless applications locally before uploading
them to the Lambda runtime. Whether you're developing on Linux, Mac, or Microsoft Windows, you can
use SAM Local to create a local testing environment that simulates the AWS runtime environment. Doing
so helps you address issues such as performance. Working with SAM Local also allows faster, iterative
development of your Lambda function code because there is no need to redeploy your application
package to the AWS Lambda runtime. For more information, see Building a Simple Application Using
SAM Local (p. 161).

SAM Local works with AWS SAM, allowing you to invoke functions dened in SAM templates, whether
directly or through API Gateway endpoints. By using SAM Local features, you can analyze your serverless
application's performance in your own testing environment and update accordingly. The following
examples outline additional advantages of using SAM Local with sample operation code. For instance,
you can do the following:

Generate sample function payloads (for example, an Amazon S3 event).

$ sam local generate-event s3 --bucket bucket-name --key key-name


> event_file.json

Test a sample function payload locally with your Lambda functions.

$ sam local invoke function-name -e event_file.json

Spawn a local API Gateway to test HTTP request and response functionality. By using the hot reloading
feature, you can test and iterate your functions without having to restart or reload them to the AWS
runtime.

$ sam local start-api

SAM Local will automatically nd any functions within your SAM template that have API event sources
dened, and mount them at the dened HTTP paths. In the example below, the Ratings function
would mount ratings.py:handler() at /ratings for GET requests.

Ratings:
Type: AWS::Serverless::Function
Properties:
Handler: ratings.handler
Runtime: python3.6
Events:
Api:
Type: Api

157
AWS Lambda Developer Guide
Supported Runtimes

Properties:
Path: /ratings
Method: get

By default, SAM Local uses Proxy Integration and expects the response from your Lambda function to
include one or more of the following: statusCode, headers and/or body. For example:

// Example of a Proxy Integration response


exports.handler = (event, context, callback) => {
callback(null, {
statusCode: 200,
headers: { "x-custom-header" : "my custom header value" },
body: "hello world"
});
}

If your Lambda function does not return a valid Proxy Integration response, you will receive an HTTP
500 (Internal Server Error) response when accessing your function. SAM Local will also print the
following error log message to help you diagnose the problem:

ERROR: Function ExampleFunction returned an invalid response (must include one of: body,
headers
or statusCode in the response object)

Validate that any runtime constraints, such as maximum memory use or timeout limits of your Lambda
function invocations, are honored.
Inspect AWS Lambda runtime logs, and also any customized logging output specied in your Lambda
function code (for example, console.log). SAM Local automatically displays this output. The following
shows an example.

START RequestId: 2137da9a-c79c-1d43-5716-406b4e6b5c0a Version: $LATEST


2017-05-18T13:18:57.852Z 2137da9a-c79c-1d43-5716-406b4e6b5c0a
Error: any error information
END RequestId: 2137da9a-c79c-1d43-5716-406b4e6b5c0a
REPORT RequestId: 2137da9a-c79c-1d43-5716-406b4e6b5c0a
Duration: 12.78 ms Billed Duration: 100 ms Memory Size: 128 MB
Max Memory Used: 29 MB

Honor security credentials that you've established by using the AWS CLI. Doing so means your Lambda
function can make remote calls to the AWS services that make up your serverless application. If you
have not installed the AWS CLI, see Installing the AWS Command Line Interface.

As with the AWS CLI and SDKs, SAM Local looks for credentials in the following order:
Environment variables (AWS_ACCESS_KEY_ID, AWS_SECRET_ACCESS_KEY)
The AWS credentials le, located at ~/.aws/credentials on Linux, MacOS, or Unix, or at C:\Users
\USERNAME \.aws\credentials on Windows)
Instance prole credentials, if running on an Amazon EC2 instance with an assigned instance role

Supported Runtimes
SAM Local supports the following AWS runtimes:

node.js 4.3
node.js 6.10
python 2.7

158
AWS Lambda Developer Guide
Requirements for Using SAM Local

python 3.6
java8

Requirements for Using SAM Local


To use SAM Local, you need to install Docker and SAM Local.

Installing Docker
Docker is an open-source software container platform that allows you to build, manage and test
applications, whether you're running on Linux, Mac or Windows. For more information and download
instructions, see Docker.

Once you have Docker installed, SAM Local automatically provides a customized Docker image called
docker-lambda. This image is designed specically by an AWS partner to simulate the live AWS Lambda
execution environment. This environment includes installed software, libraries, security permissions,
environment variables, and other features outlined at Lambda Execution Environment and Available
Libraries (p. 182).

Using docker-lambda, you can invoke your Lambda function locally. In this environment, your serverless
applications execute and perform much as in the AWS Lambda runtime, without your having to redeploy
the runtime. Their execution and performance in this environment reect such considerations as
timeouts and memory use.
Important
Because this is a simulated environment, there is no guarantee that your local testing results will
exactly match those in the actual AWS runtime.

For more information, see Docker Lambda on GitHub. (If you don't have a Github account, you can create
one for free and then access Docker Lambda).

Installing SAM Local


You can run SAM Local on Linux, Mac, and Windows environments. The easiest way to install SAM Local is
to use NPM.

npm install -g aws-sam-local

Then verify that the installation succeeded.

sam --version

If NPM doesn't work for you, you can download the latest binary and start using SAM Local immediately.
You can nd the binaries under the Releases section in the SAM CLI GitHub Repository.

Getting Started Using SAM Local


SAM Local consists of the following CLI operations:

start-api: Creates a local HTTP server hosting all of your Lambda functions. When accessed by using a
browser or the CLI, this operation launches a Docker container locally to invoke your function. It reads
the CodeUri property of the AWS::Serverless::Function resource to nd the path in your le system
containing the Lambda function code. This path can be the project's root directory for interpreted
languages like Node.js or Python, a build directory that stores your compiled artifacts, or for Java, a
.jar le.

159
AWS Lambda Developer Guide
Getting Started Using SAM Local

If you use an interpreted language, local changes are made available within the same Docker container.
This approach means you can reinvoke your Lambda function with no need for redeployment. For
compiled languages or projects requiring complex packing support, we recommend that you run
your own build solution and point AWS SAM to the directory that contains the build dependency les
needed.
invoke: Invokes a local Lambda function once and terminates after invocation completes.

# Invoking function with event file


$ sam local invoke "Ratings" -e event.json

# Invoking function with event via stdin


$ echo '{"message": "Hey, are you there?" }' | sam local invoke "Ratings"

# For more options


$ sam local invoke --help

generate-event: Generates mock serverless events. Using these, you can develop and test locally
on functions that respond to asynchronous events such as those from Amazon S3, Kinesis, and
DynamoDB. The following displays the command options available to the generate-event operation.

sam local generate-event


NAME:
sam local generate-event - Generates Lambda events (e.g. for S3/Kinesis etc) that can
be piped to 'sam local invoke'

USAGE:
sam local generate-event command [command options] [arguments...]

COMMANDS:
s3 Generates a sample Amazon S3 event
sns Generates a sample Amazon SNS event
kinesis Generates a sample Amazon Kinesis event
dynamodb Generates a sample Amazon DynamoDB event
api Generates a sample Amazon API Gateway event
schedule Generates a sample scheduled event

OPTIONS:
--help, -h show help

validate: Validates your template against the ocial AWS Serverless Application Model specication.
The following is an example.

$ sam validate
ERROR: Resource "HelloWorld", property "Runtime": Invalid value node.
Valid values are "nodejs4.3", "nodejs6.10", "java8", "python2.7",
"python3.6"(line: 11; col: 6)

# Let's fix that error...


$ sed -i 's/node/nodejs6.10/g' template.yaml

$ sam validate
Valid!

package and deploy: sam package and sam deploy implicitly call AWS CloudFormation's package and
deploy commands. For more information on packaging and deployment of SAM applications, see
Packaging and Deployment (p. 150).

The following demonstrates how to use the package and deploy commands in SAM Local.

# Package SAM template

160
AWS Lambda Developer Guide
Getting Started Using SAM Local

$ sam package --template-file sam.yaml --s3-bucket mybucket --output-template-file


packaged.yaml

# Deploy packaged SAM template


$ sam deploy --template-file ./packaged.yaml --stack-name mystack --capabilities
CAPABILITY_IAM

Building a Simple Application Using SAM Local


Suppose you want to build a simple RESTful API operation that creates, reads, updates, and deletes a list
of products. You begin by creating the following directory structure:

dir/products.js

dir/template.yaml

The template.yaml le is the AWS SAM template that describes a single Lambda function that handles all
the API requests.
Note
By default, the start-api and invoke commands search your working directory for the
template.yaml le. If you reference a template.yaml le that is in a dierent directory, add the -t
or --template parameter to these operations and pass an absolute or relative path to that le.

Copy and paste the following into the template.yaml le.

AWSTemplateFormatVersion : '2010-09-09'
Transform: AWS::Serverless-2016-10-31
Description: My first serverless application.

Resources:

Products:
Type: AWS::Serverless::Function
Properties:
Handler: products.handler
Runtime: nodejs6.10
Events:
ListProducts:
Type: Api
Properties:
Path: /products
Method: get
CreateProduct:
Type: Api
Properties:
Path: /products
Method: post
Product:
Type: Api
Properties:
Path: /products/{product}
Method: any

The preceding example congures the following RESTful API endpoints:

Create a new product with a PUT request to /products.


List all products with a GET request to /products.
Read, update, or delete a product with GET, PUT or DELETE request to /products/{product}.

161
AWS Lambda Developer Guide
Getting Started Using SAM Local

Next, copy and paste the following code into the products.js le.

'use strict';

exports.handler = (event, context, callback) => {

let id = event.pathParameters.product || false;


switch(event.httpMethod){

case "GET":

if(id) {
callback(null, {body: "This is a READ operation on product ID " + id});
return;
}

callback(null, {body: "This is a LIST operation, return all products"});


break;

case "POST":
callback(null, {body: "This is a CREATE operation"});
break;

case "PUT":
callback(null, {body: "This is an UPDATE operation on product ID " + id});
break;

case "DELETE":
callback(null, {body:"This is a DELETE operation on product ID " + id});
break;

default:
// Send HTTP 501: Not Implemented
console.log("Error: unsupported HTTP method (" + event.httpMethod + ")");
callback(null, { statusCode: 501 })

Start a local copy of your API operations by calling the start-api command.

$ sam local start-api

2017/05/18 14:03:01 Successfully parsed template.yaml (AWS::Serverless-2016-10-31)


2017/05/18 14:03:01 Found 1 AWS::Serverless::Function
2017/05/18 14:03:01 Mounting products.handler (nodejs6.10) at /products [POST]
2017/05/18 14:03:01 Mounting products.handler (nodejs6.10) at /products/{product} [OPTIONS
GET HEAD POST PUT DELETE TRACE CONNECT]
2017/05/18 14:03:01 Mounting products.handler (nodejs6.10) at /products [GET]
2017/05/18 14:03:01 Listening on http://localhost:3000

You can now browse to the above endpoints to invoke your functions.
You do not need to restart/reload while working on your functions,
changes will be reflected instantly/automatically. You only need to restart
if you update your AWS SAM template.

You can then test your API endpoint locally using either a browser or the CLI.

$ curl http://localhost:3000/products
"This is a LIST operation, return all products"

$ curl -XDELETE http://localhost:3000/products/1

162
AWS Lambda Developer Guide
Getting Started Using SAM Local

"This is a DELETE operation on product ID 1"

To see more samples, see aws sam local/samples.

Local Logging
Using the invoke and start-api commands, you can pipe logs from your Lambda function's invocation
into a le. This approach is useful if you run automated tests against SAM Local and want to capture logs
for analysis. The following is an example.

$ sam local invoke --log-file ./output.log

Using an Environment Variables File


If your Lambda function uses Environment Variables (p. 92), SAM Local provides an --env-vars
argument for both the invoke and start-api commands. With this argument, you can use a JSON le
that contains values for environment variables dened in your function. The JSON le's structure should
be similar to the following.

{
"MyFunction1": {
"TABLE_NAME": "localtable",
"BUCKET_NAME": "testBucket"
},
"MyFunction2": {
"TABLE_NAME": "localtable",
"STAGE": "dev"
},
}

You then access the JSON le using the following command:

$ sam local start-api --env-vars env.json

Using a Shell Environment


Variables dened in your shell environment are passed to the Docker container if they map to a variable
in your Lambda function. Shell variables are globally accessible to functions. For example, suppose
you have two functions, MyFunction1 and MyFunction2, which have a variable called TABLE_NAME. In
this case, the value for TABLE_NAME provided through your shell's environment is available to both
functions.

The following command sets the value of TABLE_NAME to myTable for both functions.

$ TABLE_NAME=mytable sam local start-api

Note
For greater exibility, you can use a combination of shell variables and an external JSON le
that holds environment variables. If a variable is dened in both places, the one from the
external le override the shell version. Following is the order of priority, highest to lowest:

Environment variable le
Shell environment

163
AWS Lambda Developer Guide
Troubleshooting Lambda-Based Applications

Hard-coded values contained in the SAM template

Debugging With SAM Local


Both sam local invoke and sam local start-api support local debugging of your functions. To run
SAM Local with debugging support enabled, specify --debug-port or -d on the command line.

# Invoke a function locally in debug mode on port 5858


$ sam local invoke -d 5858 function logical id

# Start local API Gateway in debug mode on port 5858


$ sam local start-api -d 5858

Note
If you use sam local start-api, the local API Gateway exposes all of your Lambda functions.
But because you can specify only one debug port, you can only debug one function at a time.

Debugging Functions Written in Python


Unlike Node.js or Java, Python requires you to enable remote debugging in your Lambda function code.
If you enable debugging (using the --debug-port or -d options mentioned above) for a function that
uses one of the Python runtimes (2.7 or 3.6), SAM Local maps through that port from your host machine
to the Lambda container. To enable remote debugging, use a Python package such as remote-pdb.
Important
When conguring the host, the debugger listens in on your code, so make sure to use 0.0.0.0
and not 127.0.0.1.

Troubleshooting Lambda-Based Applications


A typical Lambda-based application consists of one or more functions triggered by events such as object
uploads to Amazon S3, Amazon SNS notications, and API actions. Once triggered, those functions
usually call downstream resources such as DynamoDB tables or Amazon S3 buckets, or make other
API calls. AWS Lambda leverages Amazon CloudWatch to automatically emit metrics and logs for all
invocations of your function. However, this mechanism might not be convenient for tracing the event
source that invoked your Lambda function, or for tracing downstream calls that your function made. For
a complete overview of how tracing works, see AWS X-Ray.

Tracing Lambda-Based Applications with AWS X-Ray


AWS X-Ray is an AWS service that allows you to detect, analyze, and optimize performance issues with
your AWS Lambda applications. X-Ray collects metadata from the Lambda service and any upstream or
downstream services that make up your application. X-Ray uses this metadata to generate a detailed
service graph that illustrates performance bottlenecks, latency spikes, and other issues that impact the
performance of your Lambda application.

After using the Lambda on the AWS X-Ray Service Map (p. 166)to identify a problematic resource or
component, you can zoom in and view a visual representation of the request. This visual representation
covers the time from when an event source triggers a Lambda function until the function execution has
completed. X-Ray provides you with a breakdown of your function's operations, such as information
regarding downstream calls your Lambda function made to other services. In addition, X-Ray integration
with Lambda provides you with visibility into the AWS Lambda service overhead. It does so by displaying
specics such as your request's dwell time and number of invocations.

164
AWS Lambda Developer Guide
Setting Up AWS X-Ray with Lambda

Note
Only services that currently integrate with X-Ray show as standalone traces, outside of your
Lambda trace. For a list of services that currently support X-Ray, see Integrating AWS X-Ray with
Other AWS Services.

Setting Up AWS X-Ray with Lambda


Following, you can nd detailed information on how to set up X-Ray with Lambda.

Before You Begin


To enable tracing on your Lambda function using the Lambda CLI, you must rst add tracing permissions
to your function's execution role. To do so, take the following steps:

Sign in to the AWS Management Console and open the IAM console at https://
console.aws.amazon.com/iam/.
Find the execution role for your Lambda function.
Attach the following managed policy: AWSXrayWriteOnlyAccess

To learn more about these policies, see AWS X-Ray.

If you are changing the tracing mode to active using the Lambda console, tracing permissions are added
automatically, as explained in the next section.

Tracing
The path of a request through your application is tracked with a trace ID. A trace collects all of the
segments generated by a single request, typically an HTTP GET or POST request.

There are two modes of tracing for a Lambda function:

Pass Through: This is the default setting for all Lambda functions if you have added tracing
permissions to your function's execution role. This approach means the Lambda function is only traced
if X-Ray has been enabled on an upstream service, such as AWS Elastic Beanstalk.
Active: When a Lambda function has this setting, Lambda automatically samples invocation requests,
based on the sampling algorithm specied by X-Ray.
Note
X-Ray applies a sampling algorithm to ensure that tracing is ecient, while still providing
a representative sample of the requests that your application serves. The default sampling
algorithm is 1 request per minute, with 5 percent of requests sampled past that limit.
However, if the trac volume to your function is low, you may see an increased rate of
sampling.

You can change the tracing mode for your Lambda function by using either the Lambda Management
Console or the Lambda CreateFunction (p. 366) or UpdateFunctionConguration (p. 446) API actions.

If you use the Lambda console, the following applies:

When you change a function's tracing mode to active, tracing permissions are automatically
attached to the function's execution role. If you receive an error stating Lambda couldn't add the
AWSXrayWriteOnlyAccess policy to your function's execution role, sign in to the IAM console at
https://console.aws.amazon.com/iam/ and manually add the policy.
To enable active tracing, go to the Advanced settings section under Congure function and select the
Enable active tracing box.

165
AWS Lambda Developer Guide
Lambda on the AWS X-Ray Service Map

If you use the Lambda CreateFunction (p. 366) or UpdateFunctionConguration (p. 446) API actions:

If you want the tracing mode to be active, set the TracingConfig parameter's Mode property to
Active. Again, any new function has its tracing mode set to PassThrough by default.
Any new or updated Lambda function has its $LATEST version set to the value you specify.
Note
You receive an error if you haven't added tracing permissions to your function's execution role.
For more information, see Before You Begin (p. 165).

Lambda on the AWS X-Ray Service Map


X-Ray displays three types of nodes on the service map for requests served by Lambda:

Lambda service (AWS::Lambda) This type of node represents the time the request spent in the
Lambda service. Timing starts when Lambda rst receives the request and ends when the request
leaves the Lambda service.
Lambda function (AWS::Lambda::Function) This type of node represents the Lambda function's
execution time.

166
AWS Lambda Developer Guide
Lambda as an AWS X-Ray Trace

Downstream service calls In this type, each downstream service call from within the Lambda
function is represented by a separate node.

In the diagram following, the nodes represent (from left to right): The Lambda service, the user function,
and a downstream call to Amazon S3:

For more information, see Viewing the Service Map.

Lambda as an AWS X-Ray Trace


From the service map, you can zoom in to see a trace view of your Lambda function. The trace will
display in-depth information regarding your function invocations, represented as segments and
subsegments:

Lambda service segment This segment represents dierent information depending on the event
source used to invoke the function:
Synchronous and stream event sources The service segment measures the time from when the
Lambda service receives the request/event and ends when the request leaves the Lambda service
(after the nal invocation for the request is completed).
Asynchronous - The service segment represents the response time, that is, the time it took the
Lambda service to return a 202 response to the client.

The Lambda service segment can include two types of subsegments:


Dwell time (asynchronous invocations only) Represents the time the function spends in the
Lambda service before being invoked. This subsegment starts when the Lambda service receives the
request/event and ends when the Lambda function is invoked for the rst time.
Attempt Represents a single invocation attempt, including any overhead introduced by the
Lambda service. Examples of overhead are time spent initializing the function's code and function
execution time.
Lambda function segment - Represents execution time for the function for a given invocation
attempt. It starts when the function handler starts executing and ends when the function terminates.
This segment can include three types of subsegments:
Initialization - The time spent running the initialization code of the function, dened as the
code outside the Lambda function handler or static initializers.
Downstream calls - Calls made to other AWS services from the Lambda function's code.
Custom subsegments - Custom subsegments or user annotations that you can add to the Lambda
function segment by using the X-Ray SDK.

Note
For each traced invocation, Lambda emits the Lambda service segment and all of its
subsegments. These segments are emitted regardless of the runtime and require no code
changes.

167
AWS Lambda Developer Guide
Emitting Trace Segments from a Lambda Function

Emitting Trace Segments from a Lambda Function


For each traced invocation, Lambda will emit the Lambda service segment and all of its subsegments.
In addition, Lambda will emit the Lambda function segment and the init subsegment. These segments
will be emitted regardless of the function's runtime, and with no code changes or additional libraries
required. If you want your Lambda function's X-Ray traces to include custom segments, annotations, or
subsegments for downstream calls, you might need to include additional libraries and annotate your
code. Note that any instrumentation must be implemented inside the Lambda function handler and not
as part of the initialization code. You can only annotate subsegments that you create, and not the root
Lambda function segment.
Note
Currently, these additional capabilities (custom segments, annotations, and subsegments
for downstream calls) are available for the Node.js, Python and Java runtimes. Note that any
instrumentation must be implemented inside the Lambda function handler and not as part of
the initialization code.

Node.js
In Node.js, you can have Lambda emit subsegments to X-Ray to show you information about
downstream calls to other AWS services made by your function. To do so, you rst need to include the
the AWS X-Ray SDK for Node.js in your deployment package. In addition, wrap your AWS SDK require
statement in the following manner:

var AWSXRay = require('aws-xray-sdk-core');


var AWS = AWSXRay.captureAWS(require('aws-sdk'));

Then, use the AWS variable dened in the preceding example to initialize any service client that you want
to trace with X-Ray, for example:

s3Client = AWS.S3();

After following these steps, any call made from your function using s3Client results in an X-Ray
subsegment that represents that call. As an example, you can run the Node.js function following to see
how the trace looks in X-Ray:

var AWSXRay = require('aws-xray-sdk-core');


var AWS = AWSXRay.captureAWS(require('aws-sdk'));

s3 = new AWS.S3({signatureVersion: 'v4'});

exports.handler = (event, context, callback) => {

var params = {Bucket: BUCKET_NAME, Key: BUCKET_KEY, Body: BODY};

s3.putObject(params, function(err, data) {


if (err)
{ console.log(err) }
else {
console.log('success!')
}
});
};

Following is what a trace emitted by the code preceding looks like (synchronous invocation):

168
AWS Lambda Developer Guide
Emitting Trace Segments from a Lambda Function

Java
In Java, you can have Lambda emit subsegments to X-Ray to show you information regarding
downstream calls to other AWS services made by your function. To take advantage of this capability,
include the AWS X-Ray SDK for Java in your deployment package. No code changes are needed. As long
as you are using an AWS SDK version 1.11.48 and preceding, there is no need to add any additional code
lines for downstream calls from your function to be traced.

The AWS SDK will dynamically import the X-Ray SDK to emit subsegments for downstream calls made
by your function. By using the X-Ray SDK for Java, you can instrument your code in order to emit custom
subsegments and or add annotatations to your X-Ray segments.

The following example uses the X-Ray SDK for Java to instrument a Lambda function to emit a custom
subsegment and send custom annotation to X-Ray:

package uptime;

import java.io.IOException;
import java.time.Instant;
import java.util.HashMap;
import java.util.Map;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.apache.http.HttpResponse;
import org.apache.http.client.HttpClient;
import org.apache.http.client.methods.HttpGet;

import com.amazonaws.regions.Regions;
import com.amazonaws.services.dynamodbv2.AmazonDynamoDB;
import com.amazonaws.services.dynamodbv2.AmazonDynamoDBClientBuilder;
import com.amazonaws.services.dynamodbv2.model.AttributeValue;

169
AWS Lambda Developer Guide
Emitting Trace Segments from a Lambda Function

import com.amazonaws.services.lambda.runtime.Context;
import com.amazonaws.xray.AWSXRay;
import com.amazonaws.xray.proxies.apache.http.HttpClientBuilder;

public class Hello {


private static final Log logger = LogFactory.getLog(Hello.class);

private static final AmazonDynamoDB dynamoClient;


private static final HttpClient httpClient;

static {
dynamoClient =
AmazonDynamoDBClientBuilder.standard().withRegion(Regions.US_EAST_1).build();
httpClient = HttpClientBuilder.create().build();
}
public void checkUptime(Context context) {
AWSXRay.createSubsegment("makeRequest", (subsegment) -> {

HttpGet request = new HttpGet("https://aws.amazon.com/");


boolean is2xx = false;

try {
HttpResponse response = httpClient.execute(request);
is2xx = (response.getStatusLine().getStatusCode() / 100) == 2;
subsegment.putAnnotation("responseCode",
response.getStatusLine().getStatusCode());
} catch (IOException ioe) {
logger.error(ioe);
}
Map<String, AttributeValue> item = new HashMap<>();
item.put("Timestamp", new AttributeValue().withN("" +
Instant.now().getEpochSecond()));
item.put("2xx", new AttributeValue().withBOOL(is2xx));
dynamoClient.putItem("amazon-2xx", item);
});
}
}

Following is what a trace emitted by the code preceding looks like (synchronous invocation):

Python
In Python, you can have Lambda emit subsegments to X-Ray to show you information about downstream
calls to other AWS services made by your function. To do so, you rst need to include the the AWS X-Ray

170
AWS Lambda Developer Guide
Emitting Trace Segments from a Lambda Function

SDK for Python in your deployment package. In addition, you can patch the boto3 (or botocore if you are
using sessions), so any client you create to access other AWS services will automatically be traced by X-
Ray.

import boto3
from aws_xray_sdk.core import xray_recorder
from aws_xray_sdk.core import patch

patch(['boto3'])

Once you've patched the module you are using to create clients, you can use it to create your traced
clients, in the case below Amazon S3:

s3_client = boto3.client('s3')

The X-Ray SDK for Python creates a subsegment for the call and records information from
the request and response. You can use the aws_xray_sdk_sdk.core.xray_recorder to create
subsegments automatically by decorating your Lambda functions or manually by calling
xray_recorder.begin_subsegment() and xray_recorder.end_subsegment() inside the function, as
shown in the following Lambda function.

import boto3
from aws_xray_sdk.core import xray_recorder
from aws_xray_sdk.core import patch

patch(['boto3'])

s3_client = boto3.client('s3')

def lambda_handler(event, context):


bucket_name = event['bucket_name']
bucket_key = event['bucket_key']
body = event['body']

put_object_into_s3(bucket_name, bucket_key, body)


get_object_from_s3(bucket_name, bucket_key)

# Define subsegments manually


def put_object_into_s3(bucket_name, bucket_key, body):
try:
xray_recorder.begin_subsegment('put_object')
response = s3_client.put_object(Bucket=bucket_name, Key=bucket_key, Body=body)
status_code = response['ResponseMetadata']['HTTPStatusCode']
xray_recorder.current_subsegment().put_annotation('put_response', status_code)
finally:
xray_recorder.end_subsegment()

# Use decorators to automatically set the subsegments


@xray_recorder.capture('get_object')
def get_object_from_s3(bucket_name, bucket_key):
response = s3_client.get_object(Bucket=bucket_name, Key=bucket_key)
status_code = response['ResponseMetadata']['HTTPStatusCode']
xray_recorder.current_subsegment().put_annotation('get_response', status_code)

Note
The X-Ray SDK for Python allows you to patch the following modules:

botocore

171
AWS Lambda Developer Guide
The AWS X-Ray Daemon in the Lambda Environment

boto3
requests
sqlite3
mysql

You can use patch_all() to patch all of them at once.

Following is what a trace emitted by the code preceding looks like (synchronous invocation):

The AWS X-Ray Daemon in the Lambda Environment


The AWS X-Ray Daemon is a software application that gathers raw segment data and relays it to the AWS
X-Ray service. The daemon works in conjunction with the AWS X-Ray SDKs so that data sent by the SDKs
can reach the X-Ray service.

When you trace your Lambda function, the X-Ray daemon automatically runs in the Lambda
environment to gather trace data and send it to X-Ray. When tracing, the X-Ray daemon consumes a
maximum of 16 MB or 3 percent of your function's memory allocation. For example, if you allocate
128 MB of memory to your Lambda function, the X-Ray daemon has 16 MB of your function's memory
allocation. If you allocate 1024 MB to your Lambda function, the X-Ray daemon has 31 MB allocated to it
(3 percent). For more information, see The AWS X-Ray Daemon.
Note
Lambda will try to terminate the X-Ray daemon to avoid exceeding your function's memory
limit. For example, assume you have allocated 128 MB to your Lambda function, which means
the X-Ray daemon will have 16 MB allocated to it. That leaves your Lambda function with a
memory allocation of 112 MB. However, if your function exceeds 112 MB, the X-Ray daemon will
be terminated to avoid throwing an out-of-memory error.

172
AWS Lambda Developer Guide
Using Environment Variables to
Communicate with AWS X-Ray

Using Environment Variables to Communicate with


AWS X-Ray
AWS Lambda automatically generates three environment variables to facilitate communication with the
X-Ray daemon, and set the conguration of the X-Ray SDK:

_X_AMZN_TRACE_ID: Contains the tracing header, which includes the sampling decision, trace
ID, and parent segment ID. (To learn more about these properties, see Tracing Header.) If Lambda
receives a tracing header when your function is invoked, that header will be used to populate the
_X_AMZN_TRACE_ID environment variable. If a tracing header was not received, Lambda will generate
one for you.
AWS_XRAY_CONTEXT_MISSING: The X-Ray SDK uses this variable to determine its behavior in the
event that your function tries to record X-Ray data, but a tracing header is not available. Lambda sets
this value to LOG_ERROR by default.
AWS_XRAY_DAEMON_ADDRESS: This environment variable exposes the X-Ray daemon's address in
the following format: IP_ADDRESS:PORT. You can use the X-Ray daemon's address to send trace data to
the X-Ray daemon directly, without using the X-Ray SDK.

Lambda Traces in the AWS X-Ray Console: Examples


The following shows Lambda traces for two dierent Lambda functions. Each trace showcases a trace
structure for a dierent invocation type: asynchronous and synchronous.

Async - The example following shows an asynchronous Lambda request with one successful
invocation and one downstream call to DynamoDB.

The Lambda service segment encapsulates the response time, which is the time it took to return a
response (for example, 202) to the client. It includes subsegments for the time spent in the Lambda
service queue (dwell time) and each invocation attempt. (Only one invocation attempt appears in
the example preceding.) Each attempt subsegment in the service segment will have a corresponding
user function segment. In this example, the user function segment contains two subsegments: the
initialization subsegment representing the function's initialization code that is run before the handler,
and a downstream call subsegment representing a ListTables call to DynamoDB.

Status codes and error messages are displayed for each Invocation subsegment and for each
downstream call.
Synchronous - The example following shows a synchronous request with one downstream call to
Amazon S3.

173
AWS Lambda Developer Guide
Lambda Traces in the AWS X-Ray Console: Examples

The Lambda service segment captures the entire time the request spends in the Lambda service. The
service segment will have a corresponding User function segment. In this example, the User function
segment contains a subsegment representing the function's initialization code (code run before the
handler), and a subsegment representing the PutObject call to Amazon S3.

Note
If you want to trace HTTP calls, you need to use an HTTP client. For more information, see
Tracing Calls to Downstream HTTP Web Services with the X-Ray SDK for Java or Tracing Calls to
Downstream HTTP Web Services with the X-Ray SDK for Node.js .

174
AWS Lambda Developer Guide
How Does AWS Lambda Run
My Code? The Container Model

AWS Lambda: How It Works

How Does AWS Lambda Run My Code? The


Container Model
When AWS Lambda executes your Lambda function on your behalf, it takes care of provisioning and
managing resources needed to run your Lambda function. When you create a Lambda function, you
specify conguration information, such as the amount of memory and maximum execution time that you
want to allow for your Lambda function. When a Lambda function is invoked, AWS Lambda launches a
container (that is, an execution environment) based on the conguration settings you provided.
Note
The content of this section is for information only. AWS Lambda manages container creations
and deletion, there is no AWS Lambda API for you to manage containers.

It takes time to set up a container and do the necessary bootstrapping, which adds some latency each
time the Lambda function is invoked. You typically see this latency when a Lambda function is invoked
for the rst time or after it has been updated because AWS Lambda tries to reuse the container for
subsequent invocations of the Lambda function.

After a Lambda function is executed, AWS Lambda maintains the container for some time in anticipation
of another Lambda function invocation. In eect, the service freezes the container after a Lambda
function completes, and thaws the container for reuse, if AWS Lambda chooses to reuse the container
when the Lambda function is invoked again. This container reuse approach has the following
implications:

Any declarations in your Lambda function code (outside the handler code, see Programming
Model (p. 8)) remains initialized, providing additional optimization when the function is invoked again.
For example, if your Lambda function establishes a database connection, instead of reestablishing the
connection, the original connection is used in subsequent invocations. You can add logic in your code
to check if a connection already exists before creating one.


Each container provides 500MB of additional disk space in the /tmp directory. The directory content
remains when the container is frozen, providing transient cache that can be used for multiple
invocations. You can add extra code to check if the cache has the data that you stored. For information
on deployment limits, see AWS Lambda Limits (p. 317).

175
AWS Lambda Developer Guide
Concurrent Executions


Background processes or callbacks initiated by your Lambda function that did not complete when
the function ended resume if AWS Lambda chooses to reuse the container. You should make sure any
background processes or callbacks (in case of Node.js) in your code are complete before the code exits.

Note
When you write your Lambda function code, do not assume that AWS Lambda always reuses the
container because AWS Lambda may choose not to reuse the container. Depending on various
other factors, AWS Lambda may simply create a new container instead of reusing an existing
container.

Lambda Function Concurrent Executions


Concurrent executions refers to the number of executions of your function code that are happening at
any given time. You can estimate the concurrent execution count, but the concurrent execution count
will dier depending on whether or not your Lambda function is processing events from a stream-based
event source.

Stream-based event sources If you create a Lambda function that processes events from stream-
based services (Amazon Kinesis Streams or DynamoDB streams), the number of shards per stream
is the unit of concurrency. If your stream has 100 active shards, there will be at most 100 Lambda
function invocations running concurrently. Then, each Lambda function processes events on a shard in
the order that they arrive.
Event sources that aren't stream-based If you create a Lambda function to process events from
event sources that aren't stream-based (for example, Amazon S3 or API Gateway), each published
event is a unit of work. Therefore, the number of events (or requests) these event sources publish
inuences the concurrency.

You can use the following formula to estimate your concurrent Lambda function invocations:

events (or requests) per second * function duration

For example, consider a Lambda function that processes Amazon S3 events. Suppose that the Lambda
function takes on average three seconds and Amazon S3 publishes 10 events per second. Then, you
will have 30 concurrent executions of your Lambda function.

Request Rate
Request rate refers to the rate at which your Lambda function is invoked. For all services except the
stream-based services, the request rate is the rate at which the event sources generate the events. For
stream-based services, AWS Lambda calculates the request rate as follow:

request rate = number of concurrent executions / function duration

For example, if there are ve active shards on a stream (that is, you have ve Lambda functions running
in parallel) and your Lambda function takes about two seconds, the request rate is 2.5 requests/second.

Concurrent Execution Limit


By default, AWS Lambda limits the total concurrent executions across all functions within a given region
to 1000. For instructions on how to increase that limit, see the following.

176
AWS Lambda Developer Guide
Scaling

Any invocation that causes your function's concurrent execution to exceed the safety limit is throttled. In
this case, the invocation doesn't execute your function. Each throttled invocation increases the Amazon
CloudWatch Throttles metric for the function.

The throttled invocation is handled dierently based on how your function is invoked:

Event sources that aren't stream-based Some of these event sources invoke a Lambda function
synchronously, and others invoke it asynchronously. Handling is dierent for each:
Synchronous invocation If the function is invoked synchronously and is throttled, the invoking
application receives a 429 error and the invoking application is responsible for retries. These event
sources might have additional retries built into the integration. For example, CloudWatch Logs
retries the failed batch up to ve times with delays between retries. For a list of supported event
sources and the invocation types that they use, see Supported Event Sources (p. 131).

If you invoke Lambda through Amazon API Gateway, make sure that you map Lambda response
errors to API Gateway error codes. If you invoke the function directly, such as through the AWS SDKs
using the RequestResponse invocation mode or through API Gateway, your client receives the 429
error and you can retry the invocation.
Asynchronous invocation If your Lambda function is invoked asynchronously and is throttled,
AWS Lambda automatically retries the throttled event for up to six hours, with delays between
retries. Asynchronous events are queued before they are used to invoke the Lambda function.
Stream-based event sources For stream-based event sources (Amazon Kinesis Streams and Amazon
DynamoDB streams), AWS Lambda polls your stream and invokes your Lambda function. When your
Lambda function is throttled, AWS Lambda attempts to process the throttled batch of records until
the time the data expires. This time period can be up to seven days for Amazon Kinesis Streams. The
throttled request is treated as blocking per shard, and Lambda doesn't read any new records from the
shard until the throttled batch of records either expires or succeeds. If there is more than one shard in
the stream, Lambda continues invoking on the nonthrottled shards until one gets through.

To request a limit increase for concurrent executions

1. Open the AWS Support Center page, sign in if necessary, and then choose Create case.
2. For Regarding, select Service Limit Increase.
3. For Limit Type, choose Lambda, ll in the necessary elds in the form, and then choose the button
at the bottom of the page for your preferred method of contact.

Note
AWS might automatically raise the concurrent execution limit for you so that your function can
match the incoming event rate. An example is the case of when your function is triggered from
an Amazon S3 bucket.

Scaling
AWS Lambda will dynamically scale capacity in response to increased trac, subject to your account's
Concurrent Execution Limit (p. 176). To handle any burst in trac, Lambda will immediately increase
your concurrently executing functions by a predetermined amount, dependent on which region it's
executed (see table below).

If the default Immediate Concurrency Increase value, as noted in the table below, is not sucient to
accommodate the trac surge, Lambda will continue to increase the number of concurrent function
executions by 500 per minute until your account safety limit has been reached or the number of
concurrently executing functions is sucient to successfully process the increased load.
Note
Because Lambda depends on Amazon EC2 to provide Elastic Network Interfaces for VPC-
enabled Lambda functions, these functions are also subject to Amazon EC2's rate limits as

177
AWS Lambda Developer Guide
Retries on Errors

they scale. If your Amazon EC2 rate limits prevent VPC-enabled functions from adding 500
concurrent invocations per minute, please request a limit increase by following the instructions
in the preceding section under To request a limit increase for concurrent executions.
Beyond this rate (i.e. for applications taking advantage of the full Immediate concurrency
increase), your application should handle Amazon EC2 throttling (502 EC2ThrottledException)
through client-side retry and backo. For more details, see Error Retries and Exponential Backo
in AWS.

The table below outlines the immediate concurrency increase per region:

Region Immediate Concurrency Increase


(function executions)

Asia Pacic (Tokyo) 3000

US West (N. California) 3000

US East (N. Virginia) 3000

EU (Ireland) 3000

All other regions 1000

Suggested Reading

If you are new to AWS Lambda, we suggest you read through all of the topics in the How It Works section
to familiarize yourself with Lambda. The next topic is Retries on Errors (p. 178).

After you read all of the topics in the How it Works section, we recommend that you review Building
Lambda Functions (p. 5), try the Getting Started (p. 185) exercise, and then explore the Use
Cases (p. 200). Each use case provides step-by-step instructions for you to set up the end-to-end
experience.

Retries on Errors
A Lambda function can fail for any of the following reasons:

The function times out while trying to reach an endpoint.


The function fails to successfully parse input data.


The function experiences resource constraints, such as out-of-memory errors or other timeouts.

If any of these failures occur, your function will throw an exception. How the exception is handled
depends upon how the Lambda function was invoked:

Event sources that aren't stream-based Some of these event sources are set up to invoke a Lambda
function synchronously and others invoke it asynchronously. Accordingly, exceptions are handled as
follows:

178
AWS Lambda Developer Guide
Permissions Model

Synchronous invocation The invoking application receives a 429 error, and is responsible for
retries. For a list of supported event sources and the invocation types they use, see Supported Event
Sources. These event sources may have additional retries built into the integration.

If you invoked the Lambda function directly through AWS SDKs, or through API Gateway, your client
receives the error and can choose to retry. If you are invoking Lambda through API Gateway, you
need to make sure you map Lambda response errors to API Gateway error codes.


Asynchronous invocation Asynchronous events are queued before being used to invoke the
Lambda function. If AWS Lambda is unable to fully process the event, it will automatically retry the
invocation twice, with delays between retries. If you have specied a Dead Letter Queue for your
function, then the failed event is sent to the specied Amazon SQS queue or Amazon SNS topic. If
you don't specify a Dead Letter Queue (DLQ), which is not required and is the default setting, then
the event will be discarded. For more information, see Dead Letter Queues (p. 121).


Stream-based event sources For stream-based event sources (Amazon Kinesis Streams and
DynamoDB streams), AWS Lambda polls your stream and invokes your Lambda function. Therefore, if
a Lambda function fails, AWS Lambda attempts to process the erring batch of records until the time
the data expires, which can be up to seven days for Amazon Kinesis Streams. The exception is treated
as blocking, and AWS Lambda will not read any new records from the stream until the failed batch of
records either expires or processed successfully. This ensures that AWS Lambda processes the stream
events in order.

For more information about invocation modes, see Event Source Mapping (p. 127).

Suggested Reading

If you are new to AWS Lambda, we suggest you read through all of the topics in the How It Works section
to familiarize yourself with Lambda. The next topic is AWS Lambda Permissions Model (p. 179).

After you read all of the topics in the How it Works section, we recommend that you review Building
Lambda Functions (p. 5), try the Getting Started (p. 185) exercise, and then explore the Use
Cases (p. 200). Each use case provides step-by-step instructions for you to set up the end-to-end
experience.

AWS Lambda Permissions Model


For the end-to-end AWS Lambda-based applications to work, you have to manage various permissions.
For example:

For event sources, except for the stream-based services (Amazon Kinesis Streams and DynamoDB
streams), you must grant the event source permissions to invoke your AWS Lambda function.


For stream-based event sources (Amazon Kinesis Streams and DynamoDB streams), AWS Lambda polls
the streams on your behalf and reads new records on the stream, so you need to grant AWS Lambda
permissions for the relevant stream actions.


When your Lambda function executes, it can access AWS resources in your account (for example,
read an object from your S3 bucket). AWS Lambda executes your Lambda function on your behalf by
assuming the role you provided at the time of creating the Lambda function. Therefore, you need to
grant the role the necessary permissions that your Lambda function needs, such as permissions for
Amazon S3 actions to read an object.

179
AWS Lambda Developer Guide
Manage Permissions: Using an IAM Role (Execution Role)

The following sections describe permissions management.

Topics
Manage Permissions: Using an IAM Role (Execution Role) (p. 180)
Manage Permissions: Using a Lambda Function Policy (p. 181)
Suggested Reading (p. 181)

Manage Permissions: Using an IAM Role (Execution


Role)
Each Lambda function has an IAM role (execution role) associated with it. You specify the IAM role when
you create your Lambda function. Permissions you grant to this role determine what AWS Lambda can
do when it assumes the role. There are two types of permissions that you grant to the IAM role:

If your Lambda function code accesses other AWS resources, such as to read an object from an S3
bucket or write logs to CloudWatch Logs, you need to grant permissions for relevant Amazon S3 and
CloudWatch actions to the role.


If the event source is stream-based (Amazon Kinesis Streams and DynamoDB streams), AWS Lambda
polls these streams on your behalf. AWS Lambda needs permissions to poll the stream and read new
records on the stream so you need to grant the relevant permissions to this role.

For more information about IAM roles, see Roles (Delegation and Federation) in the IAM User Guide.
Important
The user that creates the IAM role is, in eect, passing permissions to AWS Lambda to
assume this role, which requires the user to have permissions for the iam:PassRole action.
If an administrator user is creating this role, you don't need to do anything extra to set up
permissions for the iam:PassRole action because the administrator user has full permissions,
including the iam:PassRole action.

To simplify the process for creating an execution role, AWS Lambda provides the following AWS
managed (predened) permissions policies that you can use. These policies include common permissions
for specic scenarios:

AWSLambdaBasicExecutionRole Grants permissions only for the Amazon CloudWatch Logs actions
to write logs. You can use this policy if your Lambda function does not access any other AWS resources
except writing logs.


AWSLambdaKinesisExecutionRole Grants permissions for Amazon Kinesis Streams actions, and
CloudWatch Logs actions. If you are writing a Lambda function to process Kinesis stream events you
can attach this permissions policy.


AWSLambdaDynamoDBExecutionRole Grants permissions for DynamoDB streams actions and
CloudWatch Logs actions. If you are writing a Lambda function to process DynamoDB stream events
you can attach this permissions policy.


AWSLambdaVPCAccessExecutionRole Grants permissions for Amazon Elastic Compute Cloud
(Amazon EC2) actions to manage elastic network interfaces (ENIs). If you are writing a Lambda
function to access resources in a VPC in the Amazon Virtual Private Cloud (Amazon VPC) service, you

180
AWS Lambda Developer Guide
Manage Permissions: Using a Lambda Function Policy

can attach this permissions policy. The policy also grants permissions for CloudWatch Logs actions to
write logs.

You can nd these AWS managed permissions policies in the IAM console. Search for these policies and
you can see the permissions each of these policies grant.

Manage Permissions: Using a Lambda Function Policy


All supported event sources, except the stream-based services (Kinesis and DynamoDB streams), invoke
your Lambda function (the push model), provided that you grant the necessary permissions. For example,
if you want Amazon S3 to invoke your Lambda function when objects are created in a bucket, Amazon S3
needs permissions to invoke your Lambda function.

You can grant these permissions via the function policies. AWS Lambda provides APIs for you to manage
permission in a function policy. For example, see AddPermission (p. 354).

You can also grant cross-account permissions using the function policy. For example, if a user-dened
application and the Lambda function it invokes belong to the same AWS account, you don't need to
grant explicit permissions. Otherwise, the AWS account that owns the Lambda function must allow cross-
account permissions in the permissions policy associated with the Lambda function.

Note
Instead of using a Lambda function policy, you can create another IAM role that grants the event
sources (for example, Amazon S3 or DynamoDB) permissions to invoke your Lambda function.
However, you might nd that resource policies are easier to set up and they make it easier for
you to track which event sources have permissions to invoke your Lambda function.

For more information about Lambda function policies, see Using Resource-Based Policies for AWS
Lambda (Lambda Function Policies) (p. 338). For more information about Lambda permissions, see
Authentication and Access Control for AWS Lambda (p. 320).

Suggested Reading
If you are new to AWS Lambda, we suggest you read through all of the topics in the How It Works section
to familiarize yourself with Lambda. The next topic is Lambda Execution Environment and Available
Libraries (p. 182).

After you read all of the topics in the How it Works section, we recommend that you review Building
Lambda Functions (p. 5), try the Getting Started (p. 185) exercise, and then explore the Use
Cases (p. 200). Each use case provides step-by-step instructions for you to set up the end-to-end
experience.

181
AWS Lambda Developer Guide
Execution Environment

Lambda Execution Environment and Available


Libraries
The underlying AWS Lambda execution environment is based on the following:

Public Amazon Linux AMI version (AMI name: amzn-ami-hvm-2016.03.3.x86_64-gp2) which can be
accessed here.

For information about using an AMI, see Amazon Machine Images (AMI) in the Amazon EC2 User Guide
for Linux Instances.
Linux kernel version 4.4.51-40.60.amzn1.x86_64

If you are using any native binaries in your code, make sure they are compiled in this environment. Note
that only 64-bit binaries are supported on AWS Lambda.

AWS Lambda supports the following runtime versions:

Node.js v4.3.2 and 6.10.3


Java Java 8
Python Python 3.6 and 2.7
.NET Core .NET Core 1.0.1 (C#)

Note
Not all runtimes are available on the Public Amazon Linux AMI version or its yum repositories.
You may need to download and install them manually from their respective public sites.

The following libraries are available in the AWS Lambda execution environment, regardless of the
supported runtime you use, so you don't need to include them:

AWS SDK AWS SDK for JavaScript version 2.92.0


AWS SDK for Python 2.7 (Boto 3) version 3-1.4.4 botocore-1.5.89

AWS SDK for Python 3.6 (Boto 3) version 3-1.4.4 botocore-1.5.89


Amazon Linux build of java-1.8.0-openjdk for Java.

Environment Variables Available to Lambda


Functions
The following is a list of environment variables that are part of the AWS Lambda execution environment
and made available to Lambda functions. The table below indicates which ones are reserved by AWS
Lambda and cannot be changed as well as which ones you can set when creating your Lambda function.
For more information on using environment variables with your Lambda function, see Environment
Variables (p. 92).

Lambda Environment Variables

Key Reserved Value

LAMBDA_TASK_ROOT Yes Contains the path to your Lambda


function code.

182
AWS Lambda Developer Guide
Environment Variables Available to Lambda Functions

Key Reserved Value

AWS_EXECUTION_ENV Yes The environment variable is set


to one of the following options,
depending on the runtime of the
Lambda function:

AWS_Lambda_java8
AWS_Lambda_nodejs
AWS_Lambda_nodejs4.3
AWS_Lambda_nodejs6.10
AWS_Lambda_python2.7
AWS_Lambda_python3.6
AWS_Lambda_dotnetcore1.0

LAMBDA_RUNTIME_DIR Yes Restricted to Lambda runtime-


related artifacts. For example the
aws-sdk for Node.js and boto3 for
Python can be found under this path.

AWS_REGION Yes The AWS region where the Lambda


function is executed.

AWS_DEFAULT_REGION Yes The AWS region where the Lambda


function is executed.

AWS_LAMBDA_LOG_GROUP_NAME Yes The name of Amazon CloudWatch


Logs group where log streams
containing your Lambda function
logs are created.

AWS_LAMBDA_LOG_STREAM_NAME Yes The Amazon CloudWatch Logs


streams containing your Lambda
function logs.

AWS_LAMBDA_FUNCTION_NAME Yes The name of the Lambda function.

AWS_LAMBDA_FUNCTION_MEMORY_SIZE
Yes The size of the Lambda function in
MB.

AWS_LAMBDA_FUNCTION_VERSION Yes The version of the Lambda function.

AWS_ACCESS_KEY Yes The security credentials required


to execute the Lambda function,
AWS_ACCESS_KEY_ID depending on which runtime is used.
Dierent runtimes use a subset of
AWS_SECRET_KEY these keys. They are generated via an
IAM execution role specied for the
AWS_SECRET_ACCESS_KEY
function.
AWS_SESSION_TOKEN

AWS_SECURITY_TOKEN

PATH No Contains /usr/local/bin, /usr/bin or /


bin for running executables.

183
AWS Lambda Developer Guide
Suggested Reading

Key Reserved Value

LANG No Set to en_US.UTF-8. This is the


Locale of the runtime.

LD_LIBRARY_PATH No Contains /lib64, /usr/lib64,


LAMBDA_TASK_ROOT,
LAMBDA_TASK_ROOT/lib. Used to
store helper libraries and function
code.

NODE_PATH No Set for the Node.js runtime. It


contains LAMBDA_RUNTIME_DIR,
LAMBDA_RUNTIME_DIR/
node_modules,
LAMBDA_TASK_ROOT.

PYTHONPATH No Set for the Python runtime. It


contains LAMBDA_RUNTIME_DIR.

TZ Yes The current local time. Defaults to


UTC.

Suggested Reading
If you are new to AWS Lambda, we suggest you read through all of the topics in the How It Works section
to familiarize yourself with Lambda, starting with How It Works (p. 175).

After you read all of the topics in the How it Works section, we recommend that you review Building
Lambda Functions (p. 5), try the Getting Started (p. 185) exercise, and then explore the Use
Cases (p. 200). Each use case provides step-by-step instructions for you to set up the end-to-end
experience.

184
AWS Lambda Developer Guide
Step 1: Set Up an AWS Account and the AWS CLI

Getting Started

In this Getting Started section, you do the following:

Set up an AWS account and AWS Command Line Interface (AWS CLI). Most tutorials use the AWS CLI
commands.
Create and test a simple Hello World Lambda function.

To get started, complete the steps in the following topics:

Topics
Step 1: Set Up an AWS Account and the AWS CLI (p. 185)
Step 2: Create a HelloWorld Lambda Function and Explore the Console (p. 188)
Step 3: Create a Simple Microservice using Lambda and API Gateway (p. 197)

Step 1: Set Up an AWS Account and the AWS CLI


If you have not already done so, you need to sign up for an AWS account and create an administrator
user in the account. You also need to set up the AWS Command Line Interface (AWS CLI). Many of the
tutorials use the AWS CLI.

To complete the setup, follow the instructions in the following topics:

Topics
Step 1.1: Set Up an AWS Account and Create an Administrator User (p. 185)
Step 1.2: Set Up the AWS Command Line Interface (AWS CLI) (p. 188)

Step 1.1: Set Up an AWS Account and Create an


Administrator User
Before you use AWS Lambda for the rst time, complete the following tasks:

1. Sign up for AWS (p. 186)


2. Create an IAM User (p. 186)

185
AWS Lambda Developer Guide
Step 1.1: Set Up an Account

Sign up for AWS


When you sign up for Amazon Web Services (AWS), your AWS account is automatically signed up for all
services in AWS, including AWS Lambda. You are charged only for the services that you use.

With AWS Lambda, you pay only for the resources you use. For more information about AWS Lambda
usage rates, see the AWS Lambda product page. If you are a new AWS customer, you can get started with
AWS Lambda for free. For more information, see AWS Free Usage Tier.

If you already have an AWS account, skip to the next task. If you don't have an AWS account, use the
following procedure to create one.

To create an AWS account

1. Open https://aws.amazon.com/, and then choose Create an AWS Account.


2. Follow the online instructions.

Part of the sign-up procedure involves receiving a phone call and entering a PIN using the phone
keypad.

Note your AWS account ID, because you'll need it for the next task.

Create an IAM User


Services in AWS, such as AWS Lambda, require that you provide credentials when you access them,
so that the service can determine whether you have permissions to access the resources owned by
that service. The console requires your password. You can create access keys for your AWS account to
access the AWS CLI or API. However, we don't recommend that you access AWS using the credentials
for your AWS account. Instead, we recommend that you use AWS Identity and Access Management
(IAM). Create an IAM user, add the user to an IAM group with administrative permissions, and then grant
administrative permissions to the IAM user that you created. You can then access AWS using a special
URL and that IAM user's credentials.

If you signed up for AWS, but you haven't created an IAM user for yourself, you can create one using the
IAM console.

The Getting Started exercises and tutorials in this guide assume you have a user (adminuser) with
administrator privileges. When you follow the procedure, create a user with name adminuser.

To create an IAM user for yourself and add the user to an Administrators group

1. Sign in to the AWS Management Console and open the IAM console at https://
console.aws.amazon.com/iam/.
2. In the navigation pane, choose Users, and then choose Add user.
3. For User name, type a user name, such as Administrator. The name can consist of letters, digits,
and the following characters: plus (+), equal (=), comma (,), period (.), at (@), underscore (_), and
hyphen (-). The name is not case sensitive and can be a maximum of 64 characters in length.
4. Select the check box next to AWS Management Console access, select Custom password, and then
type the new user's password in the text box. You can optionally select Require password reset to
force the user to select a new password the next time the user signs in.
5. Choose Next: Permissions.
6. On the Set permissions for user page, choose Add user to group.
7. Choose Create group.
8. In the Create group dialog box, type the name for the new group. The name can consist of letters,
digits, and the following characters: plus (+), equal (=), comma (,), period (.), at (@), underscore (_),
and hyphen (-). The name is not case sensitive and can be a maximum of 128 characters in length.

186
AWS Lambda Developer Guide
Step 1.1: Set Up an Account

9. For Filter, choose Job function.


10. In the policy list, select the check box for AdministratorAccess. Then choose Create group.
11. Back in the list of groups, select the check box for your new group. Choose Refresh if necessary to
see the group in the list.
12. Choose Next: Review to see the list of group memberships to be added to the new user. When you
are ready to proceed, choose Create user.

You can use this same process to create more groups and users, and to give your users access to your
AWS account resources. To learn about using policies to restrict users' permissions to specic AWS
resources, go to Access Management and Example Policies for Administering AWS Resources.

To sign in as the new IAM user

1. Sign out of the AWS Management Console.


2. Use the following URL format to log in to the console:

https://aws_account_number.signin.aws.amazon.com/console/

The aws_account_number is your AWS account ID without hyphen. For example, if your AWS account
ID is 1234-5678-9012, your AWS account number is 123456789012. For information about how to nd
your account number, see Your AWS Account ID and Its Alias in the IAM User Guide.
3. Enter the IAM user name and password that you just created. When you're signed in, the navigation
bar displays your_user_name @ your_aws_account_id.

If you don't want the URL for your sign-in page to contain your AWS account ID, you can create an
account alias.

To create or remove an account alias

1. Sign in to the AWS Management Console and open the IAM console at https://
console.aws.amazon.com/iam/.
2. On the navigation pane, choose Dashboard.
3. Find the IAM users sign-in link.
4. To create the alias, click Customize, enter the name you want to use for your alias, and then choose
Yes, Create.
5. To remove the alias, choose Customize, and then choose Yes, Delete. The sign-in URL reverts to
using your AWS account ID.

To sign in after you create an account alias, use the following URL:

https://your_account_alias.signin.aws.amazon.com/console/

To verify the sign-in link for IAM users for your account, open the IAM console and check under IAM
users sign-in link: on the dashboard.

For more information about IAM, see the following:

Identity and Access Management (IAM)


Getting Started
IAM User Guide

187
AWS Lambda Developer Guide
Step 1.2: Set Up the AWS CLI

Next Step
Step 1.2: Set Up the AWS Command Line Interface (AWS CLI) (p. 188)

Step 1.2: Set Up the AWS Command Line Interface


(AWS CLI)
All the exercises in this guide assume that you are using administrator user credentials (adminuser) in
your account to perform the operations. For instructions on creating an administrator user in your AWS
account, see Step 1.1: Set Up an AWS Account and Create an Administrator User (p. 185), and then
follow the steps to download and congure the AWS Command Line Interface (AWS CLI).

To set up the AWS CLI

1. Download and congure the AWS CLI. For instructions, see the following topics in the AWS
Command Line Interface User Guide.

Getting Set Up with the AWS Command Line Interface


Conguring the AWS Command Line Interface
2. Add a named prole for the administrator user in the AWS CLI cong le. You use this prole when
executing the AWS CLI commands.

[profile adminuser]
aws_access_key_id = adminuser access key ID
aws_secret_access_key = adminuser secret access key
region = aws-region

For a list of available AWS regions, see Regions and Endpoints in the Amazon Web Services General
Reference.
3. Verify the setup by entering the following commands at the command prompt.

Try the help command to verify that the AWS CLI is installed on your computer:

aws help

Try a Lambda command to verify the user can reach AWS Lambda. This command lists Lambda
functions in the account, if any. The AWS CLI uses the adminuser credentials to authenticate the
request.

aws lambda list-functions --profile adminuser

Now that you have set up an account and AWS CLI, you can create your rst Lambda function. For
instructions, see Step 2: Create a HelloWorld Lambda Function and Explore the Console (p. 188).

Step 2: Create a HelloWorld Lambda Function and


Explore the Console
In this Getting Started exercise you rst create a Hello World Lambda function using the AWS Lambda
console. Next, you manually invoke the Lambda function using sample event data. AWS Lambda

188
AWS Lambda Developer Guide
Preparing for the Getting Started

executes the Lambda function and returns results. You then verify execution results, including the logs
that your Lambda function created and various CloudWatch metrics.

As you follow the steps, you will also familiarize yourself with the AWS Lambda console including:

Explore the blueprints. Each blueprint provides sample code and sample congurations that enable
you to create Lambda functions with just a few clicks. The Getting Started exercise uses the hello-
world-python blueprint.
View and update conguration information of your Lambda function.
Invoke a Lambda function manually and explore results in the Execution results section.
Monitor CloudWatch metrics in the console.

Although not required, we recommend you review How It Works (p. 175) rst.

Preparing for the Getting Started


First, you need to sign up for an AWS account and create an administrator user in your account. For
instructions, see Step 1: Set Up an AWS Account and the AWS CLI (p. 185).

Next Step

Step 2.1: Create a Hello World Lambda Function (p. 189)

Step 2.1: Create a Hello World Lambda Function


Follow the steps in this section to create a Hello World Lambda function. In this step, you will do the
following:

Select a blueprint For this exercise, you use the hello-world-python blueprint. It provides sample
code authored in Python. The language used for the Lambda function does not matter for this
exercise. Later you can create your own Lambda functions in any of the supported languages.

Blueprints provide example code to do some minimal processing. Most blueprints process events from
specic event sources, such as Amazon S3, DynamoDB, or custom application. For example, if you
select an s3-get-object blueprint, it provides sample code that processes an object-created event
published by Amazon S3 that Lambda receives as parameter.
Congure function Because you select a blueprint for this exercise, the console will have some
of the conguration information prepopulated. For example, it precongures either Python 3.6 or
Python 2.7 as the runtime, provides example code, identies the handler in the code sample, and
other conguration information such as memory and timeout. For more information about conguring
functions, see Lambda Functions (p. 3). For more information about the function conguration
parameters, see CreateFunction (p. 366).

You will also create an IAM role (referred as the execution role) with the necessary permissions that
AWS Lambda can assume to invoke your Lambda function on your behalf.

To create a Hello World Lambda function

1. Sign in to the AWS Management Console and open the AWS Lambda console.
2. Choose Get Started Now.

189
AWS Lambda Developer Guide
Step 2.1: Create a Hello World Lambda Function

Note
The console shows the Get Started Now page only if you do not have any Lambda
functions created. If you have created functions already, you will see the Lambda >
Functions page. On the list page, choose Create a Lambda function to go to the Lambda >
New function page.
3. On the Select blueprint page, rst explore the available blueprints. Then, select a specic blueprint
for this Getting Started exercise.

a. Review the blueprints. You can also use the Filter to search for specic blueprints. For example:

Enter S3 in Filter to get only the list of blueprints available to process Amazon S3 events.
Enter dynamodb in Filter to get a list of available blueprints to process Amazon DynamoDB
events.
b. For this Getting Started exercise, enter hello-world-python in Filter, and then choose the
hello-world-python blueprint.
4. On the Congure triggers page, you can optionally choose a service that automatically triggers your
Lambda function by choosing the gray box with ellipses (...) to display a list of available services.

a. Depending on which service you select, you are prompted to provide relevant information for
that service. For example, if you select DynamoDB, you need to provide the following:

The name of the DynamoDB table

190
AWS Lambda Developer Guide
Step 2.1: Create a Hello World Lambda Function

Batch size
Starting position
b. For this Getting Started exercise, do not congure a trigger and choose Next.
5. On the Congure function page, do the following:

a. Review the precongured Lambda function conguration information, including:

Runtime is Python 3.6


Code authored in Python is provided. It reads incoming event data and logs some of the
information to CloudWatch.
Handler shows lambda_function.lambda_handler value. It is the filename.handler-
function. The console saves the sample code in the lambda_function.py le and in the
code lambda_handler is the function name that receives the event as a parameter when
the Lambda function is invoked. For more information, see Lambda Function Handler
(Python) (p. 42).
b. Enter the function name hello-world-python in Name.
c. In the Lambda Function Code section, do the following:

Review the sample code. Note that:

The console saves this code as lambda_handler.py. The console then zips the le, and
uploads it to AWS Lambda creating your Lambda function.
The sample code processes incoming events of the following form:

{
"key3": "value3",
"key2": "value2",
"key1": "value1"
}

After creating the Lambda function, you invoke it using sample events of this form in the
next section.
d. In the Lambda function handler and role section, do the following:

i. Note the Handler* value. It is of the form python-file-name.handler-function.


ii. In Role*, choose Create new role from template(s).
iii. In Role name, type a name for the role.
iv. In Role templates, Lambda provides a list of optional templates that, should you select
one, automatically creates the role with the requisite permissions attached to that policy.
For a list of the Policy templates, see Policy Templates (p. 344). For the purpose of this
tutorial, you can leave this eld blank because your Lambda function already has the basic
execution permission it needs.

Note
Optionally, you could select Choose an existing role if you already have a role
created with specic permissions beyond basic execution. You can also select Create a
custom role. When you choose this option, a window appears where you can edit the
permissions policy inline.
e. In the Advanced settings section, leave the default Lambda function conguration values.

The memory and timeout values are sucient for the Lambda function you are creating. These
congurations inuence the performance of your code. For more information, see Lambda
Functions (p. 3).

191
AWS Lambda Developer Guide
Step 2.2: Invoke the Lambda Function

f. Choose Next.
g. Choose Create Function to create a Lambda function.

The console saves the code into a le and then zips the le, which is the deployment package.
The console then uploads the deployment package to AWS Lambda creating your Lambda
function. The console shows the hello-world-python Lambda function, you can now perform
various action including test the function:

Note the tabs in the console:

Code Shows the Lambda function code.


Conguration shows current function conguration and you can change the conguration
as needed. After you change any conguration settings, you choose Save to save the updated
conguration.
Triggers Shows any triggers you congured for this function (does not apply to this Getting
Started exercise).
Monitoring Provides various CloudWatch metrics for your Lambda function. In the next
section, you invoke your hello-world-python Lambda function and review these metrics.

Next Step

Step 2.2: Invoke the Lambda Function Manually and Verify Results, Logs, and Metrics (p. 192)

Step 2.2: Invoke the Lambda Function Manually and


Verify Results, Logs, and Metrics
Follow the steps to invoke your Lambda function using the sample event data provided in the console.

1. On the Lambda > Functions > HelloWorld page, choose Test.


2. In the Input test event page, choose Hello World from the Sample event template list. The
following sample event template appears in the window.

{
"key3": "value3",

192
AWS Lambda Developer Guide
Step 2.2: Invoke the Lambda Function

"key2": "value2",
"key1": "value1"
}

You can change key and values in the sample JSON, but don't change the event structure. If you do
change any keys and values, you must update the sample code accordingly. Choose Save and test.
3. AWS Lambda executes your function on your behalf. The handler in your Lambda function receives
and then processes the sample event.
4. Upon successful execution, view results in the console.

Note the following:

The Execution result section shows the execution status as succeeded and also shows the
function execution results, returned by the return statement.
Note
The console always uses the RequestResponse invocation type (synchronous invocation)
when invoking a Lambda function which causes AWS Lambda to return a response
immediately. For more information, see Invocation Types (p. 4).

193
AWS Lambda Developer Guide
Step 2.2: Invoke the Lambda Function

The Summary section shows the key information reported in the Log output section (the REPORT
line in the execution log).
The Log output section shows the log AWS Lambda generates for each execution. These are the
logs written to CloudWatch by the Lambda function. The AWS Lambda console shows these logs
for your convenience.

Note that the Click here link shows logs in the CloudWatch console. The function then adds logs to
Amazon CloudWatch in the log group that corresponds to the Lambda function.
5. Run the Lambda function a few times to gather some metrics that you can view in the next step.
6. Choose the Monitoring tab to view the CloudWatch metrics for your Lambda function. This page
shows four CloudWatch metrics.

Note the following:

The X-axis shows the past 24 hours from the current time (for example, 2:00 pm as shown in the
screen shot).
Invocation count shows the number of invocations during this interval.
Invocation duration shows how long it took for your Lambda function to run. It shows minimum,
maximum, and average time of execution.
Invocation errors show the number of times your Lambda function failed. You can compare the
number of times your function executed and how many times it failed (if any).
Throttled invocation metrics show whether AWS Lambda throttled your Lambda function
invocation. For more information, see List of AWS Lambda Limits (p. 317).

194
AWS Lambda Developer Guide
Step 2.3: (Optional) Create a
Lambda Function Authored in Java

The AWS Lambda console shows these CloudWatch metrics for your convenience. You can see
these metrics in the Amazon CloudWatch console by clicking any of these metrics.

Next Step

Step 2.3: (Optional) Create a Lambda Function Authored in Java (p. 195)

Step 2.3: (Optional) Create a Lambda Function


Authored in Java
The blueprints provide sample code authored either in Python or Node.js. You can easily modify the
example using the inline editor in the console. However, if you want to author code for your Lambda
function in Java, there are no blueprints provided. Also, there is no inline editor for you to write Java
code in the AWS Lambda console.

That means, you must write your Java code and also create your deployment package outside the
console. After you create the deployment package, you can use the console to upload the package
to AWS Lambda to create your Lambda function. You can also use the console to test the function by
manually invoking it.

In this section you create a Lambda function using the following Java code example.

package example;

import com.amazonaws.services.lambda.runtime.Context;
import com.amazonaws.services.lambda.runtime.LambdaLogger;

public class Hello {


public String myHandler(int myCount, Context context) {
LambdaLogger logger = context.getLogger();
logger.log("received : " + myCount);
return String.valueOf(myCount);
}
}

The programming model explains how to write your Java code in detail, for example the input/output
types AWS Lambda supports. For more information about the programming model, see Programming
Model for Authoring Lambda Functions in Java (p. 24). For now, note the following about this code:

When you package and upload this code to create your Lambda function, you specify the
example.Hello::myHandler method reference as the handler.
The handler in this example uses the int type for input and the String type for output.

AWS Lambda supports input/output of JSON-serializable types and InputStream/OutputStream types.


When you invoke this function you will pass a sample int (for example, 123).
In this exercise you use the console to manually invoke this Lambda function. The console always uses
the RequestResponse invocation type (synchronous) and therefore you will see the response in the
console.
The handler includes the optional Context parameter. In the code we use the LambdaLogger provided
by the Context object to write log entries to CloudWatch logs. For information about using the
Context object, see The Context Object (Java) (p. 34).

First, you need to package this code and any dependencies into a deployment package. Then, you can
use the Getting Started exercise to upload the package to create your Lambda function and test using
the console.

195
AWS Lambda Developer Guide
Step 2.4: (Optional) Create a
Lambda Function Authored in C#

Next Step

Step 2.4: (Optional) Create a Lambda Function Authored in C# (p. 196)

Step 2.4: (Optional) Create a Lambda Function


Authored in C#
The AWS Lambda console blueprints provide sample code authored either in Python or Node.js. You can
easily modify the example using the inline editor in the console. However, if you want to author code for
your Lambda function in C#, there are no blueprints provided. Also, there is no inline editor for you to
write C# code in the AWS Lambda console.

While the Lambda console does not oer editing for compiled languages such as Java and C#, you can
use your choice of IDEs, such as Visual Studio, to create and package your C# code and libraries. Once
packaged as a ZIP le, you can use the AWS Lambda console to upload and test C# Lambda functions
and to view logs and metrics for them.

In this section you create a Lambda function using the following C# code example.

using Amazon.Lambda.Core;
namespace LambdaFunctionExample{
public class Hello {
public string MyHandler(int count, ILambdaContext context) {
var logger = context.Logger;
logger.Log("received : " + count);
return count.ToString();
}
}
}

Your Lambda function handler signature should be of the format


Assembly::Namespace.ClassName::MethodName. The programming model explains how to write your C#
code in detail, for example the input/output types AWS Lambda supports. For more information about
the programming model, see Programming Model for Authoring Lambda Functions in C# (p. 50). For
now, note the following about this code:

The handler in this example uses the int type for input and the string type for output.

When you invoke this function you will pass a sample int (for example, 123).
In this exercise you use the console to manually test this Lambda function. The console always uses the
RequestResponse invocation type (synchronous) and therefore you will see the response in the console.
The handler includes the optional ILambdaContext parameter. In the code we use the LambdaLogger
provided by the Amazon.Lambda.Core.LambdaLogger object to write log entries to CloudWatch logs. For
information about using the ILambdaContext object, see The Context Object (C#) (p. 54).

First, you need to package this code and any dependencies into a deployment package. Then, you can
use the Getting Started exercise to upload the package to create your Lambda function and test using
the console. For more information, see Creating a Deployment Package (C#) (p. 61).

Next Step

Step 3: Create a Simple Microservice using Lambda and API Gateway (p. 197)

196
AWS Lambda Developer Guide
Step 3: Create a Simple Microservice
using Lambda and API Gateway

Step 3: Create a Simple Microservice using Lambda


and API Gateway
In this exercise you will use the Lambda console to create a Lambda function (MyLambdaMicroservice),
and an Amazon API Gateway endpoint to trigger that function. You will be able to call the endpoint with
any method (GET, POST, PATCH, etc.) to trigger your Lambda function. When the endpoint is called, the
entire request will be passed through to your Lambda function. Your function action will depend on the
method you call your endpoint with:

DELETE: delete an item from a DynamoDB table


GET: scan table and return all items
POST: Create an item
PUT: Update an item

Next Step
Step 3.1: Create an API Using Amazon API Gateway (p. 197)

Step 3.1: Create an API Using Amazon API Gateway


Follow the steps in this section to create a new Lambda function and an API Gateway endpoint to trigger
it:

1. Sign in to the AWS Management Console and open the AWS Lambda console.
2. Choose Create Lambda function.
3. On the Select blueprint page, choose the microservice-http-endpoint blueprint. You can use the
Filter to nd it.
4. The Congure triggers page will be populated with an API Gateway trigger. The default API name
that will be created is LambdaMicroservice (You can change this name via the API Name eld if you
wish).
Note
When you complete the wizard and create your function, Lambda automatically creates a
proxy resource named MyLambdaMicroservice (your function name) under the API name you
selected. For more information about proxy resources, see Congure Proxy Integration for a
Proxy Resource. A proxy resource has an AWS_PROXY integration type and a catch-all method
ANY. The AWS_PROXY integration type applies a default mapping template to pass through the
entire request to the Lambda function and transforms the output from the Lambda function
to HTTP responses. The ANY method denes the same integration setup for all the supported
methods, including GET, POST, PATCH, DELETE and others.

After reviewing your trigger, choose Next.


5. On the Congure function page, do the following:
a. Review the precongured Lambda function conguration information, including:
Runtime is Node.js 6.10
Code authored in JavaScript is provided. The code performs DynamoDB operations based on the
method called and payload provided.
Handler shows index.handler. The format is: filename.handler-function
b. Enter the function name MyLambdaMicroservice in Name.
c. In Role, enter a role name for the new role that will be created.

197
AWS Lambda Developer Guide
Step 3.2: Test Sending an HTTPS Request

Note
The microservice-http-endpoint blueprint pre-populates the Simple Microservice
permission policy template in the Policy templates eld, to be added to your new role
upon creation. This automatically adds the requisite permissions attached to that policy to
your new role. For more information, see Policy Templates (p. 344).
6. Choose Create function.

Next Step
Step 3.2: Test Sending an HTTPS Request (p. 198)

Step 3.2: Test Sending an HTTPS Request


In this step, you will use the console to test the Lambda function. In addition, you can run a curl
command to test the end-to-end experience. That is, send an HTTPS request to your API method and
have Amazon API Gateway invoke your Lambda function. In order to complete the steps, make sure you
have created a DynamoDB table and named it "MyTable". For more information, see Step 3.1: Create a
DynamoDB Table with a Stream Enabled (p. 236)

1. With your MyLambdaMicroService function still open in the console, choose the Actions tab and then
choose Congure test event.
2. Replace the existing text with the following:

{
"httpMethod": "GET",
"queryStringParameters": {
"TableName": "MyTable"
}
}

3. After entering the text above choose Save and test.

Next Step

Step 3.3: (Optional) Try Other Blueprints (p. 198)

Step 3.3: (Optional) Try Other Blueprints


You can optionally try the following exercises:

You used the hello-world-python blueprint in this Getting Started exercise. This blueprint provides
sample code authored in Python. There is also the hello-world blueprint that provides similar Lambda
function code that is authored in Node.js.
Both the hello-world-python and the hello-world blueprints process custom events. For this Getting
Started exercise, you used hand-crafted sample event data. Your can write Lambda functions to
process events published by event sources such as Amazon S3 and DynamoDB. This requires event
source conguration in the console.

For example, you can write a Lambda function to process Amazon S3 events. Then, you congure
Amazon S3 as the event source to publish object-created events to AWS Lambda. When you upload an
object to your bucket, Amazon S3 detects the event and invokes your Lambda function. Your Lambda
function receives the event data as a parameter. You can verify your Lambda function executed by
reviewing the CloudWatch logs either in the Lambda console or the CloudWatch console.

198
AWS Lambda Developer Guide
What's Next?

The Lambda console provide blueprint to set up an example Lambda function to process Amazon S3
events. When creating a Lambda function in the console on the Select blueprint page, enter s3 in the
Filter box to search for a list of available blueprints.

For more information about working with dierent event sources, see Use Cases (p. 200).

Next Step

What's Next? (p. 199)

What's Next?
This Getting Started exercise provided you with an overview of how to use the AWS Lambda console.

AWS Lambda functions can also be automatically invoked in response to events in other AWS services
such as Amazon S3 and DynamoDB. Lambda functions can also be invoked on-demand over HTTPS.
You can also build your own custom event sources and invoke Lambda functions on demand. For more
information, see How It Works (p. 175).

Depending on your integration scenario, whether your application needs event-driven Lambda function
invocation or on-demand invocation, see the following sections:

Using AWS Lambda with Amazon S3 (p. 200)


Using AWS Lambda with Kinesis (p. 217)
Using AWS Lambda with Amazon DynamoDB (p. 227)
Using AWS Lambda with AWS CloudTrail (p. 238)
Using AWS Lambda with Amazon API Gateway (On-Demand Over HTTPS) (p. 258)
Using AWS Lambda as Mobile Application Backend (Custom Event Source: Android) (p. 272)

The console provides several blueprints for you to set up example Lambda functions quickly that can
process events from these event sources. You may want to explore other blueprints in the console to get
started with Lambda functions triggered by these event sources.

199
AWS Lambda Developer Guide
Amazon S3

Examples of How to Use AWS


Lambda

The use cases for AWS Lambda can be grouped into the following categories:

Using AWS Lambda with AWS services as event sources Event sources publish events that cause the
Lambda function to be invoked. These can be AWS services such as Amazon S3. For more information
and tutorials, see the following topics:

Using AWS Lambda with Amazon S3 (p. 200)

Using AWS Lambda with Kinesis (p. 217)

Using AWS Lambda with Amazon DynamoDB (p. 227)

Using AWS Lambda with AWS CloudTrail (p. 238)

Using AWS Lambda with Amazon SNS from Dierent Accounts (p. 253)
On-demand Lambda function invocation over HTTPS (Amazon API Gateway) In addition to
invoking Lambda functions using event sources, you can also invoke your Lambda function over
HTTPS. You can do this by dening a custom REST API and endpoint using API Gateway. For more
information and a tutorial, see Using AWS Lambda with Amazon API Gateway (On-Demand Over
HTTPS) (p. 258).
On-demand Lambda function invocation (build your own event sources using custom apps)
User applications such as client, mobile, or web applications can publish events and invoke Lambda
functions using the AWS SDKs or AWS Mobile SDKs, such as the AWS Mobile SDK for Android. For more
information and a tutorial, see Getting Started (p. 185) and Using AWS Lambda as Mobile Application
Backend (Custom Event Source: Android) (p. 272)
Scheduled events You can also set up AWS Lambda to invoke your code on a regular, scheduled
basis using the AWS Lambda console. You can specify a xed rate (number of hours, days, or weeks)
or you can specify a cron expression. For more information and a tutorial, see Using AWS Lambda with
Scheduled Events (p. 284).

Using AWS Lambda with Amazon S3


Amazon S3 can publish events (for example, when an object is created in a bucket) to AWS Lambda and
invoke your Lambda function by passing the event data as a parameter. This integration enables you
to write Lambda functions that process Amazon S3 events. In Amazon S3, you add bucket notication

200
AWS Lambda Developer Guide
Amazon S3

conguration that identies the type of event that you want Amazon S3 to publish and the Lambda
function that you want to invoke.

Note the following about how the Amazon S3 and AWS Lambda integration works:

Non-stream based (async) model This is a model (see Event Source Mapping (p. 127)), where
Amazon S3 monitors a bucket and invokes the Lambda function by passing the event data as a
parameter. In a push model, you maintain event source mapping within Amazon S3 using the bucket
notication conguration. In the conguration, you specify the event types that you want Amazon S3
to monitor and which AWS Lambda function you want Amazon S3 to invoke. For more information,
see Conguring Amazon S3 Event Notications in the Amazon Simple Storage Service Developer Guide.
Asynchronous invocation AWS Lambda invokes a Lambda function using the Event invocation type
(asynchronous invocation). For more information about invocation types, see Invocation Types (p. 4).
Event structure The event your Lambda function receives is for a single object and it provides
information, such as the bucket name and object key name.

Note that there are two types of permissions policies that you work with when you set up the end-to-end
experience:

Permissions for your Lambda function Regardless of what invokes a Lambda function, AWS Lambda
executes the function by assuming the IAM role (execution role) that you specify at the time you
create the Lambda function. Using the permissions policy associated with this role, you grant your
Lambda function the permissions that it needs. For example, if your Lambda function needs to read an
object, you grant permissions for the relevant Amazon S3 actions in the permissions policy. For more
information, see Manage Permissions: Using an IAM Role (Execution Role) (p. 180).
Permissions for Amazon S3 to invoke your Lambda function Amazon S3 cannot invoke your
Lambda function without your permission. You grant this permission via the permissions policy
associated with the Lambda function.

The following diagram summarizes the ow:

1. User uploads an object to an S3 bucket (object-created event).


2. Amazon S3 detects the object-created event.
3. Amazon S3 invokes a Lambda function that is specied in the bucket notication conguration.
4. AWS Lambda executes the Lambda function by assuming the execution role that you specied at the
time you created the Lambda function.
5. The Lambda function executes.

201
AWS Lambda Developer Guide
Tutorial

For a tutorial that walks you through an example setup, see Tutorial: Using AWS Lambda with Amazon
S3 (p. 202).

Tutorial: Using AWS Lambda with Amazon S3


Suppose you want to create a thumbnail for each image (.jpg and .png objects) that is uploaded to a
bucket. You can create a Lambda function (CreateThumbnail) that Amazon S3 can invoke when objects
are created. Then, the Lambda function can read the image object from the source bucket and create a
thumbnail image target bucket (in this tutorial, it's called the sourceresized bucket).
Important
You must use two buckets. If you use the same bucket as the source and the target, each
thumbnail uploaded to the source bucket triggers another object-created event, which then
invokes the Lambda function again, creating an unwanted recursion.

Implementation Summary
The following diagram illustrates the application ow:

1. A user uploads an object to the source bucket in Amazon S3 (object-created event).


2. Amazon S3 detects the object-created event.
3. Amazon S3 publishes the s3:ObjectCreated:* event to AWS Lambda by invoking the Lambda
function and passing event data as a function parameter.
4. AWS Lambda executes the Lambda function by assuming the execution role that you specied at the
time you created the Lambda function.
5. From the event data it receives, the Lambda function knows the source bucket name and object key
name. The Lambda function reads the object and creates a thumbnail using graphics libraries, and
saves it to the target bucket.

Note that upon completing this tutorial, you will have the following Amazon S3, Lambda, and IAM
resources in your account:

202
AWS Lambda Developer Guide
Tutorial

In Lambda:

A Lambda function.
An access permissions policy associated with your Lambda function You grant Amazon S3
permissions to invoke the Lambda function using this permissions policy. You will also restrict the
permissions so that Amazon S3 can invoke the Lambda function only for object-created events from a
specic bucket that is owned by a specic AWS account.
Note
It is possible for an AWS account to delete a bucket and some other AWS account to later
create a bucket with the same name. The additional conditions ensure that Amazon S3 can
invoke the Lambda function only if Amazon S3 detects object-created events from a specic
bucket owned by a specic AWS account.

For more information, see How It Works (p. 175).

In IAM:

Administrator user Called adminuser. Using root credentials of an AWS account is not recommended.
Instead, use the adminuser credentials to perform the steps in this tutorial.
An IAM role (execution role) You grant permissions that your Lambda function needs through the
permissions policy associated with this role.

In Amazon S3:

Two buckets named source and sourceresized. Note that source is a placeholder name and you need
to replace it with your actual bucket name. For example, if you have a bucket named example as your
source, you will create exampleresized as the target bucket.
Notication conguration on the source bucket You add notication conguration on your source
bucket identifying the type of events (object-created events) you want Amazon S3 to publish to AWS
Lambda and the Lambda function to invoke. For more information about the Amazon S3 notication
feature, see Setting Up Notication of Bucket Events in Amazon Simple Storage Service Developer
Guide..

203
AWS Lambda Developer Guide
Tutorial

Now you are ready to start the tutorial. Note that after the initial preparation, the tutorial is divided into
two main sections:

First, you complete the necessary setup steps to create a Lambda function and invoke it manually
using Amazon S3 sample event data. This intermediate testing veries that the function works.
Second, you add notication conguration to your source bucket so that Amazon S3 can invoke your
Lambda function when it detects object-created events.

Next Step
Step 1: Prepare (p. 204)

Step 1: Prepare
In this section, you do the following:

Sign up for an AWS account and set up the AWS CLI.


Create two buckets (source and sourceresized bucket) with a sample .jpg object (HappyFace.jpg) in
the source bucket. For instructions, see the following procedure.

Step 1.1: Sign Up for AWS and Set Up the AWS CLI
Make sure you have completed the following steps:

Signed up for an AWS account and created an administrator user in the account (called adminuser).
Installed and set up the AWS CLI.

For instructions, see Step 1: Set Up an AWS Account and the AWS CLI (p. 185).

Step 1.2: Create Buckets and Upload a Sample Object


Follow the steps to create buckets and upload an object.
Important
Both the source bucket and your Lambda function must be in the same AWS region. In addition,
the example code used for the Lambda function also assumes that both of the buckets are in
the same region. In this tutorial, we use the us-west-2 region.

1. Using the IAM User Sign-In URL, sign in to the Amazon S3 console as adminuser.
2. Create two buckets. The target bucket name must be source followed by resized, where source is the
name of the bucket you want to use for the source. For example, mybucket and mybucketresized.

For instructions, see Create a Bucket in the Amazon Simple Storage Service Getting Started Guide.
3. In the source bucket, upload a .jpg object, HappyFace.jpg.

When you invoke the Lambda function manually before you connect to Amazon S3, you pass sample
event data to the function that species the source bucket and HappyFace.jpg as the newly created
object so you need to create this sample object rst.

Next Step
Step 2: Create a Lambda Function and Invoke It Manually (Using Sample Event Data) (p. 205)

204
AWS Lambda Developer Guide
Tutorial

Step 2: Create a Lambda Function and Invoke It Manually (Using


Sample Event Data)
In this section, you do the following:

Create a Lambda function deployment package using the sample code provided.
Note
To see more examples of using other AWS services within your function, including calling
other Lambda functions, see AWS SDK for JavaScript
Create an IAM role (execution role). At the time you upload the deployment package, you need to
specify an IAM role (execution role) that Lambda can assume to execute the function on your behalf.
Create the Lambda function by uploading the deployment package, and then test it by invoking it
manually using sample Amazon S3 event data.

Topics
Step 2.1: Create a Deployment Package (p. 205)
Step 2.2: Create the Execution Role (IAM Role) (p. 212)
Step 2.3: Create the Lambda Function and Test It Manually (p. 212)

Step 2.1: Create a Deployment Package


From the Filter View list, choose the language you want to use for your Lambda function. The
appropriate section appears with code and specic instructions for creating a deployment package.

Node.js

The deployment package is a .zip le containing your Lambda function code and dependencies.

1. Create a folder (examplefolder), and then create a subfolder (node_modules).


2. Install the Node.js platform. For more information, see the Node.js website.
3. Install dependencies. The code examples use the following libraries:

AWS SDK for JavaScript in Node.js


gm, GraphicsMagick for node.js
Async utility module

The AWS Lambda runtime already has the AWS SDK for JavaScript in Node.js, so you only need to
install the other libraries. Open a command prompt, navigate to the examplefolder, and install the
libraries using the npm command, which is part of Node.js.

npm install async gm

4. Open a text editor, and then copy the following code.

// dependencies
var async = require('async');
var AWS = require('aws-sdk');
var gm = require('gm')
.subClass({ imageMagick: true }); // Enable ImageMagick integration.
var util = require('util');

205
AWS Lambda Developer Guide
Tutorial

// constants
var MAX_WIDTH = 100;
var MAX_HEIGHT = 100;

// get reference to S3 client


var s3 = new AWS.S3();

exports.handler = function(event, context, callback) {


// Read options from the event.
console.log("Reading options from event:\n", util.inspect(event, {depth: 5}));
var srcBucket = event.Records[0].s3.bucket.name;
// Object key may have spaces or unicode non-ASCII characters.
var srcKey =
decodeURIComponent(event.Records[0].s3.object.key.replace(/\+/g, " "));
var dstBucket = srcBucket + "resized";
var dstKey = "resized-" + srcKey;

// Sanity check: validate that source and destination are different buckets.
if (srcBucket == dstBucket) {
callback("Source and destination buckets are the same.");
return;
}

// Infer the image type.


var typeMatch = srcKey.match(/\.([^.]*)$/);
if (!typeMatch) {
callback("Could not determine the image type.");
return;
}
var imageType = typeMatch[1];
if (imageType != "jpg" && imageType != "png") {
callback('Unsupported image type: ${imageType}');
return;
}

// Download the image from S3, transform, and upload to a different S3 bucket.
async.waterfall([
function download(next) {
// Download the image from S3 into a buffer.
s3.getObject({
Bucket: srcBucket,
Key: srcKey
},
next);
},
function transform(response, next) {
gm(response.Body).size(function(err, size) {
// Infer the scaling factor to avoid stretching the image unnaturally.
var scalingFactor = Math.min(
MAX_WIDTH / size.width,
MAX_HEIGHT / size.height
);
var width = scalingFactor * size.width;
var height = scalingFactor * size.height;

// Transform the image buffer in memory.


this.resize(width, height)
.toBuffer(imageType, function(err, buffer) {
if (err) {
next(err);
} else {
next(null, response.ContentType, buffer);
}
});
});
},

206
AWS Lambda Developer Guide
Tutorial

function upload(contentType, data, next) {


// Stream the transformed image to a different S3 bucket.
s3.putObject({
Bucket: dstBucket,
Key: dstKey,
Body: data,
ContentType: contentType
},
next);
}
], function (err) {
if (err) {
console.error(
'Unable to resize ' + srcBucket + '/' + srcKey +
' and upload to ' + dstBucket + '/' + dstKey +
' due to an error: ' + err
);
} else {
console.log(
'Successfully resized ' + srcBucket + '/' + srcKey +
' and uploaded to ' + dstBucket + '/' + dstKey
);
}

callback(null, "message");
}
);
};

Note
The code sample is compliant with the Node.js runtimes v6.10 or v4.3. For more
information, see Programming Model (Node.js) (p. 9)
5. Review the preceding code and note the following:

The function knows the source bucket name and the key name of the object from the event data
it receives as parameters. If the object is a .jpg, the code creates a thumbnail and saves it to the
target bucket.
The code assumes that the destination bucket exists and its name is a concatenation of the source
bucket name followed by the string resized. For example, if the source bucket identied in the
event data is examplebucket, the code assumes you have an examplebucketresized destination
bucket.
For the thumbnail it creates, the code derives its key name as the concatenation of the string
resized- followed by the source object key name. For example, if the source object key is
sample.jpg, the code creates a thumbnail object that has the key resized-sample.jpg.
6. Save the le as CreateThumbnail.js in examplefolder. After you complete this step, you will have
the following folder structure:

CreateThumbnail.js
/node_modules/gm
/node_modules/async

7. Zip the CreateThumbnail.js le and the node_modules folder as CreateThumbnail.zip.

This is your Lambda function deployment package.

Next Step

Step 2.2: Create the Execution Role (IAM Role) (p. 212)

207
AWS Lambda Developer Guide
Tutorial

Java

The following is example Java code that reads incoming Amazon S3 events and creates a thumbnail.
Note that it implements the RequestHandler interface provided in the aws-lambda-java-core library.
Therefore, at the time you create a Lambda function you specify the class as the handler (that is,
example.S3EventProcessorCreateThumbnail). For more information about using interfaces to provide a
handler, see Leveraging Predened Interfaces for Creating Handler (Java) (p. 30).

The S3Event type that the handler uses as the input type is one of the predened classes in the aws-
lambda-java-events library that provides methods for you to easily read information from the incoming
Amazon S3 event. The handler returns a string as output.

package example;

import java.awt.Color;
import java.awt.Graphics2D;
import java.awt.RenderingHints;
import java.awt.image.BufferedImage;
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.net.URLDecoder;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

import javax.imageio.ImageIO;

import com.amazonaws.services.lambda.runtime.Context;
import com.amazonaws.services.lambda.runtime.RequestHandler;
import com.amazonaws.services.lambda.runtime.events.S3Event;
import com.amazonaws.services.s3.AmazonS3;
import com.amazonaws.services.s3.AmazonS3Client;
import com.amazonaws.services.s3.event.S3EventNotification.S3EventNotificationRecord;
import com.amazonaws.services.s3.model.GetObjectRequest;
import com.amazonaws.services.s3.model.ObjectMetadata;
import com.amazonaws.services.s3.model.S3Object;

public class S3EventProcessorCreateThumbnail implements


RequestHandler<S3Event, String> {
private static final float MAX_WIDTH = 100;
private static final float MAX_HEIGHT = 100;
private final String JPG_TYPE = (String) "jpg";
private final String JPG_MIME = (String) "image/jpeg";
private final String PNG_TYPE = (String) "png";
private final String PNG_MIME = (String) "image/png";

public String handleRequest(S3Event s3event, Context context) {


try {
S3EventNotificationRecord record = s3event.getRecords().get(0);

String srcBucket = record.getS3().getBucket().getName();


// Object key may have spaces or unicode non-ASCII characters.
String srcKey = record.getS3().getObject().getKey()
.replace('+', ' ');
srcKey = URLDecoder.decode(srcKey, "UTF-8");

String dstBucket = srcBucket + "resized";


String dstKey = "resized-" + srcKey;

// Sanity check: validate that source and destination are different


// buckets.
if (srcBucket.equals(dstBucket)) {
System.out

208
AWS Lambda Developer Guide
Tutorial

.println("Destination bucket must not match source bucket.");


return "";
}

// Infer the image type.


Matcher matcher = Pattern.compile(".*\\.([^\\.]*)").matcher(srcKey);
if (!matcher.matches()) {
System.out.println("Unable to infer image type for key "
+ srcKey);
return "";
}
String imageType = matcher.group(1);
if (!(JPG_TYPE.equals(imageType)) && !(PNG_TYPE.equals(imageType))) {
System.out.println("Skipping non-image " + srcKey);
return "";
}

// Download the image from S3 into a stream


AmazonS3 s3Client = new AmazonS3Client();
S3Object s3Object = s3Client.getObject(new GetObjectRequest(
srcBucket, srcKey));
InputStream objectData = s3Object.getObjectContent();

// Read the source image


BufferedImage srcImage = ImageIO.read(objectData);
int srcHeight = srcImage.getHeight();
int srcWidth = srcImage.getWidth();
// Infer the scaling factor to avoid stretching the image
// unnaturally
float scalingFactor = Math.min(MAX_WIDTH / srcWidth, MAX_HEIGHT
/ srcHeight);
int width = (int) (scalingFactor * srcWidth);
int height = (int) (scalingFactor * srcHeight);

BufferedImage resizedImage = new BufferedImage(width, height,


BufferedImage.TYPE_INT_RGB);
Graphics2D g = resizedImage.createGraphics();
// Fill with white before applying semi-transparent (alpha) images
g.setPaint(Color.white);
g.fillRect(0, 0, width, height);
// Simple bilinear resize
// If you want higher quality algorithms, check this link:
// https://today.java.net/pub/a/today/2007/04/03/perils-of-image-
getscaledinstance.html
g.setRenderingHint(RenderingHints.KEY_INTERPOLATION,
RenderingHints.VALUE_INTERPOLATION_BILINEAR);
g.drawImage(srcImage, 0, 0, width, height, null);
g.dispose();

// Re-encode image to target format


ByteArrayOutputStream os = new ByteArrayOutputStream();
ImageIO.write(resizedImage, imageType, os);
InputStream is = new ByteArrayInputStream(os.toByteArray());
// Set Content-Length and Content-Type
ObjectMetadata meta = new ObjectMetadata();
meta.setContentLength(os.size());
if (JPG_TYPE.equals(imageType)) {
meta.setContentType(JPG_MIME);
}
if (PNG_TYPE.equals(imageType)) {
meta.setContentType(PNG_MIME);
}

// Uploading to S3 destination bucket


System.out.println("Writing to: " + dstBucket + "/" + dstKey);
s3Client.putObject(dstBucket, dstKey, is, meta);

209
AWS Lambda Developer Guide
Tutorial

System.out.println("Successfully resized " + srcBucket + "/"


+ srcKey + " and uploaded to " + dstBucket + "/" + dstKey);
return "Ok";
} catch (IOException e) {
throw new RuntimeException(e);
}
}
}

Amazon S3 invokes your Lambda function using the Event invocation type, where AWS Lambda executes
the code asynchronously. What you return does not matter. However, in this case we are implementing
an interface that requires us to specify a return type, so in this example the handler uses String as the
return type.

Using the preceding code (in a le named S3EventProcessorCreateThumbnail.java), create a


deployment package. Make sure that you add the following dependencies:

aws-lambda-java-core
aws-lambda-java-events

These can be found at aws-lambda-java-libs.

For more information, see Programming Model for Authoring Lambda Functions in Java (p. 24).

Your deployment package can be a .zip le or a standalone .jar. You can use any build and packaging
tool you are familiar with to create a deployment package. For examples of how to use the Maven build
tool to create a standalone .jar, see Creating a .jar Deployment Package Using Maven without any IDE
(Java) (p. 66) and Creating a .jar Deployment Package Using Maven and Eclipse IDE (Java) (p. 68). For an
example of how to use the Gradle build tool to create a .zip le, see Creating a .zip Deployment Package
(Java) (p. 70).

After you verify that your deployment package is created, go to the next step to create an IAM role
(execution role). You specify this role at the time you create your Lambda function.

Next Step
Step 2.2: Create the Execution Role (IAM Role) (p. 212)

Python
In this section, you create an example Python function and install dependencies. The code sample is
compliant with Python runtime versions 3.6 or 2.7. The steps assume the 3.6 runtime but you can use
either one.

1. Open a text editor, and copy the following code. The code uploads the resized image to a dierent
bucket with the same image name, as shown following:

source-bucket/image.png -> source-bucketresized/image.png


Note
The from __future__ statement enables you to write code that is compatible with Python 2
or 3. If you are using runtime version 3.6, it is not necessary to include it.

from __future__ import print_function


import boto3
import os
import sys
import uuid
from PIL import Image
import PIL.Image

210
AWS Lambda Developer Guide
Tutorial

s3_client = boto3.client('s3')

def resize_image(image_path, resized_path):


with Image.open(image_path) as image:
image.thumbnail(tuple(x / 2 for x in image.size))
image.save(resized_path)

def handler(event, context):


for record in event['Records']:
bucket = record['s3']['bucket']['name']
key = record['s3']['object']['key']
download_path = '/tmp/{}{}'.format(uuid.uuid4(), key)
upload_path = '/tmp/resized-{}'.format(key)

s3_client.download_file(bucket, key, download_path)


resize_image(download_path, upload_path)
s3_client.upload_file(upload_path, '{}resized'.format(bucket), key)

2. Save the le as CreateThumbnail.py.


3. If your source code is on a local host, copy it over.

scp -i key.pem /path/to/my_code.py ec2-user@public-ip-address:~/CreateThumbnail.py


4. Connect to a 64-bit Amazon Linux instance via SSH.

ssh -i key.pem ec2-user@public-ip-address


5. Install Python 3.6 and virtualenv using the following steps:

1. sudo yum install -y gcc zlib zlib-devel openssl openssl-devel


2. wget https://www.python.org/ftp/python/3.6.1/Python-3.6.1.tgz
3. tar -xzvf Python-3.6.1.tgz
4. cd Python-3.6.1 && ./configure && make
5. sudo make install
6. sudo /usr/local/bin/pip3 install virtualenv
6. Choose the virtual environment that was installed via pip3

/usr/local/bin/virtualenv ~/shrink_venv

source ~/shrink_venv/bin/activate
7. Install libraries in the virtual environment

pip install Pillow

pip install boto3

Note
AWS Lambda includes the AWS SDK for Python (Boto 3), so you don't need to include it in
your deployment package, but you can optionally include it for local testing.
8. Add the contents of lib and lib64 site-packages to your .zip le. Note that the following steps
assume you used Python runtime version 3.6. If you used version 2.7 you will need to update
accordingly.

cd $VIRTUAL_ENV/lib/python3.6/site-packages

zip -r9 ~/CreateThumbnail.zip *


9. Add your python code to the .zip le

cd ~

zip -g CreateThumbnail.zip CreateThumbnail.py

211
AWS Lambda Developer Guide
Tutorial

Next Step
Step 2.2: Create the Execution Role (IAM Role) (p. 212)

Step 2.2: Create the Execution Role (IAM Role)


In this section, you create an IAM role using the following predened role type and access permissions
policy:

AWS service role of the type AWS Lambda This role grants AWS Lambda permissions to assume the
role.
AWSLambdaExecute access permissions policy that you attach to the role.
Enter a Role name and then choose Create role.

For more information about IAM roles, see IAM Roles in the IAM User Guide. Use the following procedure
to create the IAM role.

To create an IAM role (execution role)

1. Sign in to the AWS Management Console and open the IAM console at https://
console.aws.amazon.com/iam/.
2. Follow the steps in Creating a Role to Delegate Permissions to an AWS Service in the IAM User Guide
to create an IAM role (execution role). As you follow the steps to create a role, note the following:

In Role Name, use a name that is unique within your AWS account (for example, lambda-s3-
execution-role).
In Select Role Type, choose AWS Service Roles, and then choose AWS Lambda. This grants the
AWS Lambda service permissions to assume the role.
In Attach Policy, choose AWSLambdaBasicExecuteRole.
3. Write down the role ARN. You will need it in the next step when you create your Lambda function.

Next Step
Step 2.3: Create the Lambda Function and Test It Manually (p. 212)

Step 2.3: Create the Lambda Function and Test It Manually


In this section, you do the following:

Create a Lambda function by uploading the deployment package.


Test the Lambda function by invoking it manually and passing sample Amazon S3 event data as a
parameter.

Step 2.3.1: Create the Lambda Function (Upload the Deployment Package)
In this step, you upload the deployment package using the AWS CLI.

1. At the command prompt, run the following Lambda AWS CLI create-function command using
the adminuser as the --profile. You need to update the command by providing the .zip le path
and the execution role ARN. For the runtime parameter, choose between nodejs6.10, nodejs4.3,
python3.6, python2.7 or java8, depending on the code sample you when you created your
deployment package.

$ aws lambda create-function \


--region us-west-2 \
--function-name CreateThumbnail \

212
AWS Lambda Developer Guide
Tutorial

--zip-file fileb://file-path/CreateThumbnail.zip \
--role role-arn \
--handler CreateThumbnail.handler \
--runtime runtime \
--profile adminuser \
--timeout 10 \
--memory-size 1024

Optionally, you can upload the .zip le to an Amazon S3 bucket in the same AWS region, and then
specify the bucket and object name in the preceding command. You need to replace the --zip-file
parameter by the --code parameter, as shown following:

--code S3Bucket=bucket-name,S3Key=zip-file-object-key

2. Write down the function ARN. You will need this in the next section when you add notication
conguration to your Amazon S3 bucket.
3. (Optional) The preceding command species a 10-second timeout value as the function
conguration. Depending on the size of objects you upload, you might need to increase the timeout
value using the following AWS CLI command.

$ aws lambda update-function-configuration \


--function-name CreateThumbnail \
--region us-west-2 \
--timeout timeout-in-seconds \
--profile adminuser

Note
You can create the Lambda function using the AWS Lambda console, in which case note the
value of the create-function AWS CLI command parameters. You provide the same values in
the console UI.

Step 2.3.2: Test the Lambda Function (Invoke Manually)

In this step, you invoke the Lambda function manually using sample Amazon S3 event data. You can test
the function using the AWS Management Console or the AWS CLI.

To test the Lambda function (console)

1. Follow the steps in the Getting Started to create and invoke the Lambda function at Step 2.2: Invoke
the Lambda Function Manually and Verify Results, Logs, and Metrics (p. 192). For the sample event
for testing, choose S3 Put in Sample event template.
2. Verify that the thumbnail was created in the target bucket and monitor the activity of your Lambda
function in the AWS Lambda console as follows:

The AWS Lambda console shows a graphical representation of some of the CloudWatch metrics in
the Cloudwatch Metrics at a glance section for your function.
For each graph, you can also click the logs link to view the CloudWatch Logs directly.

To test the Lambda function (AWS CLI)

1. Save the following Amazon S3 sample event data in a le and save it as input.txt. You need to
update the JSON by providing your sourcebucket name and a .jpg object key.

{
"Records":[
{

213
AWS Lambda Developer Guide
Tutorial

"eventVersion":"2.0",
"eventSource":"aws:s3",
"awsRegion":"us-west-2",
"eventTime":"1970-01-01T00:00:00.000Z",
"eventName":"ObjectCreated:Put",
"userIdentity":{
"principalId":"AIDAJDPLRKLG7UEXAMPLE"
},
"requestParameters":{
"sourceIPAddress":"127.0.0.1"
},
"responseElements":{
"x-amz-request-id":"C3D13FE58DE4C810",
"x-amz-id-2":"FMyUVURIY8/IgAtTv8xRjskZQpcIZ9KG4V5Wp6S7S/
JRWeUWerMUE5JgHvANOjpD"
},
"s3":{
"s3SchemaVersion":"1.0",
"configurationId":"testConfigRule",
"bucket":{
"name":"sourcebucket",
"ownerIdentity":{
"principalId":"A3NL1KOZZKExample"
},
"arn":"arn:aws:s3:::sourcebucket"
},
"object":{
"key":"HappyFace.jpg",
"size":1024,
"eTag":"d41d8cd98f00b204e9800998ecf8427e",
"versionId":"096fKKXTRTtl3on89fVO.nfljtsv6qko"
}
}
}
]
}

2. Run the following Lambda CLI invoke command to invoke the function. Note that the command
requests asynchronous execution. You can optionally invoke it synchronously by specifying
RequestResponse as the invocation-type parameter value.

$ aws lambda invoke \


--invocation-type Event \
--function-name CreateThumbnail \
--region us-west-2 \
--payload file://file-path/inputfile.txt \
--profile adminuser \
outputfile.txt

Note
You are able to invoke this function because you are using your own credentials to invoke
your own function. In the next section, you congure Amazon S3 to invoke this function on
your behalf, which requires you to add permissions to the access policy associated with your
Lambda function to grant Amazon S3 permissions to invoke your function.
3. Verify that the thumbnail was created in the target bucket and monitor the activity of your Lambda
function in the AWS Lambda console as follows:

The AWS Lambda console shows a graphical representation of some of the CloudWatch metrics in
the Cloudwatch Metrics at a glance section for your function.
For each graph, you can also click the logs link to view the CloudWatch Logs directly.

214
AWS Lambda Developer Guide
Tutorial

Next Step

Step 3: Add an Event Source (Congure Amazon S3 to Publish Events) (p. 215)

Step 3: Add an Event Source (Congure Amazon S3 to Publish


Events)
In this step, you add the remaining conguration so that Amazon S3 can publish object-created events to
AWS Lambda and invoke your Lambda function. You do the following in this step:

Add permissions to the Lambda function access policy to allow Amazon S3 to invoke the function.
Add notication conguration to your source bucket. In the notication conguration, you provide the
following:
Event type for which you want Amazon S3 to publish events. For this tutorial, you specify the
s3:ObjectCreated:* event type so that Amazon S3 publishes events when objects are created.
Lambda function to invoke.

Step 3.1: Add Permissions to the Lambda Function's Access Permissions Policy
1. Run the following Lambda CLI add-permission command to grant Amazon S3 service principal
(s3.amazonaws.com) permissions to perform the lambda:InvokeFunction action. Note that
permission is granted to Amazon S3 to invoke the function only if the following conditions are met:

An object-created event is detected on a specic bucket.


The bucket is owned by a specic AWS account. If a bucket owner deletes a bucket, some other
AWS account can create a bucket with the same name. This condition ensures that only a specic
AWS account can invoke your Lambda function.

$ aws lambda add-permission \


--function-name CreateThumbnail \
--region us-west-2 \
--statement-id some-unique-id \
--action "lambda:InvokeFunction" \
--principal s3.amazonaws.com \
--source-arn arn:aws:s3:::sourcebucket \
--source-account bucket-owner-account-id \
--profile adminuser

2. Verify the function's access policy by running the AWS CLI get-policy command.

$ aws lambda get-policy \


--function-name function-name \
--profile adminuser

Step 3.2: Congure Notication on the Bucket


Add notication conguration on the source bucket to request Amazon S3 to publish object-created
events to Lambda. In the conguration, you specify the following:

Event type For this tutorial, select the ObjectCreated (All) Amazon S3 event type.
Lambda function This is your Lambda function that you want Amazon S3 to invoke.

215
AWS Lambda Developer Guide
Tutorial

For instructions on adding notication conguration to a bucket, see Enabling Event Notications in the
Amazon Simple Storage Service Console User Guide.

Step 3.3: Test the Setup


You're all done! Now adminuser can test the setup as follows:

1. Upload .jpg or .png objects to the source bucket using the Amazon S3 console.
2. Verify that the thumbnail was created in the target bucket using the CreateThumbnail function.
3. The adminuser can also verify the CloudWatch Logs. You can monitor the activity of your Lambda
function in the AWS Lambda console. For example, choose the logs link in the console to view logs,
including logs your function wrote to CloudWatch Logs.

Step 4: Deploy With AWS SAM and AWS CloudFormation


In the previous section, you used AWS Lambda APIs to create and update a Lambda function by
providing a deployment package as a ZIP le. However, this mechanism may not be convenient for
automating deployment steps for functions, or coordinating deployments and updates to other elements
of a serverless application, like event sources and downstream resources.

You can use AWS CloudFormation to easily specify, deploy, and congure serverless applications. AWS
CloudFormation is a service that helps you model and set up your Amazon Web Services resources so
that you can spend less time managing those resources and more time focusing on your applications
that run in AWS. You create a template that describes all the AWS resources that you want (like Lambda
functions and DynamoDB tables), and AWS CloudFormation takes care of provisioning and conguring
those resources for you.

In addition, you can use the AWS Serverless Application Model to express resources that comprise the
serverless application. These resource types, such as Lambda functions and APIs, are fully supported by
AWS CloudFormation and make it easier for you to dene and deploy your serverless application.

For more information, see Deploying Lambda-based Applications (p. 144).

Specication for Amazon S3 Thumbnail Application


The following contains the SAM template for this application. Copy the text below to a .yaml le and
save it next to the ZIP package you created previously. Note that the Handler and Runtime parameter
values should match the ones you used when you created the function in the previous section.

AWSTemplateFormatVersion: '2010-09-09'
Transform: AWS::Serverless-2016-10-31
Resources:
CreateThumbnail:
Type: AWS::Serverless::Function
Properties:
Handler: handler
Runtime: runtime
Timeout: 60
Policies: AWSLambdaExecute
Events:
CreateThumbnailEvent:
Type: S3
Properties:
Bucket: !Ref SrcBucket
Events: s3:ObjectCreated:*

SrcBucket:
Type: AWS::S3::Bucket

216
AWS Lambda Developer Guide
Kinesis

Deploying the Serverless Application


For information on how to package and deploy your serverless application using the package and deploy
commands, see Packaging and Deployment (p. 150).

Using AWS Lambda with Kinesis


You can create an Kinesis stream to continuously capture and store terabytes of data per hour from
hundreds of thousands of sources such as website click streams, nancial transactions, social media
feeds, IT logs, and location-tracking events. For more information, see Kinesis.

You can subscribe Lambda functions to automatically read batches of records o your Kinesis stream
and process them if records are detected on the stream. AWS Lambda then polls the stream periodically
(once per second) for new records.

Note the following about how the Kinesis and AWS Lambda integration works:

Stream-based model This is a model (see Event Source Mapping (p. 127)), where AWS Lambda
polls the stream and, when it detects new records, invokes your Lambda function by passing the new
records as a parameter.

In a stream-based model, you maintain event source mapping in AWS Lambda. The event source
mapping describes which stream maps to which Lambda function. AWS Lambda provides an API
(CreateEventSourceMapping (p. 361)) that you can use to create the mapping. You can also use the
AWS Lambda console to create event source mappings.
Synchronous invocation AWS Lambda invokes a Lambda function using the RequestResponse
invocation type (synchronous invocation) by polling the Kinesis Stream. For more information about
invocation types, see Invocation Types (p. 4).
Event structure The event your Lambda function receives is a collection of records AWS Lambda
reads from your stream. When you congure event source mapping, the batch size you specify is the
maximum number of records that you want your Lambda function to receive per invocation.

Regardless of what invokes a Lambda function, AWS Lambda always executes a Lambda function on
your behalf. If your Lambda function needs to access any AWS resources, you need to grant the relevant
permissions to access those resources. You also need to grant AWS Lambda permissions to poll your
Kinesis stream. You grant all of these permissions to an IAM role (execution role) that AWS Lambda
can assume to poll the stream and execute the Lambda function on your behalf. You create this role
rst and then enable it at the time you create the Lambda function. For more information, see Manage
Permissions: Using an IAM Role (Execution Role) (p. 180).

The following diagram illustrates the application ow:

217
AWS Lambda Developer Guide
Tutorial

1. Custom app writes records to the stream.


2. AWS Lambda polls the stream and, when it detects new records in the stream, invokes your Lambda
function.
3. AWS Lambda executes the Lambda function by assuming the execution role you specied at the time
you created the Lambda function.

For a tutorial that walks you through an example setup, see Tutorial: Using AWS Lambda with
Kinesis (p. 218).

Tutorial: Using AWS Lambda with Kinesis


In this tutorial, you create a Lambda function to consume events from an Kinesis stream.

The tutorial is divided into two main sections:

First, you perform the necessary setup to create a Lambda function and then you test it by invoking it
manually using sample event data (you don't need an Kinesis stream).
Second, you create an Kinesis stream (event source). You add an event source mapping in AWS Lambda
to associate the stream with your Lambda function. AWS Lambda starts polling the stream, you add
test records to the stream using the Kinesis API, and then you verify that AWS Lambda executed your
Lambda function.

Important
Both the Lambda function and the Kinesis stream must be in the same AWS region. This tutorial
assumes that you create these resources in the us-west-2 region.

In this tutorial, you use the AWS Command Line Interface to perform AWS Lambda operations such
as creating a Lambda function, creating a stream, and adding records to the stream. You use the AWS
Lambda console to manually invoke the function before you create a Kinesis stream. You verify return
values and logs in the console UI.

Next Step
Step 1: Prepare (p. 218)

Step 1: Prepare
Make sure you have completed the following steps:

Signed up for an AWS account and created an administrator user in the account.
Installed and set up the AWS CLI.

For instructions, see Step 1: Set Up an AWS Account and the AWS CLI (p. 185).

Next Step
Step 2: Create a Lambda Function and Invoke It Manually (Using Sample Event Data) (p. 218)

Step 2: Create a Lambda Function and Invoke It Manually (Using


Sample Event Data)
In this section, you do the following:

218
AWS Lambda Developer Guide
Tutorial

Create a Lambda function deployment package using the sample code provided. The sample Lambda
function code that you'll use to process Kinesis events is provided in various languages. Select one of
the languages and follow the corresponding instructions to create a deployment package.
Note
To see more examples of using other AWS services within your function, including calling
other Lambda functions, see AWS SDK for JavaScript
Create an IAM role (execution role). At the time you upload the deployment package, you need to
specify an IAM role (execution role) that Lambda can assume to execute the function on your behalf.
Create the Lambda function by uploading the deployment package, and then test it by invoking it
manually using sample Kinesis event data.

Topics
Step 2.1: Create a Deployment Package (p. 219)
Step 2.2: Create the Execution Role (IAM Role) (p. 222)
Step 2.3: Create the Lambda Function and Test It Manually (p. 223)

Step 2.1: Create a Deployment Package


From the Filter View list, choose the language you want to use for your Lambda function. The
appropriate section appears with code and specic instructions for creating a deployment package.

Node.js

The following is example Node.js code that receives Kinesis event records as input and processes them.
For illustration, the code writes some of the incoming event data to CloudWatch Logs.

Follow the instructions to create a AWS Lambda function deployment package.

1. Open a text editor, and then copy the following code.

console.log('Loading function');

exports.handler = function(event, context, callback) {


//console.log(JSON.stringify(event, null, 2));
event.Records.forEach(function(record) {
// Kinesis data is base64 encoded so decode here
var payload = new Buffer(record.kinesis.data, 'base64').toString('ascii');
console.log('Decoded payload:', payload);
});
callback(null, "message");
};

Note
The code sample is compliant with the Node.js runtimes v6.10 or v4.3. For more
information, see Programming Model (Node.js) (p. 9)
2. Save the le as ProcessKinesisRecords.js.
3. Zip the ProcessKinesisRecords.js le as ProcessKinesisRecords.zip.

Next Step

Step 2.2: Create the Execution Role (IAM Role) (p. 222)

219
AWS Lambda Developer Guide
Tutorial

Java

The following is example Java code that receives Kinesis event record data as a input and processes it.
For illustration, the code writes some of the incoming event data to CloudWatch Logs.

In the code, recordHandler is the handler. The handler uses the predened KinesisEvent class that is
dened in the aws-lambda-java-events library.

package example;

import com.amazonaws.services.lambda.runtime.Context;
import com.amazonaws.services.lambda.runtime.RequestHandler;
import com.amazonaws.services.lambda.runtime.events.KinesisEvent;
import com.amazonaws.services.lambda.runtime.events.KinesisEvent.KinesisEventRecord;

public class ProcessKinesisEvents implements RequestHandler<KinesisEvent, Void>{


@Override
public Void handleRequest(KinesisEvent event, Context context)
{
for(KinesisEventRecord rec : event.getRecords()) {
System.out.println(new String(rec.getKinesis().getData().array()));
}
return null;
}
}

If the handler returns normally without exceptions, Lambda considers the input batch of records as
processed successfully and begins reading new records in the stream. If the handler throws an exception,
Lambda considers the input batch of records as not processed and invokes the function with the same
batch of records again.

Using the preceding code (in a le named ProcessKinesisEvents.java), create a deployment package.
Make sure that you add the following dependencies:

aws-lambda-java-core
aws-lambda-java-events

For more information, see Programming Model for Authoring Lambda Functions in Java (p. 24).

Your deployment package can be a .zip le or a standalone .jar. You can use any build and packaging
tool you are familiar with to create a deployment package. For examples of how to use the Maven build
tool to create a standalone .jar, see Creating a .jar Deployment Package Using Maven without any IDE
(Java) (p. 66) and Creating a .jar Deployment Package Using Maven and Eclipse IDE (Java) (p. 68). For an
example of how to use the Gradle build tool to create a .zip le, see Creating a .zip Deployment Package
(Java) (p. 70).

After you verify that your deployment package is created, go to the next step to create an IAM role
(execution role). You specify this role at the time you create your Lambda function.

Next Step

Step 2.2: Create the Execution Role (IAM Role) (p. 222)

C#

The following is example C# code that receives Kinesis event record data as a input and processes it. For
illustration, the code writes some of the incoming event data to CloudWatch Logs.

In the code, HandleKinesisRecord is the handler. The handler uses the predened KinesisEvent class
that is dened in the Amazon.Lambda.KinesisEvents library.

220
AWS Lambda Developer Guide
Tutorial

using System;
using System.IO;
using System.Text;

using Amazon.Lambda.Core;
using Amazon.Lambda.KinesisEvents;

namespace KinesisStreams
{
public class KinesisSample
{
[LambdaSerializer(typeof(JsonSerializer))]
public void HandleKinesisRecord(KinesisEvent kinesisEvent)
{
Console.WriteLine($"Beginning to process {kinesisEvent.Records.Count}
records...");

foreach (var record in kinesisEvent.Records)


{
Console.WriteLine($"Event ID: {record.EventId}");
Console.WriteLine($"Event Name: {record.EventName}");

string recordData = GetRecordContents(record.Kinesis);


Console.WriteLine($"Record Data:");
Console.WriteLine(recordData);
}

Console.WriteLine("Stream processing complete.");


}

private string GetRecordContents(KinesisEvent.Record streamRecord)


{
using (var reader = new StreamReader(streamRecord.Data, Encoding.ASCII))
{
return reader.ReadToEnd();
}
}
}
}

To create a deployment package, follow the steps outlined in .NET Core CLI (p. 61). In doing so, note the
following after you've created your .NET project:

Rename the default Program.cs le with a le name of your choice, such as ProcessingKinesisEvents.cs.
Replace the default contents of the renamed Program.cs le with the code example above.
In the project.json le, make sure the following references are included in the dependencies node.
"Amazon.Lambda.Core": "1.0.0-*"
"Amazon.Lambda.KinesisEvents":"1.0.0-*"
"Amazon.Lambda.Serialization.Json":"1.0.0-*"

After you verify that your deployment package is created, go to the next step to create an IAM role
(execution role). You specify this role at the time you create your Lambda function.

Next Step

Step 2.2: Create the Execution Role (IAM Role) (p. 222)

221
AWS Lambda Developer Guide
Tutorial

Python

The following is example Python code that receives Kinesis event record data as input and processes it.
For illustration, the code writes to some of the incoming event data to CloudWatch Logs.

Follow the instructions to create a AWS Lambda function deployment package.

1. Open a text editor, and then copy the following code.


Note
The from __future__ statement enables you to write code that is compatible with Python 2
or 3. If you are using runtime version 3.6, is not necessary to include it.

from __future__ import print_function


#import json
import base64
def lambda_handler(event, context):
for record in event['Records']:
#Kinesis data is base64 encoded so decode here
payload=base64.b64decode(record["kinesis"]["data"])
print("Decoded payload: " + str(payload))

2. Save the le as ProcessKinesisRecords.py.


3. Zip the ProcessKinesisRecords.py le as ProcessKinesisRecords.zip.

Next Step

Step 2.2: Create the Execution Role (IAM Role) (p. 222)

Step 2.2: Create the Execution Role (IAM Role)


In this section, you create an IAM role using the following predened role type and access policy:

AWS service role of the type AWS Lambda This role grants AWS Lambda permissions to assume the
role.
AWSLambdaKinesisExecutionRole This is the access permissions policy that you attach to the role.

For more information about IAM roles, see IAM Roles in the IAM User Guide. Use the following procedure
to create the IAM role.

To create an IAM role (execution role)

1. Sign in to the AWS Management Console and open the IAM console at https://
console.aws.amazon.com/iam/.
2. Follow the steps in Creating a Role to Delegate Permissions to an AWS Service in the IAM User Guide
to create an IAM role (execution role). As you follow the steps to create a role, note the following:

In Role Name, use a name that is unique within your AWS account (for example, lambda-kinesis-
execution-role).
In Select Role Type, choose AWS Service Roles, and then choose AWS Lambda. This grants the
AWS Lambda service permissions to assume the role.
In Attach Policy, choose AWSLambdaKinesisExecutionRole. The permissions in this policy are
sucient for the Lambda function in this tutorial.
3. Write down the role ARN. You will need it in the next step when you create your Lambda function.

222
AWS Lambda Developer Guide
Tutorial

Next Step

Step 2.3: Create the Lambda Function and Test It Manually (p. 223)

Step 2.3: Create the Lambda Function and Test It Manually


In this section, you do the following:

Create a Lambda function by uploading the deployment package.


Test the Lambda function by invoking it manually. Instead of creating an event source, you use sample
Kinesis event data.

In the next section, you create an Kinesis stream and test the end-to-end experience.

Step 2.3.1: Create a Lambda Function (Upload the Deployment Package)

In this step, you upload the deployment package using the AWS CLI.

At the command prompt, run the following Lambda CLI create-function command using the
adminuser prole. For more information on setting this up, see Conguring the AWS CLI.

You need to update the command by providing the .zip le path and the execution role ARN. The --
runtime parameter value can be python3.6, python2.7, nodejs6.10, nodejs4.3, or java8, depending on
the language you used to author your code.

$ aws lambda create-function \


--region us-west-2 \
--function-name ProcessKinesisRecords \
--zip-file fileb://file-path/ProcessKinesisRecords.zip \
--role execution-role-arn \
--handler handler \
--runtime runtime-value \
--profile adminuser

The --handler parameter value for Java should be example.ProcessKinesisRecords::recordHandler.


For Node.js, it should be ProcessKinesisRecords.handler and for Python it should be
ProcessKinesisRecords.lambda_handler.

Optionally, you can upload the .zip le to an Amazon S3 bucket in the same AWS region, and then
specify the bucket and object name in the preceding command. You need to replace the --zip-file
parameter by the --code parameter, as shown following:

--code S3Bucket=bucket-name,S3Key=zip-file-object-key

Note
You can create the Lambda function using the AWS Lambda console, in which case note the
value of the create-function AWS CLI command parameters. You provide the same values in
the console UI.

Step 2.3.2: Test the Lambda Function (Invoke Manually)

Invoke the function manually using sample Kinesis event data. We recommend that you invoke the
function using the console because the console UI provides a user-friendly interface for reviewing the
execution results, including the execution summary, logs written by your code, and the results returned
by the function (because the console always performs synchronous executioninvokes the Lambda
function using the RequestResponse invocation type).

223
AWS Lambda Developer Guide
Tutorial

To test the Lambda function (console)

1. Follow the steps in the Getting Started to create and invoke the Lambda function at Step 2.2: Invoke
the Lambda Function Manually and Verify Results, Logs, and Metrics (p. 192). For the sample event
for testing, choose Kinesis in Sample event template.
2. Verify the results in the console.

To test the Lambda function (AWS CLI)

1. Copy the following JSON into a le and save it as input.txt.

{
"Records": [
{
"kinesis": {
"partitionKey": "partitionKey-3",
"kinesisSchemaVersion": "1.0",
"data": "SGVsbG8sIHRoaXMgaXMgYSB0ZXN0IDEyMy4=",
"sequenceNumber":
"49545115243490985018280067714973144582180062593244200961"
},
"eventSource": "aws:kinesis",
"eventID":
"shardId-000000000000:49545115243490985018280067714973144582180062593244200961",
"invokeIdentityArn": "arn:aws:iam::account-id:role/testLEBRole",
"eventVersion": "1.0",
"eventName": "aws:kinesis:record",
"eventSourceARN": "arn:aws:kinesis:us-west-2:35667example:stream/
examplestream",
"awsRegion": "us-west-2"
}
]
}

2. Execute the following invoke command:

$ aws lambda invoke \


--invocation-type Event \
--function-name ProcessKinesisRecords \
--region us-west-2 \
--payload file://file-path/input.txt \
--profile adminuser
outputfile.txt

Note
In this tutorial example, the message is saved in the outputfile.txt le. If you request
synchronous execution (RequestResponse as the invocation type), the function returns the
string message in the response body.
For Node.js, it could be one of the following (whatever one you specify in the code):
context.succeed("message")
context.fail("message")
context.done(null, "message)
For Python or Java, it is the message in the return statement:
return "message"

Next Step

Step 3: Add an Event Source (Create an Kinesis Stream and Associate It with Your Lambda
Function) (p. 225)

224
AWS Lambda Developer Guide
Tutorial

Step 3: Add an Event Source (Create an Kinesis Stream and


Associate It with Your Lambda Function)
In this section, you create an Kinesis stream, and then you add an event source in AWS Lambda to
associate the Kinesis stream with your Lambda function.

After you create an event source, AWS Lambda starts polling the stream. You then test the setup by
adding events to the stream and verify that AWS Lambda executed your Lambda function on your
behalf:

Step 3.1: Create an Kinesis Stream


Use the following Kinesis create-stream CLI command to create a stream.

$ aws kinesis create-stream \


--stream-name examplestream \
--shard-count 1 \
--region us-west-2 \
--profile adminuser

Run the following Kinesis describe-stream AWS CLI command to get the stream ARN.

$ aws kinesis describe-stream \


--stream-name examplestream \
--region us-west-2 \
--profile adminuser

You need the stream ARN in the next step to associate the stream with your Lambda function. The
stream is of the form:

arn:aws:kinesis:aws-region:account-id:stream/stream-name

Step 3.2: Add an Event Source in AWS Lambda


Run the following AWS CLI add-event-source command. After the command executes, note down the
UUID. You'll need this UUID to refer to the event source in any commands (for example, when deleting
the event source).

$ aws lambda create-event-source-mapping \


--region us-west-2 \
--function-name ProcessKinesisRecords \
--event-source kinesis-stream-arn \
--batch-size 100 \
--starting-position TRIM_HORIZON \
--profile adminuser

You can get a list of event source mappings by running the following command.

$ aws lambda list-event-source-mappings \


--region us-west-2 \
--function-name ProcessKinesisRecords \
--event-source kinesis-stream-arn \
--profile adminuser \
--debug

225
AWS Lambda Developer Guide
Tutorial

In the response, you can verify the status value is enabled.


Note
If you disable the event source mapping, AWS Lambda stops polling the Kinesis stream. If
you re-enable event source mapping, it will resume polling from the sequence number where
it stopped, so each record is processed either before you disabled the mapping or after you
enabled it. If the sequence number falls behind TRIM_HORIZON, when you re-enable it polling
will start from TRIM_HORIZON. However, if you create a new event source mapping, polling will
always start from TRIM_HORIZON, LATEST or AT_TIMESTAMP, depending on the starting position
you specify. This applies even if you delete an event source mapping and create a new one with
the same conguration as the deleted one.

Step 3.3: Test the Setup


You're all done! Now adminuser can test the setup as follows:

1. Using the following AWS CLI command, add event records to your Kinesis stream. The --data value
is a base64-encoded value of the "Hello, this is a test." string. You can run the same command
more than once to add multiple records to the stream.

$ aws kinesis put-record \


--stream-name examplestream \
--data "This is a test. final" \
--partition-key shardId-000000000000 \
--region us-west-2 \
--profile adminuser

2. AWS Lambda polls the stream and, when it detects updates to the stream, it invokes your Lambda
function by passing in the event data from the stream.

AWS Lambda assumes the execution role to poll the stream. You have granted the role permissions
for the necessary Kinesis actions so that AWS Lambda can poll the stream and read events from the
stream.
3. Your function executes and adds logs to the log group that corresponds to the Lambda function in
Amazon CloudWatch.

The adminuser can also verify the logs reported in the Amazon CloudWatch console. Make sure you
are checking for logs in the same AWS region where you created the Lambda function.

Step 4: Deploy With AWS SAM and AWS CloudFormation


In the previous section, you used AWS Lambda APIs to create and update a Lambda function by
providing a deployment package as a ZIP le. However, this mechanism may not be convenient for
automating deployment steps for functions, or coordinating deployments and updates to other elements
of a serverless application, like event sources and downstream resources.

You can use AWS CloudFormation to easily specify, deploy, and congure serverless applications. AWS
CloudFormation is a service that helps you model and set up your Amazon Web Services resources so
that you can spend less time managing those resources and more time focusing on your applications
that run in AWS. You create a template that describes all the AWS resources that you want (like Lambda
functions and DynamoDB tables), and AWS CloudFormation takes care of provisioning and conguring
those resources for you.

In addition, you can use the AWS Serverless Application Model to express resources that comprise the
serverless application. These resource types, such as Lambda functions and APIs, are fully supported by
AWS CloudFormation and make it easier for you to dene and deploy your serverless application.

For more information, see Deploying Lambda-based Applications (p. 144).

226
AWS Lambda Developer Guide
Amazon DynamoDB

Specication for Kinesis Application


The following contains the SAM template for this application. Copy the text below to a .yaml le and
save it next to the ZIP package you created previously. Note that the Handler and Runtime parameter
values should match the ones you used when you created the function in the previous section.

AWSTemplateFormatVersion: '2010-09-09'
Transform: AWS::Serverless-2016-10-31
Resources:
ProcessKinesisRecords:
Type: AWS::Serverless::Function
Properties:
Handler: handler
Runtime: runtime
Policies: AWSLambdaKinesisExecutionRole
Events:
Stream:
Type: Kinesis
Properties:
Stream: !GetAtt ExampleStream.Arn
BatchSize: 100
StartingPosition: TRIM_HORIZON

ExampleStream:
Type: AWS::Kinesis::Stream
Properties:
ShardCount: 1

Deploying the Serverless Application


For information on how to package and deploy your serverless application using the package and deploy
commands, see Packaging and Deployment (p. 150).

Using AWS Lambda with Amazon DynamoDB


You can use Lambda functions as triggers for your Amazon DynamoDB table. Triggers are custom actions
you take in response to updates made to the DynamoDB table. To create a trigger, rst you enable
Amazon DynamoDB Streams for your table. Then, you write a Lambda function to process the updates
published to the stream.

Note the following about how the Amazon DynamoDB and AWS Lambda integration works:

Stream-based model This is a model (see Event Source Mapping (p. 127)), where AWS Lambda polls
the stream and, when it detects new records, invokes your Lambda function by passing the update
event as parameter.

In a stream-based model, you maintain event source mapping in AWS Lambda. The event source
mapping describes which stream maps to which Lambda function. AWS Lambda provides an API
(CreateEventSourceMapping (p. 361)) for you to create the mapping. You can also use the AWS
Lambda console to create event source mappings.
Synchronous invocation AWS Lambda invokes a Lambda function using the RequestResponse
invocation type (synchronous invocation). For more information about invocation types, see Invocation
Types (p. 4).
Event structure The event your Lambda function receives is the table update information AWS
Lambda reads from your stream. When you congure event source mapping, the batch size you specify
is the maximum number of records that you want your Lambda function to receive per invocation.

227
AWS Lambda Developer Guide
Tutorial

Regardless of what invokes a Lambda function, AWS Lambda always executes a Lambda function on
your behalf. If your Lambda function needs to access any AWS resources, you need to grant the relevant
permissions to access those resources. You also need to grant AWS Lambda permissions to poll your
DynamoDB stream. You grant all of these permissions to an IAM role (execution role) that AWS Lambda
can assume to poll the stream and execute the Lambda function on your behalf. You create this role
rst and then enable it at the time you create the Lambda function. For more information, see Manage
Permissions: Using an IAM Role (Execution Role) (p. 180).

The following diagram illustrates the application ow:

1. Custom app updates the DynamoDB table.


2. Amazon DynamoDB publishes item updates to the stream.
3. AWS Lambda polls the stream and invokes your Lambda function when it detects new records in the
stream.
4. AWS Lambda executes the Lambda function by assuming the execution role you specied at the time
you created the Lambda function.

For a tutorial that walks you through an example setup, see Tutorial: Using AWS Lambda with Amazon
DynamoDB (p. 228).

Tutorial: Using AWS Lambda with Amazon


DynamoDB
In this tutorial, you create a Lambda function to consume events from a DynamoDB stream.

The tutorial is divided into two main sections:

First, you perform the necessary setup to create a Lambda function and then you test it by invoking it
manually using sample event data.
Second, you create an DynamoDB stream-enabled table and add an event source mapping in AWS
Lambda to associate the stream with your Lambda function. AWS Lambda starts polling the stream.
Then, you test the end-to-end setup. As you create, update, and delete items from the table, Amazon
DynamoDB writes records to the stream. AWS Lambda detects the new records as it polls the stream
and executes your Lambda function on your behalf.

Important
Both the Lambda function and the DynamoDB stream must be in the same AWS region. This
tutorial assumes that you create these resources in the us-east-1 region.

In this tutorial, you use the AWS Command Line Interface to perform AWS Lambda operations such
as creating a Lambda function, creating a stream, and adding records to the stream. You use the AWS

228
AWS Lambda Developer Guide
Tutorial

Lambda console to manually invoke the function before you create a DynamoDB stream. You verify
return values and logs in the console UI.

Next Step
Step 1: Prepare (p. 229)

Step 1: Prepare
Make sure you have completed the following steps:

Signed up for an AWS account and created an administrator user in the account.
Installed and set up the AWS CLI.

For instructions, see Step 1: Set Up an AWS Account and the AWS CLI (p. 185).

Next Step
Step 2: Create a Lambda Function and Invoke It Manually (Using Sample Event Data) (p. 229)

Step 2: Create a Lambda Function and Invoke It Manually (Using


Sample Event Data)
In this section, you do the following:

Create a Lambda function deployment package using the sample code provided. The sample Lambda
function code that you'll use to process DynamoDB events is provided in various languages. Select one
of the languages and follow the corresponding instructions to create a deployment package.
Note
To see more examples of using other AWS services within your function, including calling
other Lambda functions, see AWS SDK for JavaScript
Create an IAM role (execution role). At the time you upload the deployment package, you need to
specify an IAM role (execution role) that Lambda can assume to execute the function on your behalf.
For example, AWS Lambda needs permissions for DynamoDB actions so it can poll the stream and read
records from the stream. In the pull model you must also grant AWS Lambda permissions to invoke
your Lambda function. The example Lambda function writes some of the event data to CloudWatch, so
it needs permissions for necessary CloudWatch actions.
Create the Lambda function by uploading the deployment package, and then test it by invoking it
manually using sample DynamoDB event data. You provide both the deployment package and the IAM
role at the time of creating a Lambda function. You can also specify other conguration information,
such as the function name, memory size, runtime environment to use, and the handler. For more
information about these parameters, see CreateFunction (p. 366). After creating the Lambda
function, you invoke it using sample Amazon DynamoDB event data.

Topics
Step 2.1: Create a Lambda Function Deployment Package (p. 229)
Step 2.2: Create the Execution Role (IAM Role) (p. 232)
Step 2.3: Create the Lambda Function and Test It Manually (p. 233)

Step 2.1: Create a Lambda Function Deployment Package


From the Filter View list, choose the language you want to use for your Lambda function. The
appropriate section appears with code and specic instructions for creating a deployment package.

229
AWS Lambda Developer Guide
Tutorial

Node.js

1. Open a text editor, and then copy the following code.

console.log('Loading function');

exports.lambda_handler = function(event, context, callback) {


console.log(JSON.stringify(event, null, 2));
event.Records.forEach(function(record) {
console.log(record.eventID);
console.log(record.eventName);
console.log('DynamoDB Record: %j', record.dynamodb);
});
callback(null, "message");
};

Note
The code sample is compliant with the Node.js runtimes v6.10 or v4.3. For more
information, see Programming Model (Node.js) (p. 9)
2. Save the le as ProcessDynamoDBStream.js.
3. Zip the ProcessDynamoDBStream.js le as ProcessDynamoDBStream.zip.

Next Step

Step 2.2: Create the Execution Role (IAM Role) (p. 232)

Java

In the following code, handleRequest is the handler that AWS Lambda invokes and provides event data.
The handler uses the predened DynamodbEvent class, which is dened in the aws-lambda-java-events
library.

package example;

import com.amazonaws.services.lambda.runtime.Context;
import com.amazonaws.services.lambda.runtime.LambdaLogger;
import com.amazonaws.services.lambda.runtime.RequestHandler;
import com.amazonaws.services.lambda.runtime.events.DynamodbEvent;
import com.amazonaws.services.lambda.runtime.events.DynamodbEvent.DynamodbStreamRecord;

public class DDBEventProcessor implements


RequestHandler<DynamodbEvent, String> {

public String handleRequest(DynamodbEvent ddbEvent, Context context) {


for (DynamodbStreamRecord record : ddbEvent.getRecords()){
System.out.println(record.getEventID());
System.out.println(record.getEventName());
System.out.println(record.getDynamodb().toString());

}
return "Successfully processed " + ddbEvent.getRecords().size() + " records.";
}
}

If the handler returns normally without exceptions, Lambda considers the input batch of records as
processed successfully and begins reading new records in the stream. If the handler throws an exception,
Lambda considers the input batch of records as not processed and invokes the function with the same
batch of records again.

230
AWS Lambda Developer Guide
Tutorial

Using the preceding code (in a le named DDBEventProcessor.java), create a deployment package. Make
sure that you add the following dependencies:

aws-lambda-java-core
aws-lambda-java-events

For more information, see Programming Model for Authoring Lambda Functions in Java (p. 24).

Your deployment package can be a .zip le or a standalone .jar. You can use any build and packaging
tool you are familiar with to create a deployment package. For examples of how to use the Maven build
tool to create a standalone .jar, see Creating a .jar Deployment Package Using Maven without any IDE
(Java) (p. 66) and Creating a .jar Deployment Package Using Maven and Eclipse IDE (Java) (p. 68). For an
example of how to use the Gradle build tool to create a .zip le, see Creating a .zip Deployment Package
(Java) (p. 70).

After you verify that your deployment package is created, go to the next step to create an IAM role
(execution role). You specify this role at the time you create your Lambda function.

Next Step
Step 2.2: Create the Execution Role (IAM Role) (p. 232)

C#
In the following code, ProcessDynamoEvent is the handler that AWS Lambda invokes and provides
event data. The handler uses the predened DynamoDbEvent class, which is dened in the
Amazon.Lambda.DynamoDBEvents library.

using System;
using System.IO;
using System.Text;
using Amazon.Lambda.Core;
using Amazon.Lambda.DynamoDBEvents;

using Amazon.Lambda.Serialization.Json;

namespace DynamoDBStreams
{
public class DdbSample
{
private static readonly JsonSerializer _jsonSerializer = new JsonSerializer();

public void ProcessDynamoEvent(DynamoDBEvent dynamoEvent)


{
Console.WriteLine($"Beginning to process {dynamoEvent.Records.Count}
records...");

foreach (var record in dynamoEvent.Records)


{
Console.WriteLine($"Event ID: {record.EventID}");
Console.WriteLine($"Event Name: {record.EventName}");

string streamRecordJson = SerializeObject(record.Dynamodb);


Console.WriteLine($"DynamoDB Record:");
Console.WriteLine(streamRecordJson);
}

Console.WriteLine("Stream processing complete.");


}

private string SerializeObject(object streamRecord)

231
AWS Lambda Developer Guide
Tutorial

{
using (var ms = new MemoryStream())
{
_jsonSerializer.Serialize(streamRecord, ms);
return Encoding.UTF8.GetString(ms.ToArray());
}
}
}
}

To create a deployment package, follow the steps outlined in .NET Core CLI (p. 61). In doing so, note the
following after you've created your .NET project:

Rename the default Program.cs le with a le name of your choice, such as


ProcessingDynamoDBStreams.cs.
Replace the default contents of the renamed Program.cs le with the code example above.
In the project.json le, add the following references to the dependencies node.
"Amazon.Lambda.Core":"1.0.0-*"
"Amazon.Lambda.Serialiation.Json":"1.0.0-*"
"Amazon.Lambda.DynamoDBEvents":"1.0.0-*"

After you verify that your deployment package is created, go to the next step to create an IAM role
(execution role). You specify this role at the time you create your Lambda function.

Next Step

Step 2.2: Create the Execution Role (IAM Role) (p. 232)

Python

1. Open a text editor, and then copy the following code.


Note
The from __future__ statement enables you to write code that is compatible with Python 2
or 3. If you are using runtime version 3.6, it is not necessary to include it.

from __future__ import print_function

def lambda_handler(event, context):


for record in event['Records']:
print(record['eventID'])
print(record['eventName'])
print('Successfully processed %s records.' % str(len(event['Records'])))

2. Save the le as ProcessDynamoDBStream.py.


3. Zip the ProcessDynamoDBStream.py le as ProcessDynamoDBStream.zip.

Next Step

Step 2.2: Create the Execution Role (IAM Role) (p. 232)

Step 2.2: Create the Execution Role (IAM Role)


In this section, you create an IAM role using the following predened role type and access policy:

AWS service role of the type AWS Lambda This role grants AWS Lambda permissions to assume the
role.

232
AWS Lambda Developer Guide
Tutorial

AWSLambdaDynamoDBExecutionRole This is the access permissions policy that you attach to the
role.

For more information about IAM roles, see IAM Roles in the IAM User Guide. Use the following procedure
to create the IAM role.

To create an IAM role (execution role)

1. Sign in to the AWS Management Console and open the IAM console at https://
console.aws.amazon.com/iam/.
2. Follow the steps in Creating a Role to Delegate Permissions to an AWS Service in the IAM User Guide
to create an IAM role (execution role). As you follow the steps to create a role, note the following:

In Role Name, use a name that is unique within your AWS account (for example, lambda-
dynamodb-execution-role).
In Select Role Type, choose AWS Service Roles, and then choose AWS Lambda. This grants the
AWS Lambda service permissions to assume the role.
In Attach Policy, choose AWSLambdaDynamoDBExecutionRole. The permissions in this policy
are sucient for the Lambda function in this tutorial.
3. Write down the role ARN. You will need it in the next step when you create your Lambda function.

Next Step
Step 2.3: Create the Lambda Function and Test It Manually (p. 233)

Step 2.3: Create the Lambda Function and Test It Manually


In this section, you do the following:

Create a Lambda function by uploading the deployment package.


Test the Lambda function by invoking it manually. Instead of creating an event source, you use sample
DynamoDB event data.

In the next section, you create an DynamoDB stream and test the end-to-end experience.

Step 2.3.1: Create a Lambda Function (Upload the Deployment Package)


In this step, you upload the deployment package using the AWS CLI.

At the command prompt, run the following Lambda CLI create-function command using the
adminuser prole.

You need to update the command by providing the .zip le path and the execution role ARN. The --
runtime parameter value can be python3.6, python2.7, nodejs6.10 nodejs4.3, or java8, depending on
the language you used to author your code.

$ aws lambda create-function \


--region us-east-1 \
--function-name ProcessDynamoDBStream \
--zip-file fileb://file-path/ProcessDynamoDBStream.zip \
--role role-arn \
--handler ProcessDynamoDBStream.lambda_handler \
--runtime runtime-value \
--profile adminuser

Note
If you choose Java 8 as the runtime, the handler value must be packageName::methodName.

233
AWS Lambda Developer Guide
Tutorial

For more information, see CreateFunction (p. 366). AWS Lambda creates the function and returns
function conguration information.

Optionally, you can upload the .zip le to an Amazon S3 bucket in the same AWS region, and then
specify the bucket and object name in the preceding command. You need to replace the --zip-file
parameter by the --code parameter, as shown following:

--code S3Bucket=bucket-name,S3Key=zip-file-object-key

Step 2.3.2: Test the Lambda Function (Invoke Manually)

In this step, you invoke your Lambda function manually using the invoke AWS Lambda CLI command and
the following sample DynamoDB event.

1. Copy the following JSON into a le and save it as input.txt.

{
"Records":[
{
"eventID":"1",
"eventName":"INSERT",
"eventVersion":"1.0",
"eventSource":"aws:dynamodb",
"awsRegion":"us-east-1",
"dynamodb":{
"Keys":{
"Id":{
"N":"101"
}
},
"NewImage":{
"Message":{
"S":"New item!"
},
"Id":{
"N":"101"
}
},
"SequenceNumber":"111",
"SizeBytes":26,
"StreamViewType":"NEW_AND_OLD_IMAGES"
},
"eventSourceARN":"stream-ARN"
},
{
"eventID":"2",
"eventName":"MODIFY",
"eventVersion":"1.0",
"eventSource":"aws:dynamodb",
"awsRegion":"us-east-1",
"dynamodb":{
"Keys":{
"Id":{
"N":"101"
}
},
"NewImage":{
"Message":{
"S":"This item has changed"
},
"Id":{
"N":"101"
}

234
AWS Lambda Developer Guide
Tutorial

},
"OldImage":{
"Message":{
"S":"New item!"
},
"Id":{
"N":"101"
}
},
"SequenceNumber":"222",
"SizeBytes":59,
"StreamViewType":"NEW_AND_OLD_IMAGES"
},
"eventSourceARN":"stream-ARN"
},
{
"eventID":"3",
"eventName":"REMOVE",
"eventVersion":"1.0",
"eventSource":"aws:dynamodb",
"awsRegion":"us-east-1",
"dynamodb":{
"Keys":{
"Id":{
"N":"101"
}
},
"OldImage":{
"Message":{
"S":"This item has changed"
},
"Id":{
"N":"101"
}
},
"SequenceNumber":"333",
"SizeBytes":38,
"StreamViewType":"NEW_AND_OLD_IMAGES"
},
"eventSourceARN":"stream-ARN"
}
]
}

2. Execute the following invoke command.

$ aws lambda invoke \


--invocation-type RequestResponse \
--function-name ProcessDynamoDBStream \
--region us-east-1 \
--payload file://file-path/input.txt \
--profile adminuser \
outputfile.txt

Note that the invoke command species the RequestResponse as the invocation type, which
requests synchronous execution. For more information, see Invoke (p. 401). The function returns
the string message (message in the context.succeed() in the code) in the response body.
3. Verify the output in the outputfile.txt le.

You can monitor the activity of your Lambda function in the AWS Lambda console.

235
AWS Lambda Developer Guide
Tutorial

The AWS Lambda console shows a graphical representation of some of the CloudWatch metrics
in the Cloudwatch Metrics at a glance section for your function. Sign in to the AWS Management
Console at https://console.aws.amazon.com/.
For each graph you can also click the logs link to view the CloudWatch logs directly.

Next Step

Step 3: Add an Event Source (Create a DynamoDB Stream and Associate It with Your Lambda
Function) (p. 236)

Step 3: Add an Event Source (Create a DynamoDB Stream and


Associate It with Your Lambda Function)
In this section, you do the following:

Create an Amazon DynamoDB table with a stream enabled.


Create an event source mapping in AWS Lambda. This event source mapping associates the DynamoDB
stream with your Lambda function. After you create this event source mapping, AWS Lambda starts
polling the stream.
Test the end-to-end experience. As you perform table updates, DynamoDB writes event records to
the stream. As AWS Lambda polls the stream, it detects new records in the stream and executes your
Lambda function on your behalf by passing events to the function.

Step 3.1: Create a DynamoDB Table with a Stream Enabled


Follow the procedure to create a table with a stream:

1. Sign in to the AWS Management Console and open the DynamoDB console at https://
console.aws.amazon.com/dynamodb/.
2. In the DynamoDB console, create a table with streams enabled. For more information on enabling
streams, see Capturing Table Activity with DynamoDB Streams.
Important
You must create a DynamoDB table in the same region where you created the Lambda
function. This tutorial assumes the US East (N. Virginia) region. In addition, both the table
and the Lambda functions must belong to the same AWS account.
3. Write down the stream ARN. You need this in the next step when you associate the stream with your
Lambda function.

Step 3.2: Add an Event Source in AWS Lambda


Run the following AWS CLI create-event-source-mapping command. After the command executes,
note down the UUID. You'll need this UUID to refer to the event source mapping in any commands, for
example, when deleting the event source mapping.

$ aws lambda create-event-source-mapping \


--region us-east-1 \
--function-name ProcessDynamoDBStream \
--event-source DynamoDB-stream-arn \
--batch-size 100 \
--starting-position TRIM_HORIZON \
--profile adminuser

236
AWS Lambda Developer Guide
Tutorial

Note
This creates a mapping between the specied DynamoDB stream and the Lambda function.
You can associate a DynamoDB stream with multiple Lambda functions, and associate the same
Lambda function with multiple streams. However, the Lambda functions will share the read
throughput for the stream they share.

You can get the list of event source mappings by running the following command.

$ aws lambda list-event-source-mappings \


--region us-east-1 \
--function-name ProcessDynamoDBStream \
--event-source DynamoDB-stream-arn \
--profile adminuser

The list returns all of the event source mappings you created, and for each mapping it shows the
LastProcessingResult, among other things. This eld is used to provide an informative message if
there are any problems. Values such as No records processed (indicates that AWS Lambda has not
started polling or that there are no records in the stream) and OK (indicates AWS Lambda successfully
read records from the stream and invoked your Lambda function) indicate that there no issues. If there
are issues, you receive an error message.

Step 3.3: Test the Setup


You're all done! Now adminuser can test the setup as follows:

1. In the DynamoDB console, add, update, delete items to the table. DynamoDB writes records of these
actions to the stream.
2. AWS Lambda polls the stream and when it detects updates to the stream, it invokes your Lambda
function by passing in the event data it nds in the stream.
3. Your function executes and creates logs in Amazon CloudWatch. The adminuser can also verify the
logs reported in the Amazon CloudWatch console.

Step 4: Deploy With AWS SAM and AWS CloudFormation


In the previous section, you used AWS Lambda APIs to create and update a Lambda function by
providing a deployment package as a ZIP le. However, this mechanism may not be convenient for
automating deployment steps for functions, or coordinating deployments and updates to other elements
of a serverless application, like event sources and downstream resources.

You can use AWS CloudFormation to easily specify, deploy, and congure serverless applications. AWS
CloudFormation is a service that helps you model and set up your Amazon Web Services resources so
that you can spend less time managing those resources and more time focusing on your applications
that run in AWS. You create a template that describes all the AWS resources that you want (like Lambda
functions and DynamoDB tables), and AWS CloudFormation takes care of provisioning and conguring
those resources for you.

In addition, you can use the AWS Serverless Application Model to express resources that comprise the
serverless application. These resource types, such as Lambda functions and APIs, are fully supported by
AWS CloudFormation and make it easier for you to dene and deploy your serverless application.

For more information, see Deploying Lambda-based Applications (p. 144).

Specication for DynamoDB Application


The following contains the SAM template for this application. Copy the text below to a .yaml le and
save it next to the ZIP package you created previously. Note that the Handler and Runtime parameter
values should match the ones you used when you created the function in the previous section.

237
AWS Lambda Developer Guide
AWS CloudTrail

AWSTemplateFormatVersion: '2010-09-09'
Transform: AWS::Serverless-2016-10-31
Resources:
ProcessDynamoDBStream:
Type: AWS::Serverless::Function
Properties:
Handler: handler
Runtime: runtime
Policies: AWSLambdaDynamoDBExecutionRole
Events:
Stream:
Type: DynamoDB
Properties:
Stream: !GetAtt DynamoDBTable.StreamArn
BatchSize: 100
StartingPosition: TRIM_HORIZON

DynamoDBTable:
Type: AWS::DynamoDB::Table
Properties:
AttributeDefinitions:
- AttributeName: id
AttributeType: S
KeySchema:
- AttributeName: id
KeyType: HASH
ProvisionedThroughput:
ReadCapacityUnits: 5
WriteCapacityUnits: 5
StreamSpecification:
StreamViewType: NEW_IMAGE

Deploying the Serverless Application


For information on how to package and deploy your serverless application using the package and deploy
commands, see Packaging and Deployment (p. 150).

Using AWS Lambda with AWS CloudTrail


You can enable CloudTrail in your AWS account to get logs of API calls and related events history in your
account. CloudTrail records all of the API access events as objects in your Amazon S3 bucket that you
specify at the time you enable CloudTrail.

You can take advantage of Amazon S3's bucket notication feature and direct Amazon S3 to publish
object-created events to AWS Lambda. Whenever CloudTrail writes logs to your S3 bucket, Amazon S3
can then invoke your Lambda function by passing the Amazon S3 object-created event as a parameter.
The S3 event provides information, including the bucket name and key name of the log object that
CloudTrail created. Your Lambda function code can read the log object and process the access records
logged by CloudTrail. For example, you might write Lambda function code to notify you if specic API
call was made in your account.

In this scenario, you enable CloudTrail so it can write access logs to your S3 bucket. As for AWS Lambda,
Amazon S3 is the event source so Amazon S3 publishes events to AWS Lambda and invokes your Lambda
function.
Note
Amazon S3 can only support one event destination.

For detailed information about how to congure Amazon S3 as the event source, see Using AWS Lambda
with Amazon S3 (p. 200).

238
AWS Lambda Developer Guide
Tutorial

The following diagram summarizes the ow:

1. AWS CloudTrail saves logs to an S3 bucket (object-created event).


2. Amazon S3 detects the object-created event.
3. Amazon S3 publishes the s3:ObjectCreated:* event to AWS Lambda by invoking the Lambda
function, as specied in the bucket notication conguration. Because the Lambda function's access
permissions policy includes permissions for Amazon S3 to invoke the function, Amazon S3 can invoke
the function.
4. AWS Lambda executes the Lambda function by assuming the execution role that you specied at the
time you created the Lambda function.
5. The Lambda function reads the Amazon S3 event it receives as a parameter, determines where the
CloudTrail object is, reads the CloudTrail object, and then it processes the log records in the CloudTrail
object.
6. If the log includes a record with specic eventType and eventSource values, it publishes the event to
your Amazon SNS topic. In Tutorial: Using AWS Lambda with AWS CloudTrail (p. 239), you subscribe
to the SNS topic using the email protocol, so you get email notications.

For a tutorial that walks you through an example scenario, see Tutorial: Using AWS Lambda with AWS
CloudTrail (p. 239).

Tutorial: Using AWS Lambda with AWS CloudTrail


Suppose you have turned on AWS CloudTrail for your AWS account to maintain records (logs) of AWS
API calls made on your account and you want to be notied anytime an API call is made to create an
SNS topic. As API calls are made in your account, CloudTrail writes logs to an Amazon S3 bucket that you
congured. In this scenario, you want Amazon S3 to publish the object-created events to AWS Lambda
and invoke your Lambda function as CloudTrail creates log objects.

When Amazon S3 invokes your Lambda function, it passes an S3 event identifying, among other things,
the bucket name and key name of the object that CloudTrail created. Your Lambda function can read the
log object, and it knows the API calls that were reported in the log.

Each object CloudTrail creates in your S3 bucket is a JSON object, with one or more event records. Each
record, among other things, provides eventSource and eventName.

239
AWS Lambda Developer Guide
Tutorial

"Records":[

{
"eventVersion":"1.02",
"userIdentity":{
...
},
"eventTime":"2014-12-16T19:17:43Z",
"eventSource":"sns.amazonaws.com",
"eventName":"CreateTopic",
"awsRegion":"us-west-2",
"sourceIPAddress":"72.21.198.64",
...
},
{
...
},
...
}

For illustration, the Lambda function noties you by email if an API call to create an Amazon SNS topic
is reported in the log. That is, when your Lambda function parses the log, it looks for records with the
following:

eventSource = "sns.amazonaws.com"
eventName = "CreateTopic"

If found, it publishes the event to your Amazon SNS topic (you congure this topic to notify you by
email).

Implementation Summary
Upon completing this tutorial, you will have Amazon S3, AWS Lambda, Amazon SNS, and AWS Identity
and Access Management (IAM) resources in your account:
Note
This tutorial assumes that you create these resources in the us-west-2 region.

In Lambda:

A Lambda function.
An access policy associated with your Lambda function You grant Amazon S3 permissions to invoke
the Lambda function using this permissions policy. You will also restrict the permissions so that
Amazon S3 can invoke the Lambda function only for object-created events from a specic bucket that
is owned by a specic AWS account.
Note
It is possible for an AWS account to delete a bucket and some other AWS account to later
create a bucket with same name. The additional conditions ensure that Amazon S3 can invoke
the Lambda function only if Amazon S3 detects object-created events from a specic bucket
owned by a specic AWS account.

For more information, see How It Works (p. 175).

In IAM:

An IAM role (execution role) You grant permissions that your Lambda function needs through the
permissions policy associated with this role.

240
AWS Lambda Developer Guide
Tutorial

In Amazon S3:

A bucket In this tutorial, the bucket name is examplebucket. When you turn the trail on in the
CloudTrail console, you specify this bucket for CloudTrail to save the logs.
Notication conguration on the examplebucket In the conguration, you direct Amazon S3 to
publish object-created events to Lambda, by invoking your Lambda function. For more information
about the Amazon S3 notication feature, see Setting Up Notication of Bucket Events in Amazon
Simple Storage Service Developer Guide.
Sample CloudTrail log object (ExampleCloudTrailLog.json) in examplebucket bucket In the rst
half of this exercise, you create and test your Lambda function by manually invoking it using a sample
S3 event. This sample event identies examplebucket as the bucket name and this sample object key
name. Your Lambda function then reads the object and sends you email notications using an SNS
topic.

In Amazon SNS

An SNS topic You subscribe to this topic by specifying email as the protocol.

Now you are ready to start the tutorial.

Next Step
Step 1: Prepare (p. 241)

Step 1: Prepare
In this section you do the following:

Sign up for an AWS account and set up the AWS CLI.


Turn on CloudTrail in your account.
Create an SNS topic and subscribe to it.

Follow the steps in the following sections to walk through the setup process.
Note
In this tutorial, we assume that you are setting the resources in the us-west-2 region.

Step 1.1: Sign Up for AWS and Set Up the AWS CLI
Make sure you have completed the following steps:

Signed up for an AWS account and created an administrator user in the account (called adminuser).
Installed and set up the AWS CLI.

For instructions, see Step 1: Set Up an AWS Account and the AWS CLI (p. 185).

Step 1.2: Turn on CloudTrail


In the AWS CloudTrail console, turn on the trail in your account by specifying examplebucket in the us-
west-2 region for CloudTrail to save logs. When conguring the trail, do not enable SNS notication.

For instructions, see Creating and Updating Your Trail in the AWS CloudTrail User Guide.

241
AWS Lambda Developer Guide
Tutorial

Note
Although you turn CloudTrail on now, you do not perform any additional conguration for your
Lambda function to process the real CloudTrail logs in the rst half of this exercise. Instead, you
will use sample CloudTrail log objects (that you will upload) and sample S3 events to manually
invoke and test your Lambda function. In the second half of this tutorial, you perform additional
conguration steps that enable your Lambda function to process the CloudTrail logs.

Step 1.3: Create an SNS Topic and Subscribe to the Topic


Follow the procedure to create an SNS topic in the us-west-2 region and subscribe to it by providing an
email address as the endpoint.

To create and subscribe to a topic

1. Create an SNS topic.

For instructions, see Create a Topic in the Amazon Simple Notication Service Developer Guide.
2. Subscribe to the topic by providing an email address as the endpoint.

For instructions, see Subscribe to a Topic in the Amazon Simple Notication Service Developer Guide.
3. Note down the topic ARN. You will need the value in the following sections.

Next Step
Step 2: Create a Lambda Function and Invoke It Manually (Using Sample Event Data) (p. 242)

Step 2: Create a Lambda Function and Invoke It Manually (Using


Sample Event Data)
In this section, you do the following:

Create a Lambda function deployment package using the sample code provided. The sample Lambda
function code that you'll use to process Amazon S3 events is provided in various languages. Select one
of the languages and follow the corresponding instructions to create a deployment package.
Note
Your Lambda function uses an S3 event that provides the bucket name and key name of the
object CloudTrail created. Your Lambda function then reads that object to process CloudTrail
records.
Create an IAM role (execution role). At the time you upload the deployment package, you need to
specify an IAM role (execution role) that Lambda can assume to execute the function on your behalf.
Create the Lambda function by uploading the deployment package, and then test it by invoking it
manually using sample CloudTrail event data.

Topics
Step 2.1: Create a Deployment Package (p. 242)
Step 2.2: Create the Execution Role (IAM Role) (p. 244)
Step 2.3: Create the Lambda Function and Test It Manually (p. 245)

Step 2.1: Create a Deployment Package


The deployment package is a .zip le containing your Lambda function code. For this tutorial, you will
need to install the async library. To do this, open a command window and navigate to the directory

242
AWS Lambda Developer Guide
Tutorial

where you intend to store the code le you will copy and save below. Use npm to install the async library
as shown below :

npm install async

Node.js

1. Open a text editor, and then copy the following code.

var aws = require('aws-sdk');


var zlib = require('zlib');
var async = require('async');

var EVENT_SOURCE_TO_TRACK = /sns.amazonaws.com/;


var EVENT_NAME_TO_TRACK = /CreateTopic/;
var DEFAULT_SNS_REGION = 'us-west-2';
var SNS_TOPIC_ARN = 'The ARN of your SNS topic';

var s3 = new aws.S3();


var sns = new aws.SNS({
apiVersion: '2010-03-31',
region: DEFAULT_SNS_REGION
});

exports.handler = function(event, context, callback) {


var srcBucket = event.Records[0].s3.bucket.name;
var srcKey = event.Records[0].s3.object.key;

async.waterfall([
function fetchLogFromS3(next){
console.log('Fetching compressed log from S3...');
s3.getObject({
Bucket: srcBucket,
Key: srcKey
},
next);
},
function uncompressLog(response, next){
console.log("Uncompressing log...");
zlib.gunzip(response.Body, next);
},
function publishNotifications(jsonBuffer, next) {
console.log('Filtering log...');
var json = jsonBuffer.toString();
console.log('CloudTrail JSON from S3:', json);
var records;
try {
records = JSON.parse(json);
} catch (err) {
next('Unable to parse CloudTrail JSON: ' + err);
return;
}
var matchingRecords = records
.Records
.filter(function(record) {
return record.eventSource.match(EVENT_SOURCE_TO_TRACK)
&& record.eventName.match(EVENT_NAME_TO_TRACK);
});

console.log('Publishing ' + matchingRecords.length + ' notification(s) in


parallel...');
async.each(
matchingRecords,
function(record, publishComplete) {
console.log('Publishing notification: ', record);

243
AWS Lambda Developer Guide
Tutorial

sns.publish({
Message:
'Alert... SNS topic created: \n TopicARN=' +
record.responseElements.topicArn + '\n\n' +
JSON.stringify(record),
TopicArn: SNS_TOPIC_ARN
}, publishComplete);
},
next
);
}
], function (err) {
if (err) {
console.error('Failed to publish notifications: ', err);
} else {
console.log('Successfully published all notifications.');
}
callback(null,"message");
});
};

Note
The code sample is compliant with the Node.js runtimes v6.10 or v4.3. For more
information, see Programming Model (Node.js) (p. 9)
2. Save the le as CloudTrailEventProcessing.js.
3. Zip the CloudTrailEventProcessing.js le as CloudTrailEventProcessing.zip.

Note
We're using Node.js in this tutorial example, but you can author your Lambda functions in Java
or Python too.

Next Step
Step 2.2: Create the Execution Role (IAM Role) (p. 244)

Step 2.2: Create the Execution Role (IAM Role)


Now you create an IAM role (execution role) that you specify when creating your Lambda function. This
role has a permissions policy that grant the necessary permissions that your Lambda function needs,
such as permissions to write CloudWatch logs, permissions to read CloudTrail log objects from an S3
bucket, and permissions to publish events to your SNS topic when your Lambda function nds specic
API calls in the CloudTrail records.

For more information about the execution role, see Manage Permissions: Using an IAM Role (Execution
Role) (p. 180).

To create an IAM role (execution role)

1. Sign in to the AWS Management Console and open the IAM console at https://
console.aws.amazon.com/iam/.
2. Create a managed policy and attach it to the IAM role. In this step, you modify an existing AWS
Managed Policy, save it using a dierent name, and then attach the permissions policy to an IAM
role that you create.

a. In the navigation pane of the IAM console, choose Policies, and then choose Create Policy.
b. Next to Copy an AWS Managed Policy, choose Select.
c. Next to AWSLambdaExecute, choose Select.
d. Copy the following policy into the Policy Document, replacing the existing policy, and then
update the policy with the ARN of the Amazon SNS topic that you created.

244
AWS Lambda Developer Guide
Tutorial

{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"logs:*"
],
"Resource": "arn:aws:logs:*:*:*"
},
{
"Effect": "Allow",
"Action": [
"s3:GetObject"
],
"Resource": "arn:aws:s3:::examplebucket/*"
},
{
"Effect": "Allow",
"Action": [
"sns:Publish"
],
"Resource": "your sns topic ARN"
}
]
}

3. Note the permissions policy name because you will use it in the next step.
4. Follow the steps in Creating a Role to Delegate Permissions to an AWS Service in the IAM User Guide
to create an IAM role and then attach the permissions policy you just created to the role. As you
follow the steps to create a role, note the following:

In Role Name, use a name that is unique within your AWS account (for example, lambda-
cloudtrail-execution-role).
In Select Role Type, choose AWS Service Roles, and then choose AWS Lambda.
In Attach Policy, choose the policy you created in the previous step.

Next Step

Step 2.3: Create the Lambda Function and Test It Manually (p. 245)

Step 2.3: Create the Lambda Function and Test It Manually


In this section, you do the following:

Create a Lambda function by uploading the deployment package.


Test the Lambda function by invoking it manually.

In this step, you use a sample S3 event that identies your bucket name and the sample object (that
is, an example CloudTrail log). In the next section you congure your S3 bucket notication to publish
object-created events and test the end-to-end experience.

Step 2.3.1: Create the Lambda Function (Upload the Deployment Package)

In this step, you upload the deployment package using the AWS CLI and provide conguration
information when you create the Lambda function. At the command prompt, run the following Lambda
CLI create-function command using the adminuser profile.

245
AWS Lambda Developer Guide
Tutorial

Note
You need to update the command by providing the .zip le path (//file-path/
CloudTrailEventProcessing.zip \) and the execution role ARN (execution-role-arn). If you
used the sample code provided earlier in this tutorial, set the --runtime parameter value to
nodejs6.10 or nodejs4.3.
You can author your Lambda functions in Java or Python too. If you use another language,
change the --runtime parameter value to java8, python3.6 or python2.7 as needed.

$ aws lambda create-function \


--region us-west-2 \
--function-name CloudTrailEventProcessing \
--zip-file fileb://file-path/CloudTrailEventProcessing.zip \
--role execution-role-arn \
--handler CloudTrailEventProcessing.handler \
--runtime nodejs6.10 \
--profile adminuser \
--timeout 10 \
--memory-size 1024

Optionally, you can upload the .zip le to an Amazon S3 bucket in the same AWS region, and then
specify the bucket and object name in the preceding command. You need to replace the --zip-file
parameter by the --code parameter as shown:

--code S3Bucket=bucket-name,S3Key=zip-file-object-key

Note
You can create the Lambda function using the AWS Lambda console, in which case note the
value of the create-function AWS CLI command parameters. You provide the same values in
the console.

Step 2.3.2: Test the Lambda Function (Invoke Manually)

In this section, you invoke the Lambda function manually using sample Amazon S3 event data. When
the Lambda function executes, it reads the S3 object (a sample CloudTrail log) from the bucket identied
in the S3 event data, and then it publishes an event to your SNS topic if the sample CloudTrail log
reports use a specic API. For this tutorial, the API is the SNS API used to create a topic. That is, the
CloudTrail log reports a record identifying sns.amazonaws.com as the eventSource, and CreateTopic as
the eventName.

1. Save the following sample CloudTrail log to a le (ExampleCloudTrailLog.json).


Note
Note that one of events in this log has sns.amazonaws.com as the eventSource and
CreateTopic as the eventName. Your Lambda function reads the logs and if it nds an event
of this type, it publishes the event to the Amazon SNS topic that you created and then you
receive one email when you invoke the Lambda function manually.

{
"Records":[
{
"eventVersion":"1.02",
"userIdentity":{
"type":"Root",
"principalId":"account-id",
"arn":"arn:aws:iam::account-id:root",
"accountId":"account-id",
"accessKeyId":"access-key-id",
"sessionContext":{
"attributes":{

246
AWS Lambda Developer Guide
Tutorial

"mfaAuthenticated":"false",
"creationDate":"2015-01-24T22:41:54Z"
}
}
},
"eventTime":"2015-01-24T23:26:50Z",
"eventSource":"sns.amazonaws.com",
"eventName":"CreateTopic",
"awsRegion":"us-west-2",
"sourceIPAddress":"205.251.233.176",
"userAgent":"console.amazonaws.com",
"requestParameters":{
"name":"dropmeplease"
},
"responseElements":{
"topicArn":"arn:aws:sns:us-west-2:account-id:exampletopic"
},
"requestID":"3fdb7834-9079-557e-8ef2-350abc03536b",
"eventID":"17b46459-dada-4278-b8e2-5a4ca9ff1a9c",
"eventType":"AwsApiCall",
"recipientAccountId":"account-id"
},
{
"eventVersion":"1.02",
"userIdentity":{
"type":"Root",
"principalId":"account-id",
"arn":"arn:aws:iam::account-id:root",
"accountId":"account-id",
"accessKeyId":"access-key-id",
"sessionContext":{
"attributes":{
"mfaAuthenticated":"false",
"creationDate":"2015-01-24T22:41:54Z"
}
}
},
"eventTime":"2015-01-24T23:27:02Z",
"eventSource":"sns.amazonaws.com",
"eventName":"GetTopicAttributes",
"awsRegion":"us-west-2",
"sourceIPAddress":"205.251.233.176",
"userAgent":"console.amazonaws.com",
"requestParameters":{
"topicArn":"arn:aws:sns:us-west-2:account-id:exampletopic"
},
"responseElements":null,
"requestID":"4a0388f7-a0af-5df9-9587-c5c98c29cbec",
"eventID":"ec5bb073-8fa1-4d45-b03c-f07b9fc9ea18",
"eventType":"AwsApiCall",
"recipientAccountId":"account-id"
}
]
}

2. Run the gzip command to create a .gz le from the preceding source le.

$ gzip ExampleCloudTrailLog.json

This creates ExampleCloudTrailLog.json.gz le.


3. Upload the ExampleCloudTrailLog.json.gz le to the examplebucket that you specied in the
CloudTrail conguration.

247
AWS Lambda Developer Guide
Tutorial

This object is specied in the sample Amazon S3 event data that we use to manually invoke the
Lambda function.
4. Save the following JSON (an example S3 event) in a le, input.txt. Note the bucket name and the
object key name values.

You provide this sample event when you invoke your Lambda function. For more information about
the S3 event structure, see Event Message Structure in the Amazon Simple Storage Service Developer
Guide.

{
"Records":[
{
"eventVersion":"2.0",
"eventSource":"aws:s3",
"awsRegion":"us-west-2",
"eventTime":"1970-01-01T00:00:00.000Z",
"eventName":"ObjectCreated:Put",
"userIdentity":{
"principalId":"AIDAJDPLRKLG7UEXAMPLE"
},
"requestParameters":{
"sourceIPAddress":"127.0.0.1"
},
"responseElements":{
"x-amz-request-id":"C3D13FE58DE4C810",
"x-amz-id-2":"FMyUVURIY8/IgAtTv8xRjskZQpcIZ9KG4V5Wp6S7S/
JRWeUWerMUE5JgHvANOjpD"
},
"s3":{
"s3SchemaVersion":"1.0",
"configurationId":"testConfigRule",
"bucket":{
"name":"your bucket name",
"ownerIdentity":{
"principalId":"A3NL1KOZZKExample"
},
"arn":"arn:aws:s3:::mybucket"
},
"object":{
"key":"ExampleCloudTrailLog.json.gz",
"size":1024,
"eTag":"d41d8cd98f00b204e9800998ecf8427e",
"versionId":"096fKKXTRTtl3on89fVO.nfljtsv6qko"
}
}
}
]
}

5. In the AWS Management Console, invoke the function manually using sample Amazon S3 event
data. For instructions, see the Getting Started exercise Step 2.2: Invoke the Lambda Function
Manually and Verify Results, Logs, and Metrics (p. 192). In the console, use the following sample
Amazon S3 event data.
Note
We recommend that you invoke the function using the console because the console
UI provides a user-friendly interface for reviewing the execution results, including the
execution summary, logs written by your code, and the results returned by the function
(because the console always performs synchronous executioninvokes the Lambda
function using the RequestResponse invocation type).

248
AWS Lambda Developer Guide
Tutorial

{
"Records":[
{
"eventVersion":"2.0",
"eventSource":"aws:s3",
"awsRegion":"us-west-2",
"eventTime":"1970-01-01T00:00:00.000Z",
"eventName":"ObjectCreated:Put",
"userIdentity":{
"principalId":"AIDAJDPLRKLG7UEXAMPLE"
},
"requestParameters":{
"sourceIPAddress":"127.0.0.1"
},
"responseElements":{
"x-amz-request-id":"C3D13FE58DE4C810",
"x-amz-id-2":"FMyUVURIY8/IgAtTv8xRjskZQpcIZ9KG4V5Wp6S7S/
JRWeUWerMUE5JgHvANOjpD"
},
"s3":{
"s3SchemaVersion":"1.0",
"configurationId":"testConfigRule",
"bucket":{
"name":"your bucket name",
"ownerIdentity":{
"principalId":"A3NL1KOZZKExample"
},
"arn":"arn:aws:s3:::mybucket"
},
"object":{
"key":"ExampleCloudTrailLog.json.gz",
"size":1024,
"eTag":"d41d8cd98f00b204e9800998ecf8427e",
"versionId":"096fKKXTRTtl3on89fVO.nfljtsv6qko"
}
}
}
]
}

6. Execute the following AWS CLI command to invoke the function manually using the adminuser
profile.

$ aws lambda invoke-async \


--function-name CloudTrailEventProcessing \
--region us-west-2 \
--invoke-args /filepath/input.txt \
--debug \
--profile adminuser

Because your example log object has an event record showing the SNS API to call to create a topic,
the Lambda function posts that event to your SNS topic, and you should get an email notication.

You can monitor the activity of your Lambda function by using CloudWatch metrics and logs. For
more information about CloudWatch monitoring, see Troubleshooting and Monitoring AWS Lambda
Functions with Amazon CloudWatch (p. 114).
7. (Optional) Manually invoke the Lambda function using AWS CLI as follows:

a. Save the JSON from Step 2 earlier in this procedure to a le called input.txt.
b. Execute the following invoke command:

249
AWS Lambda Developer Guide
Tutorial

$ aws lambda invoke \


--invocation-type Event \
--function-name CloudTrailEventProcessing \
--region us-west-2 \
--payload file://file-path/input.txt \
--profile adminuser
outputfile.txt

Note
In this tutorial example, the message is saved in the outputfile.txt le. If you request
synchronous execution (RequestResponse as the invocation type), the function returns
the string message in the response body.
For Node.js, it could be one of the following (whatever one you specify in the code):
context.succeed("message")
context.fail("message")
context.done(null, "message)
For Python or Java, it is the message in the return statement:
return "message"

Next Step

Step 3: Add Event Source (Congure Amazon S3 to Publish Events) (p. 250)

Step 3: Add Event Source (Congure Amazon S3 to Publish


Events)
In this section, you add the remaining conguration so Amazon S3 can publish object-created events to
AWS Lambda and invoke your Lambda function. You will do the following:

Add permissions to the Lambda function's access policy to allow Amazon S3 to invoke the function.
Add notication conguration to your source bucket. In the notication conguration, you provide the
following:
Event type for which you want Amazon S3 to publish events. For this tutorial, you specify the
s3:ObjectCreated:*event type.
Lambda function to invoke.

Step 3.1: Add Permissions to the Lambda Function's Access Permissions Policy
1. Run the following Lambda CLI add-permission command to grant Amazon S3 service principal
(s3.amazonaws.com) permissions to perform the lambda:InvokeFunction action. Note that
permission is granted to Amazon S3 to invoke the function only if the following conditions are met:

An object-created event is detected on a specic bucket.


The bucket is owned by a specic AWS account. If a bucket owner deletes a bucket, some other
AWS account can create a bucket with the same name. This condition ensures that only a specic
AWS account can invoke your Lambda function.

$ aws lambda add-permission \


--function-name CloudTrailEventProcessing \
--region us-west-2 \
--statement-id Id-1 \
--action "lambda:InvokeFunction" \
--principal s3.amazonaws.com \

250
AWS Lambda Developer Guide
Tutorial

--source-arn arn:aws:s3:::examplebucket \
--source-account examplebucket-owner-account-id \
--profile adminuser

2. Verify the function's access policy by running the AWS CLI get-policy command.

$ aws lambda get-policy \


--function-name function-name \
--profile adminuser

Step 3.2: Congure Notication on the Bucket


Add notication conguration on the examplebucket to request Amazon S3 to publish object-created
events to Lambda. In the conguration, you specify the following:

Event type For this tutorial, these can be any event types that create objects.
Lambda function ARN This is your Lambda function that you want Amazon S3 to invoke. The ARN is
of the following form:

arn:aws:lambda:aws-region:account-id:function:function-name

For example, the function CloudTrailEventProcessing created in us-west-2 region has the following
ARN:

arn:aws:lambda:us-west-2:account-id:function:CloudTrailEventProcessing

For instructions on adding notication conguration to a bucket, see Enabling Event Notications in the
Amazon Simple Storage Service Console User Guide.

Step 3.3: Test the Setup


You're all done! Now you can test the setup as follows:

1. Perform some action in your AWS account. For example, add another topic in the Amazon SNS
console.
2. You receive an email notication about this event.
3. AWS CloudTrail creates a log object in your bucket.
4. If you open the log object (.gz le), the log shows the CreateTopic SNS event.
5. For each object AWS CloudTrail creates, Amazon S3 invokes your Lambda function by passing in the
log object as event data.
6. Lambda executes your function. The function parses the log, nds a CreateTopic SNS event, and then
you receive an email notication.

You can monitor the activity of your Lambda function by using CloudWatch metrics and logs. For
more information about CloudWatch monitoring, see Troubleshooting and Monitoring AWS Lambda
Functions with Amazon CloudWatch (p. 114).

251
AWS Lambda Developer Guide
Tutorial

Step 4: Deploy With AWS SAM and AWS CloudFormation


In the previous section, you used AWS Lambda APIs to create and update a Lambda function by
providing a deployment package as a ZIP le. However, this mechanism may not be convenient for
automating deployment steps for functions, or coordinating deployments and updates to other elements
of a serverless application, like event sources and downstream resources.

You can use AWS CloudFormation to easily specify, deploy, and congure serverless applications. AWS
CloudFormation is a service that helps you model and set up your Amazon Web Services resources so
that you can spend less time managing those resources and more time focusing on your applications
that run in AWS. You create a template that describes all the AWS resources that you want (like Lambda
functions and DynamoDB tables), and AWS CloudFormation takes care of provisioning and conguring
those resources for you.

In addition, you can use the AWS Serverless Application Model to express resources that comprise the
serverless application. These resource types, such as Lambda functions and APIs, are fully supported by
AWS CloudFormation and make it easier for you to dene and deploy your serverless application.

For more information, see Deploying Lambda-based Applications (p. 144).

Specication for Amazon API Gateway Application


The following contains the SAM template for this application. Copy the text below to a .yaml le and
save it next to the ZIP package you created in the previous section. Note that the Handler and Runtime
parameter values should match the ones you used when you created the function in the previous section.

AWSTemplateFormatVersion: '2010-09-09'
Transform: AWS::Serverless-2016-10-31
Parameters:
NotificationEmail:
Type: String
Resources:
CloudTrailEventProcessing:
Type: AWS::Serverless::Function
Properties:
Handler: handler
Runtime: runtime
Timeout: 10
MemorySize: 1024
Policies:
Statement:
- Effect: Allow
Action: s3:GetObject
Resource: !Sub 'arn:aws:s3:::${Bucket}/*'

252
AWS Lambda Developer Guide
Amazon SNS

- Effect: Allow
Action: sns:Publish
Resource: !Ref Topic
Events:
PhotoUpload:
Type: S3
Properties:
Bucket: !Ref Bucket
Events: s3:ObjectCreated:*
Environment:
Variables:
SNS_TOPIC_ARN: !Ref Topic

Bucket:
Type: AWS::S3::Bucket

Trail:
Type: AWS::CloudTrail::Trail
Properties:
IsLogging: true
S3BucketName: !Ref Bucket

Topic:
Type: AWS::SNS::Topic
Properties:
Subscription:
- Protocol: email
Endpoint: !Ref NotificationEmail

Deploying the Serverless Application


For information on how to package and deploy your serverless application using the package and deploy
commands, see Packaging and Deployment (p. 150).

Using AWS Lambda with Amazon SNS from


Dierent Accounts
In order to perform cross account Amazon SNS deliveries to Lambda, you need to authorize your Lambda
function to be invoked from Amazon SNS. In turn, Amazon SNS needs to allow the Lambda account
to subscribe to the Amazon SNS topic. For example, if the Amazon SNS topic is in account A and the
Lambda function is in account B, both accounts must grant permissions to the other to access their
respective resources. Since not all the options for setting up cross-account permissions are available from
the AWS console, you use the AWS CLI to set up the entire process.

For a tutorial that walks you through an example setup, see Tutorial: Using AWS Lambda with Amazon
SNS (p. 253).

Tutorial: Using AWS Lambda with Amazon SNS


In this tutorial, you create a Lambda function in one AWS account to subscribe to an Amazon SNS topic
in a separate AWS account.

The tutorial is divided into three main sections:

First, you perform the necessary setup to create a Lambda function.


Second, you create an Amazon SNS topic in a separate AWS account.

253
AWS Lambda Developer Guide
Tutorial

Third, you grant permissions from each account in order for the Lambda function to subscribe to the
Amazon SNS topic. Then, you test the end-to-end setup.

Important
This tutorial assumes that you create these resources in the us-east-1 region.

In this tutorial, you use the AWS Command Line Interface to perform AWS Lambda operations such as
creating a Lambda function, creating an Amazon SNS topic and granting permissions to allow these two
resources to access each other.

Next Step
Step 1: Prepare (p. 254)

Step 1: Prepare
Sign up for an AWS account and create an administrator user in the account (called adminuser).
Install and set up the AWS CLI.

For instructions, see Step 1: Set Up an AWS Account and the AWS CLI (p. 185).

Next Step
Step 2: Create a Lambda Function (p. 254)

Step 2: Create a Lambda Function


In this section, you do the following:

Create a Lambda function deployment package using the sample code provided. The sample Lambda
function code that you'll use to subscribe to an Amazon SNS topic is provided in various languages.
Select one of the languages and follow the corresponding instructions to create a deployment
package.
Create an IAM role (execution role). At the time you upload the deployment package, you need to
specify an IAM role (execution role) that Lambda can assume to execute the function on your behalf.

Topics
Step 2.1: Create a Lambda Function Deployment Package (p. 254)
Step 2.2: Create the Execution Role (IAM Role) (p. 256)

Step 2.1: Create a Lambda Function Deployment Package


From the Filter View list, choose the language you want to use for your Lambda function. The
appropriate section appears with code and specic instructions for creating a deployment package.

Node.js

1. Open a text editor, and then copy the following code.

console.log('Loading function');

exports.handler = function(event, context, callback) {

254
AWS Lambda Developer Guide
Tutorial

// console.log('Received event:', JSON.stringify(event, null, 4));

var message = event.Records[0].Sns.Message;


console.log('Message received from SNS:', message);
callback(null, "Success");
};

Note
The code sample is compliant with the Node.js runtimes v6.10 or v4.3. For more
information, see Programming Model (Node.js) (p. 9)
2. Save the le as index.js.
3. Zip the index.js le as LambdaWithSNS.zip.

Next Step

Step 2.2: Create the Execution Role (IAM Role) (p. 256)

Java

Open a text editor, and then copy the following code.

package example;

import java.text.SimpleDateFormat;
import java.util.Calendar;

import com.amazonaws.services.lambda.runtime.RequestHandler;
import com.amazonaws.services.lambda.runtime.Context;
import com.amazonaws.services.lambda.runtime.events.SNSEvent;

public class LogEvent implements RequestHandler<SNSEvent, Object> {


public Object handleRequest(SNSEvent request, Context context){
String timeStamp = new SimpleDateFormat("yyyy-MM-
dd_HH:mm:ss").format(Calendar.getInstance().getTime());
context.getLogger().log("Invocation started: " + timeStamp);

context.getLogger().log(request.getRecords().get(0).getSNS().getMessage());

timeStamp = new SimpleDateFormat("yyyy-MM-


dd_HH:mm:ss").format(Calendar.getInstance().getTime());
context.getLogger().log("Invocation completed: " + timeStamp);
return null;
}
}

Using the preceding code (in a le named LambdaWithSNS.java), create a deployment package. Make sure
that you add the following dependencies:

aws-lambda-java-core
aws-lambda-java-events

For more information, see Programming Model for Authoring Lambda Functions in Java (p. 24).

Your deployment package can be a .zip le or a standalone .jar. You can use any build and packaging
tool you are familiar with to create a deployment package. For examples of how to use the Maven build
tool to create a standalone .jar, see Creating a .jar Deployment Package Using Maven without any IDE
(Java) (p. 66) and Creating a .jar Deployment Package Using Maven and Eclipse IDE (Java) (p. 68). For an

255
AWS Lambda Developer Guide
Tutorial

example of how to use the Gradle build tool to create a .zip le, see Creating a .zip Deployment Package
(Java) (p. 70).

After you verify that your deployment package is created, go to the next step to create an IAM role
(execution role). You specify this role at the time you create your Lambda function.

Next Step

Step 2.2: Create the Execution Role (IAM Role) (p. 256)

Python

1. Open a text editor, and then copy the following code.


Note
The from __future__ statement enables you to write code that is compatible with Python 2
or 3. If you are using runtime version 3.6, it is not necessary to include it.

from __future__ import print_function


import json
print('Loading function')

def lambda_handler(event, context):


#print("Received event: " + json.dumps(event, indent=2))
message = event['Records'][0]['Sns']['Message']
print("From SNS: " + message)
return message

2. Save the le as lambda_handler.py.


3. Zip the lambda_handler.py le as LambdaWithSNS.zip.

Next Step

Step 2.2: Create the Execution Role (IAM Role) (p. 256)

Step 2.2: Create the Execution Role (IAM Role)


In this section, you create an IAM role using the following predened role type and access policy:

AWS service role of the type AWS Lambda This role grants AWS Lambda permissions to assume the
role.
AWSLambdaBasicExecutionRole This is the access permissions policy that you attach to the role.

For more information about IAM roles, see IAM Roles in the IAM User Guide. Use the following procedure
to create the IAM role.

To create an IAM role (execution role)

1. Sign in to the AWS Management Console and open the IAM console at https://
console.aws.amazon.com/iam/.
2. Follow the steps in Creating a Role to Delegate Permissions to an AWS Service in the IAM User Guide
to create an IAM role (execution role). As you follow the steps to create a role, note the following:

In Role Name, use a name that is unique within your AWS account (for example, lambda-sns-
execution-role).
In Select Role Type, choose AWS Service Roles, and then choose AWS Lambda. This grants the
AWS Lambda service permissions to assume the role.

256
AWS Lambda Developer Guide
Tutorial

In Attach Policy, choose AWSLambdaBasicExecutionRole. The permissions in this policy are


sucient for the Lambda function in this tutorial.
3. Write down the role ARN. You will need it in the next step when you create your Lambda function.

Step 3: Set Up Cross-Account Permissions


In this section, you use CLI commands to set permissions across the Lambda function account and the
Amazon SNS topic account and then test the subscription.

1. From account A, create the Amazon SNS topic:

aws sns create-topic \


--name lambda-x-account

Note the topic arn that is returned by the command. You will need it when you add permissions to the
Lambda function to subscribe to the topic.
2. From account B, create the Lambda function. For the runtime parameter, select either nodejs6.10,
nodejs4.3, python3.6, python2.7 or java8, depending on the code sample you selected when you
created your deployment package.

aws lambda create-function \


--function-name SNS-X-Account \
--runtime runtime language \
--role role arn \
--handler handler-name \
--description "SNS X Account Test Function" \
--timeout 60 \
--memory-size 128 \
--zip-file fileb://path/LambdaWithSNS.zip

Note the function arn that is returned by the command. You will need it when you add permissions to
allow Amazon SNS to invoke your function.
3. From account A add permission to account B to subscribe to the topic:

aws sns add-permission \


--region us-east-1 \
--topic-arn Amazon SNS topic arn \
--label lambda-access \
--aws-account-id B \
--action-name Subscribe ListSubscriptionsByTopic Receive

4. From account B add the Lambda permission to allow invocation from Amazon SNS:

aws lambda add-permission \


--function-name SNS-X-Account \
--statement-id sns-x-account \
--action "lambda:InvokeFunction" \
--principal sns.amazonaws.com \
--source-arn Amazon SNS topic arn

In response, Lambda returns the following JSON code. The Statement value is a JSON string version of
the statement added to the Lambda function policy:

{
"Statement": "{\"Condition\":{\"ArnLike\":{\"AWS:SourceArn\":\"arn:aws:lambda:us-
east-1:B:function:SNS-X-Account\"}},\"Action\":[\"lambda:InvokeFunction\"],\"Resource\":

257
AWS Lambda Developer Guide
Amazon API Gateway

\"arn:aws:lambda:us-east-1:A:function:SNS-X-Account\",\"Effect\":\"Allow\",\"Principal\":
{\"Service\":\"sns.amazonaws.com\"},\"Sid\":\"sns-x-account1\"}"
}

Note
Do not use the --source-account parameter to add a source account to the Lambda policy
when adding the policy. Source account is not supported for Amazon SNS event sources
and will result in access being denied. This has no security impact as the source account is
included in the source ARN.
5. From account B subscribe the Lambda function to the topic:

aws sns subscribe \


--topic-arn Amazon SNS topic arn \
--protocol lambda \
--notification-endpoint arn:aws:lambda:us-east-1:B:function:SNS-X-Account

You should see JSON output similar to the following:

{
"SubscriptionArn": "arn:aws:sns:us-east-1:A:lambda-x-account:5d906xxxx-7c8x-45dx-
a9dx-0484e31c98xx"
}

6. From account A you can now test the subscription. Type "Hello World" into a text le and save it as
message.txt. Then run the following command:

aws sns publish \


--topic-arn arn:aws:sns:us-east-1:A:lambda-x-account \
--message file://message.txt \
--subject Test

This will return a message id with a unique identier, indicating the message has been accepted by the
Amazon SNS service. Amazon SNS will then attempt to deliver it to the topic's subscribers.

Note
Alternatively, you could supply a JSON string directly to the message parameter, but using a text
le allows for line breaks in the message.

For more information on Amazon SNS, see What is Amazon Simple Notication Service?

Using AWS Lambda with Amazon API Gateway


(On-Demand Over HTTPS)
You can invoke AWS Lambda functions over HTTPS. You can do this by dening a custom REST API
and endpoint using Amazon API Gateway, and then mapping individual methods, such as GET and PUT,
to specic Lambda functions. Alternatively, you could add a special method named ANY to map all
supported methods (GET, POST, PATCH, DELETE) to your Lambda function. When you send an HTTPS
request to the API endpoint, the Amazon API Gateway service invokes the corresponding Lambda
function. For more information about the ANY method, see Step 3: Create a Simple Microservice using
Lambda and API Gateway (p. 197).

Amazon API Gateway also adds a layer between your application users and your app logic that enables
the following:

258
AWS Lambda Developer Guide
Using AWS Lambda with Amazon API
Gateway (On-Demand Over HTTPS)

Ability to throttle individual users or requests.


Protect against Distributed Denial of Service attacks.
Provide a caching layer to cache response from your Lambda function.

Note the following about how the Amazon API Gateway and AWS Lambda integration works:

Push-event model This is a model (see Event Source Mapping (p. 127)), where Amazon API Gateway
invokes the Lambda function by passing data in the request body as parameter to the Lambda
function.
Synchronous invocation The Amazon API Gateway can invoke the Lambda function and get a
response back in real time by specifying RequestResponse as the invocation type. For information
about invocation types, see Invocation Types (p. 4).
Event structure The event your Lambda function receives is the body from the HTTPS request that
Amazon API Gateway receives and your Lambda function is the custom code written to process the
specic event type.

Note that there are two types of permissions policies that you work with when you set up the end-to-end
experience:

Permissions for your Lambda function Regardless of what invokes a Lambda function, AWS Lambda
executes the function by assuming the IAM role (execution role) that you specify at the time you
create the Lambda function. Using the permissions policy associated with this role, you grant your
Lambda function the permissions that it needs. For example, if your Lambda function needs to read an
object, you grant permissions for the relevant Amazon S3 actions in the permissions policy. For more
information, see Manage Permissions: Using an IAM Role (Execution Role) (p. 180).
Permission for Amazon API Gateway to invoke your Lambda function Amazon API Gateway cannot
invoke your Lambda function without your permission. You grant this permission via the permission
policy associated with the Lambda function.

For a tutorial that walks you through an example setup, see Using AWS Lambda with Amazon API
Gateway (On-Demand Over HTTPS) (p. 259).

Using AWS Lambda with Amazon API Gateway (On-


Demand Over HTTPS)
In this example you create a simple API (DynamoDBOperations) using Amazon API Gateway. An Amazon
API Gateway is a collection of resources and methods. For this tutorial, you create one resource
(DynamoDBManager) and dene one method (POST) on it. The method is backed by a Lambda function
(LambdaFunctionForAPIGateway). That is, when you invoke the method through an HTTPS endpoint,
Amazon API Gateway invokes the Lambda function.

The POST method on the DynamoDBManager resource supports the following DynamoDB operations:

Create, update, and delete an item.


Read an item.
Scan an item.
Other operations (echo, ping), not related to DynamoDB, that you can use for testing.

The request payload you send in the POST request identies the DynamoDB operation and provides
necessary data. For example:

259
AWS Lambda Developer Guide
Using AWS Lambda with Amazon API
Gateway (On-Demand Over HTTPS)

The following is a sample request payload for a DynamoDB put item operation:

{
"operation": "create",
"tableName": "LambdaTable",
"payload": {
"Item": {
"Id": "1",
"name": "Bob"
}
}
}

The following is a sample request payload for a DynamoDB read item operation:

{
"operation": "read",
"tableName": "LambdaTable",
"payload": {
"Key": {
"Id": "1"
}
}
}

The following is a sample request payload for a the echo operation. You will then send HTTPS PUT
request to the endpoint, using the following data in the request body.

{
"operation": "echo",
"payload": {
"somekey1": "somevalue1",
"somekey2": "somevalue2"
}
}

You can also create and manage API endpoints from the AWS Lambda console. For example, search for
the microservice in the blueprints. This tutorial does not use the console, instead it uses AWS CLI to
provide you with more details of how the API works.
Note
API Gateway oers advanced capabilities, such as:

Pass through the entire request A Lambda function can receive the entire HTTP request
(instead of just the request body) and set the HTTP response (instead of just the response
body) using the AWS_PROXY integration type.
Catch-all methods Map all methods of an API resource to a single function with a single
mapping, using the ANY catch-all method.
Catch-all resources Map all sub-paths of a resource to a Lambda function without any
additional conguration using the new path parameter ({proxy+}).

To learn more about these API Gateway features, see Congure Proxy Integration for a Proxy
Resource.

Next Step
Step 1: Prepare (p. 261)

260
AWS Lambda Developer Guide
Using AWS Lambda with Amazon API
Gateway (On-Demand Over HTTPS)

Step 1: Prepare
Make sure you have completed the following steps:

Signed up for an AWS account and created an administrator user in the account.
Installed and set up the AWS CLI.

For instructions, see Step 1: Set Up an AWS Account and the AWS CLI (p. 185).
Important
This example uses the region region to create an API using Amazon API Gateway and a Lambda
function.

Next Step
Step 2: Create a Lambda Function and Test It Manually (p. 261)

Step 2: Create a Lambda Function and Test It Manually


In this section, you do the following:

Create a Lambda function deployment package using the sample code provided.
Create an IAM role (execution role). At the time you upload the deployment package, you need to
specify an IAM role (execution role) that Lambda can assume to execute the function on your behalf.
Create the Lambda function and then test it manually.

Topics
Step 2.1: Create a Deployment Package (p. 261)
Step 2.2: Create the Execution Role (IAM Role) (p. 263)
Step 2.3: Create the Lambda Function and Test It Manually (p. 264)

Step 2.1: Create a Deployment Package


From the Filter View list, choose the language you want to use for your Lambda function. The
appropriate section appears with code and specic instructions for creating a deployment package.

Node.js

Follow the instructions to create a AWS Lambda function deployment package.

1. Open a text editor, and then copy the following code.

console.log('Loading function');

var AWS = require('aws-sdk');


var dynamo = new AWS.DynamoDB.DocumentClient();

/**
* Provide an event that contains the following keys:
*
* - operation: one of the operations in the switch statement below
* - tableName: required for operations that interact with DynamoDB
* - payload: a parameter to pass to the operation being performed
*/
exports.handler = function(event, context, callback) {
//console.log('Received event:', JSON.stringify(event, null, 2));

261
AWS Lambda Developer Guide
Using AWS Lambda with Amazon API
Gateway (On-Demand Over HTTPS)

var operation = event.operation;

if (event.tableName) {
event.payload.TableName = event.tableName;
}

switch (operation) {
case 'create':
dynamo.put(event.payload, callback);
break;
case 'read':
dynamo.get(event.payload, callback);
break;
case 'update':
dynamo.update(event.payload, callback);
break;
case 'delete':
dynamo.delete(event.payload, callback);
break;
case 'list':
dynamo.scan(event.payload, callback);
break;
case 'echo':
callback(null, "Success");
break;
case 'ping':
callback(null, "pong");
break;
default:
callback('Unknown operation: ${operation}');
}
};

Note
The code sample is compliant with the Node.js runtimes v6.10 or v4.3. For more
information, see Programming Model (Node.js) (p. 9)
2. Save the le as LambdaFunctionOverHttps.js.
3. Zip the LambdaFunctionOverHttps.js le as LambdaFunctionOverHttps.zip.

Next Step
Step 2.2: Create the Execution Role (IAM Role) (p. 263)

Python
Follow the instructions to create AWS Lambda function deployment package.

1. Open a text editor, and then copy the following code.


Note
The from __future__ statement enables you to write code that is compatible with Python 2
or 3. If are you using runtime version 3.6, it is not necessary to include it.

from __future__ import print_function

import boto3
import json

print('Loading function')

262
AWS Lambda Developer Guide
Using AWS Lambda with Amazon API
Gateway (On-Demand Over HTTPS)

def handler(event, context):


'''Provide an event that contains the following keys:

- operation: one of the operations in the operations dict below


- tableName: required for operations that interact with DynamoDB
- payload: a parameter to pass to the operation being performed
'''
#print("Received event: " + json.dumps(event, indent=2))

operation = event['operation']

if 'tableName' in event:
dynamo = boto3.resource('dynamodb').Table(event['tableName'])

operations = {
'create': lambda x: dynamo.put_item(**x),
'read': lambda x: dynamo.get_item(**x),
'update': lambda x: dynamo.update_item(**x),
'delete': lambda x: dynamo.delete_item(**x),
'list': lambda x: dynamo.scan(**x),
'echo': lambda x: x,
'ping': lambda x: 'pong'
}

if operation in operations:
return operations[operation](event.get('payload'))
else:
raise ValueError('Unrecognized operation "{}"'.format(operation))

2. Save the le as LambdaFunctionOverHttps.py.


3. Zip the LambdaFunctionOverHttps.py le as LambdaFunctionOverHttps.zip.

Next Step

Step 2.2: Create the Execution Role (IAM Role) (p. 263)

Step 2.2: Create the Execution Role (IAM Role)


In this section, you create an IAM role using the following predened role type:

AWS service role of the type AWS Lambda This role grants AWS Lambda permissions to assume the
role.

For more information about IAM roles, see IAM Roles in the IAM User Guide. Use the following procedure
to create the IAM role.

To create an IAM role (execution role)

1. Sign in to the AWS Management Console and open the IAM console at https://
console.aws.amazon.com/iam/.
2. Follow the steps in Creating a Role to Delegate Permissions to an AWS Service in the IAM User Guide
to create an IAM role (execution role). As you follow the steps to create a role, note the following:

In Role Name, use a name that is unique within your AWS account (for example, lambda-
gateway-execution-role).
In Select Role Type, choose AWS Service Roles, and then choose AWS Lambda. This grants the
AWS Lambda service permissions to assume the role.
You create an IAM role without attaching a permissions policy in the console. After you create the
role, you update the role, and then attach the following permissions policy to the role.

263
AWS Lambda Developer Guide
Using AWS Lambda with Amazon API
Gateway (On-Demand Over HTTPS)

{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "Stmt1428341300017",
"Action": [
"dynamodb:DeleteItem",
"dynamodb:GetItem",
"dynamodb:PutItem",
"dynamodb:Query",
"dynamodb:Scan",
"dynamodb:UpdateItem"
],
"Effect": "Allow",
"Resource": "*"
},
{
"Sid": "",
"Resource": "*",
"Action": [
"logs:CreateLogGroup",
"logs:CreateLogStream",
"logs:PutLogEvents"
],
"Effect": "Allow"
}
]
}

3. Write down the role ARN (Amazon Resource Name). You need it in the next step when you create
your Lambda function.

Next Step

Step 2.3: Create the Lambda Function and Test It Manually (p. 264)

Step 2.3: Create the Lambda Function and Test It Manually


In this section, you do the following:

Create a Lambda function by uploading the deployment package.


Test the Lambda function by invoking it manually and passing sample event data.

Step 2.3.1: Create a Lambda Function (Upload the Deployment Package)

In this step, you upload the deployment package using the AWS CLI.

At the command prompt, run the following Lambda CLI create-function command using the
adminuser prole.

You need to update the command by providing the .zip le path and the execution role ARN. The --
runtime parameter value can be python3.6, python2.7, nodejs6.10, nodejs4.3, or java8, depending on
the language you used to author your code.

$ aws lambda create-function \


--region region \
--function-name LambdaFunctionOverHttps \
--zip-file fileb://file-path/LambdaFunctionOverHttps.zip \

264
AWS Lambda Developer Guide
Using AWS Lambda with Amazon API
Gateway (On-Demand Over HTTPS)

--role execution-role-arn \
--handler LambdaFunctionOverHttps.handler \
--runtime runtime-value \
--profile adminuser

Optionally, you can upload the .zip le to an Amazon S3 bucket in the same AWS region, and then
specify the bucket and object name in the preceding command. You need to replace the --zip-file
parameter by the --code parameter, as shown following:

--code S3Bucket=bucket-name,S3Key=zip-file-object-key

Note
You can create the Lambda function using the AWS Lambda console, in which case note the
value of the create-function AWS CLI command parameters. You provide the same values in
the console UI.

Step 2.3.2: Test the Lambda Function (Invoke Manually)

Invoke the function manually using the sample event data. We recommend that you invoke the function
using the console because the console UI provides a user-friendly interface for reviewing the execution
results, including the execution summary, logs written by your code, and the results returned by the
function (because the console always performs synchronous executioninvokes the Lambda function
using the RequestResponse invocation type).

To test the Lambda function (AWS Management Console)

1. Follow the steps in the Getting Started exercise to create and invoke the Lambda function at Step
2.2: Invoke the Lambda Function Manually and Verify Results, Logs, and Metrics (p. 192). For the
sample event for testing, choose Hello World in Sample event template, and then replace the data
using the following:

{
"operation": "echo",
"payload": {
"somekey1": "somevalue1",
"somekey2": "somevalue2"
}
}

2. To test one of the dynamo operations, such as read, change the input data to the following:

{
"operation": "read",
"tableName": "the name of your stream table",
"payload": {
"Key": {
"the primary key of the table": "the value of the key"
}
}
}

3. Verify the results in the console.

To test the Lambda function (AWS CLI)

1. Copy the following JSON into a le and save it as input.txt.

265
AWS Lambda Developer Guide
Using AWS Lambda with Amazon API
Gateway (On-Demand Over HTTPS)

"operation": "echo",
"payload": {
"somekey1": "somevalue1",
"somekey2": "somevalue2"
}
}

2. Execute the following invoke command:

$ aws lambda invoke \


--invocation-type Event \
--function-name LambdaFunctionOverHttps \
--region region \
--payload file://file-path/input.txt \
--profile adminuser
outputfile.txt

Note
In this tutorial example, the message is saved in the outputfile.txt le if you request
synchronous execution (RequestResponse as the invocation type). The function returns the
string message in the response body. If you use the Event invocation type, no message is
returned to the output le. In either case, the outputle.txt parameter is required.

Next Step

Step 3: Create an API Using Amazon API Gateway and Test It (p. 266)

Step 3: Create an API Using Amazon API Gateway and Test It


In this step, you associate your Lambda function with a method in the API that you created using
Amazon API Gateway and test the end-to-end experience. That is, when an HTTPS request is sent to an
API method, Amazon API Gateway invokes your Lambda function.

First, you create an API (DynamoDBOperations) using Amazon API Gateway with one resource
(DynamoDBManager) and one method (POST). You associate the POST method with your Lambda function.
Then, you test the end-to-end experience.

Step 3.1: Create the API


Run the following create-rest-api command to create the DynamoDBOperations API for this tutorial.

$ aws apigateway create-rest-api \


--name DynamoDBOperations \
--region region \
--profile profile

The following is an example response:

{
"name": "DynamoDBOperations",
"id": "api-id",
"createdDate": 1447724091
}

Note the API ID.

266
AWS Lambda Developer Guide
Using AWS Lambda with Amazon API
Gateway (On-Demand Over HTTPS)

You also need the ID of the API root resource. To get the ID, run the get-resources command.

$ aws apigateway get-resources \


--rest-api-id api-id

The following is example response (at this time you only have the root resource, but you add more
resources in the next step):

{
"items": [
{
"path": "/",
"id": "root-id"
}
]
}

Step 3.2: Create a Resource (DynamoDBManager) in the API


Run the following create-resource command to create a resource (DynamoDBManager) in the API that you
created in the preceding section.

$ aws apigateway create-resource \


--rest-api-id api-id \
--parent-id root-id \
--path-part DynamoDBManager

The following is an example response:

{
"path": "/DynamoDBManager",
"pathPart": "DynamoDBManager",
"id": "resource-id",
"parentId": "root-id"
}

Note the ID in the response. This is the ID of the resource (DynamoDBManager) that you created.

Step 3.3: Create Method (POST) on the Resource


Run the following put-method command to create a method (POST) on the resource (DynamoDBManager) in
your API (DynamoDBOperations).

$ aws apigateway put-method \


--rest-api-id api-id \
--resource-id resource-id \
--http-method POST \
--authorization-type NONE

We specify NONE for the --authorization-type parameter, which means that unauthenticated requests
for this method are supported. This is ne for testing but in production you should use either the key-
based or role-base authentication.

The following is an example response:

267
AWS Lambda Developer Guide
Using AWS Lambda with Amazon API
Gateway (On-Demand Over HTTPS)

"apiKeyRequired": false,
"httpMethod": "POST",
"authorizationType": "NONE"
}

Step 3.4: Set the Lambda Function as the Destination for the POST Method
Run the following command to set the Lambda function as the integration point for the POST method
(this is the method Amazon API Gateway invokes when you make an HTTPS request for the POST method
endpoint).

$ aws apigateway put-integration \


--rest-api-id api-id \
--resource-id resource-id \
--http-method POST \
--type AWS \
--integration-http-method POST \
--uri arn:aws:apigateway:aws-region:lambda:path/2015-03-31/functions/arn:aws:lambda:aws-
region:aws-acct-id:function:your-lambda-function-name/invocations

Note

--rest-api-id is the ID of the API (DynamoDBOperations) that you created in Amazon API
Gateway.
--resource-id is the resource ID of the resource (DynamoDBManager) you created in the API
--http-method is the API Gateway method and --integration-http-method is the method
that API Gateway uses to communicate with AWS Lambda.
--uri is unique identier for the endpoint to which Amazon API Gateway can send request.

The following is an example response:

{
"httpMethod": "POST",
"type": "AWS",
"uri": "arn:aws:apigateway:region:lambda:path/2015-03-31/functions/
arn:aws:lambda:region:aws-acct-id:function:LambdaFunctionForAPIGateway/invocations",
"cacheNamespace": "resource-id"
}

Set content-type of the POST method response and integration response to JSON as follows:

Run the following command to set the POST method response to JSON. This is the response type that
your API method returns.

$ aws apigateway put-method-response \


--rest-api-id api-id \
--resource-id resource-id \
--http-method POST \
--status-code 200 \
--response-models "{\"application/json\": \"Empty\"}"

Run the following command to set the POST method integration response to JSON. This is the response
type that Lambda function returns.

$ aws apigateway put-integration-response \


--rest-api-id api-id \

268
AWS Lambda Developer Guide
Using AWS Lambda with Amazon API
Gateway (On-Demand Over HTTPS)

--resource-id resource-id \
--http-method POST \
--status-code 200 \
--response-templates "{\"application/json\": \"\"}"

Step 3.5: Deploy the API


In this step, you deploy the API that you created to a stage called prod.

$ aws apigateway create-deployment \


--rest-api-id api-id \
--stage-name prod

The following is an example response:

{
"id": "deployment-id",
"createdDate": 1447726017
}

Step 3.6: Grant Permissions that Allows Amazon API Gateway to Invoke the
Lambda Function
Now that you have an API created using Amazon API Gateway and you've deployed it, you can test. First,
you need to add permissions so that Amazon API Gateway can invoke your Lambda function when you
send HTTPS request to the POST method.

To do this, you need to add a permissions to the permissions policy associated with your Lambda
function. Run the following add-permission AWS Lambda command to grant the Amazon API
Gateway service principal (apigateway.amazonaws.com) permissions to invoke your Lambda function
(LambdaFunctionForAPIGateway).

$ aws lambda add-permission \


--function-name LambdaFunctionOverHttps \
--statement-id apigateway-test-2 \
--action lambda:InvokeFunction \
--principal apigateway.amazonaws.com \
--source-arn "arn:aws:execute-api:region:aws-acct-id:api-id/*/POST/DynamoDBManager"

You must grant this permission to enable testing (if you go to the Amazon API Gateway and choose Test
to test the API method, you need this permission). Note the --source-arn species a wildcard character
(*) as the stage value (indicates testing only). This allows you to test without deploying the API.

Now, run the same command again, but this time you grant to your deployed API permissions to invoke
the Lambda function.

$ aws lambda add-permission \


--function-name LambdaFunctionOverHttps \
--statement-id apigateway-prod-2 \
--action lambda:InvokeFunction \
--principal apigateway.amazonaws.com \
--source-arn "arn:aws:execute-api:region:aws-acct-id:api-id/prod/POST/DynamoDBManager"

You grant this permission so that your deployed API has permissions to invoke the Lambda function.
Note that the --source-arn species a prod which is the stage name we used when deploying the API.

269
AWS Lambda Developer Guide
Using AWS Lambda with Amazon API
Gateway (On-Demand Over HTTPS)

Step 3.7: Test Sending an HTTPS Request


In this step, you are ready to send an HTTPS request to the POST method endpoint. You can use either
Curl or a method (test-invoke-method) provided by Amazon API Gateway.

If you want to test operations that your Lambda function supports on a DynamoDB table, rst you need
to create a table in Amazon DynamoDB LambdaTable (Id), where Id is the hash key of string type.

If you are testing the echo and ping operations that your Lambda function supports, you don't need to
create the DynamoDB table.

You can use Amazon API Gateway CLI commands to send an HTTPS POST request to the resource
(DynamoDBManager) endpoint. Because you deployed your Amazon API Gateway, you can use Curl to
invoke the methods for the same operation.

The Lambda function supports using the create operation to create an item in your DynamoDB table. To
request this operation, use the following JSON:

{
"operation": "create",
"tableName": "LambdaTable",
"payload": {
"Item": {
"Id": "foo",
"number": 5
}
}
}

Run the test-invoke-method Amazon API Gateway command to send an HTTPS POST method request to
the resource (DynamoDBManager) endpoint with the preceding JSON in the request body.

$ aws apigateway test-invoke-method \


--rest-api-id api-id \
--resource-id resource-id \
--http-method POST \
--path-with-query-string "" \
--body "{\"operation\":\"create\",\"tableName\":\"LambdaTable\",\"payload\":{\"Item\":{\"Id
\":\"1\",\"name\":\"Bob\"}}}"

Or, you can use the following Curl command:

curl -X POST -d "{\"operation\":\"create\",\"tableName\":\"LambdaTable\",\"payload


\":{\"Item\":{\"Id\":\"1\",\"name\":\"Bob\"}}}" https://api-id.execute-api.aws-
region.amazonaws.com/prod/DynamoDBManager

To send request for the echo operation that your Lambda function supports, you can use the following
request payload:

{
"operation": "echo",
"payload": {
"somekey1": "somevalue1",
"somekey2": "somevalue2"
}
}

270
AWS Lambda Developer Guide
Using AWS Lambda with Amazon API
Gateway (On-Demand Over HTTPS)

Run the test-invoke-method Amazon API Gateway CLI command to send an HTTPS POST method
request to the resource (DynamoDBManager) endpoint using the preceding JSON in the request body.

$ aws apigateway test-invoke-method \


--rest-api-id api-id \
--resource-id resource-id \
--http-method POST \
--path-with-query-string "" \
--body "{\"operation\":\"echo\",\"payload\":{\"somekey1\":\"somevalue1\",\"somekey2\":
\"somevalue2\"}}"

Or, you can use the following Curl command:

curl -X POST -d "{\"operation\":\"echo\",\"payload\":{\"somekey1\":\"somevalue1\",


\"somekey2\":\"somevalue2\"}}" https://api-id.execute-api.region.amazonaws.com/prod/
DynamoDBManager

Step 4: Deploy With AWS SAM and AWS CloudFormation


In the previous section, you used AWS Lambda APIs to create and update a Lambda function by
providing a deployment package as a ZIP le. However, this mechanism may not be convenient for
automating deployment steps for functions, or coordinating deployments and updates to other elements
of a serverless application, like event sources and downstream resources.

You can use AWS CloudFormation to easily specify, deploy, and congure serverless applications. AWS
CloudFormation is a service that helps you model and set up your Amazon Web Services resources so
that you can spend less time managing those resources and more time focusing on your applications
that run in AWS. You create a template that describes all the AWS resources that you want (like Lambda
functions and DynamoDB tables), and AWS CloudFormation takes care of provisioning and conguring
those resources for you.

In addition, you can use the AWS Serverless Application Model to express resources that comprise the
serverless application. These resource types, such as Lambda functions and APIs, are fully supported by
AWS CloudFormation and make it easier for you to dene and deploy your serverless application.

For more information, see Deploying Lambda-based Applications (p. 144).

Specication for Amazon API Gateway Application


The following contains the SAM template for this application. Copy the text below to a .yaml le and
save it next to the ZIP package you created previously. Note that the Handler and Runtime parameter
values should match the ones you used when you created the function in the previous section.

AWSTemplateFormatVersion: '2010-09-09'
Transform: AWS::Serverless-2016-10-31
Resources:
LambdaFunctionOverHttps:
Type: AWS::Serverless::Function
Properties:
Handler: handler
Runtime: runtime
Policies: AmazonDynamoDBFullAccess
Events:
HttpPost:
Type: Api
Properties:
Path: 'DynamoDBOperations/DynamoDBManager'
Method: post

271
AWS Lambda Developer Guide
Mobile Backend (Android)

Deploying the Serverless Application


For information on how to package and deploy your serverless application using the package and deploy
commands, see Packaging and Deployment (p. 150).

Using AWS Lambda as Mobile Application Backend


(Custom Event Source: Android)
You can use AWS Lambda to host backend logic for mobile applications. That is, some of your mobile
app code can be run as Lambda functions. This allows you to put minimal logic in the mobile application
itself making it easy to scale and update (for example, you only apply code updates to the Lambda
function, instead of having to deploy code updates in your app clients).

After you create the Lambda function, you can invoke it from your mobile app using AWS Mobile SDKs,
such as the AWS SDK for Android. For more information, see Tools for Amazon Web Services.
Note
You can also invoke your Lambda function over HTTP using Amazon API Gateway (instead of
using any of the AWS SDKs). Amazon API Gateway adds an additional layer between your mobile
users and your app logic that enable the following:

Ability to throttle individual users or requests.


Protect against Distributed Denial of Service attacks.
Provide a caching layer to cache response from your Lambda function.

Note the following about how the mobile application and AWS Lambda integration works:

Push-event model This is a model (see Event Source Mapping (p. 127)), where the app invokes the
Lambda function by passing the event data as parameter.
Synchronous or asynchronous invocation The app can invoke the Lambda function and get a
response back in real time by specifying RequestResponse as the invocation type (or use the Event
invocation type for asynchronous invocation). For information about invocation types, see Manage
Permissions: Using a Lambda Function Policy (p. 181).
Event structure The event your Lambda function receives is dened by your application, and your
Lambda function is the custom code written to process the specic event type.

Note that there are two types of permissions policies that you work with in setting the end-to-end
experience:

Permissions for your Lambda function Regardless of what invokes a Lambda function, AWS Lambda
executes the function by assuming the IAM role (execution role) that you specify at the time you
create the Lambda function. Using the permissions policy associated with this role, you grant your
Lambda function the permissions that it needs. For example, if your Lambda function needs to read an
object, you grant permissions for the relevant Amazon S3 actions in the permissions policy. For more
information, see Manage Permissions: Using an IAM Role (Execution Role) (p. 180).
Permissions for the mobile app to invoke your Lambda function The application must have valid
security credentials and permissions to invoke a Lambda function. For mobile applications, you can use
the Amazon Cognito service to manage user identities, authentication, and permissions.

The following diagram illustrates the application ow (the illustration assumes a mobile app using AWS
Mobile SDK for Android to make the API calls):

272
AWS Lambda Developer Guide
Tutorial

1. The mobile application sends a request to Amazon Cognito with an identity pool ID in the request (you
create the identity pool as part the setup).
2. Amazon Cognito returns temporary security credentials back to the application.

Amazon Cognito assumes the role associated with the identity pool to generate temporary
credentials. What the application can do using the credentials is limited to the permissions dened
in the permissions policy associated with the role Amazon Cognito used in obtaining the temporary
credential.
Note
The AWS SDK can cache the temporary credentials so that the application does not send a
request to Amazon Cognito each time it needs to invoke a Lambda function.
3. The mobile application invokes the Lambda function using temporary credentials (Cognito Identity).
4. AWS Lambda assumes the execution role to execute your Lambda function on your behalf.
5. The Lambda function executes.
6. AWS Lambda returns results to the mobile application, assuming the app invoked the Lambda
function using the RequestResponse invocation type (synchronous invocation).

For a tutorial that walks you through an example setup, see Tutorial: Using AWS Lambda as Mobile
Application Backend (p. 273).

Tutorial: Using AWS Lambda as Mobile Application


Backend
In this tutorial, you create a simple Android mobile application. The primary purpose of this tutorial is
to show you how to hook up various components to enable an Android mobile application to invoke a
Lambda function and process response. The app itself is simple, we will assume following:

The sample mobile application will generate event data consisting of a name (rst name and last
name) in this format:

{ firstName: 'value1', lastName: 'value2' }

273
AWS Lambda Developer Guide
Tutorial

You use Lambda function to process the event. That is, the app (using the AWS Mobile SDK for
Android) invokes a Lambda function (ExampleAndroidEventProcessor) by passing the event data to it.
The Lambda function in this tutorial does the following:
Logs incoming event data to Amazon CloudWatch Logs.
Upon successful execution, returns a simple string in the response body. Your mobile app displays
the message using the Android Toast class.

Note
The way that the mobile application invokes a Lambda function as shown in this tutorial is an
example of the AWS Lambda request-response model in which an application invokes a Lambda
function and then receives a response in real time. For more information, seeProgramming
Model (p. 8).

Implementation Summary
The tutorial is divided into two main sections:

First, you perform the necessary setup to create a Lambda function and test it by invoking it manually
using sample event data (you don't need mobile app to test your Lambda function).
Second, you create an Amazon Cognito identity pool to manage authentication and permissions, and
create the example Android application. Then, you run the application and it invokes the Lambda
function. You can then verify the end-to-end experience. In this tutorial example:
You use the Amazon Cognito service to manage user identities, authentication, and permissions.
The mobile application must have valid security credentials and permissions to invoke a Lambda
function. As part of the application setup, you create an Amazon Cognito identity pool to store user
identities and dene permissions. For more information, see Amazon Cognito
This mobile application does not require its users to log in. A mobile application can require its users
to log in using public identity providers such as Amazon and Facebook. The scope of this tutorial is
limited and assumes that the mobile application users are unauthenticated. Therefore, when you
congure Amazon Cognito identity pool you will do the following:
Enable access for unauthenticated identities.

Amazon Cognito provides a unique identier and temporary AWS credentials for these users to
invoke the Lambda function.
In the access permissions policy associated with the IAM role for unauthenticated users, add
permissions to invoke the Lambda function. An identity pool has two associated IAM roles, one for
authenticated and one for unauthenticated application users. In this example, Amazon Cognito
assumes the role for unauthenticated users to obtain temporary credentials. When the app uses
these temporary credentials to invoke your Lambda function, it can do so only if has necessary
permissions (that is, credentials may be valid, but you also need permissions). You do this by
updating the permissions policy that Amazon Cognito uses to obtain the temporary credentials.

The following diagram illustrates the application ow:

274
AWS Lambda Developer Guide
Tutorial

Now you are ready to start the tutorial.

Next Step
Step 1: Prepare (p. 275)

Step 1: Prepare
Make sure you have completed the following steps:

Signed up for an AWS account and created an administrator user in the account.
Installed and set up the AWS CLI.

For instructions, see Step 1: Set Up an AWS Account and the AWS CLI (p. 185).
Note
The tutorial creates a Lambda function and an Amazon Cognito identity pool in the us-east-1
region. If you want to use a dierent AWS region, you must create these resources in the same
region. You also need to update the example mobile application code by providing the specic
region that you want to use.

Next Step
Step 2: Create the Lambda Function and Invoke It Manually (Using Sample Event Data) (p. 275)

Step 2: Create the Lambda Function and Invoke It Manually


(Using Sample Event Data)
In this section, you do the following:

Create a Lambda function deployment package using the sample code provided. The sample Lambda
function code to process your mobile application events is provided in various languages. Select one of
the languages and follow the corresponding instructions to create a deployment package.
Note
To see more examples of using other AWS services within your function, including calling
other Lambda functions, see AWS SDK for JavaScript

275
AWS Lambda Developer Guide
Tutorial

Create an IAM role (execution role). At the time you upload the deployment package, you need to
specify an IAM role (execution role). This is the role that AWS Lambda assumes to invoke your Lambda
function on your behalf.
Create the Lambda function by uploading the deployment package, and then test it by invoking it
manually using sample event data.

Topics
Step 2.1: Create a Deployment Package (p. 276)
Step 2.2: Create the Execution Role (IAM Role) (p. 278)
Step 2.3: Create the Lambda Function and Invoke It Manually (Using Sample Event Data) (p. 278)

Step 2.1: Create a Deployment Package


From the Filter View list, choose the language you want to use for your Lambda function. The
appropriate section appears with code and specic instructions for creating a deployment package.

Node.js

Follow the instructions to create a AWS Lambda function deployment package.

1. Open a text editor, and then copy the following code.

exports.handler = function(event, context, callback) {


console.log("Received event: ", event);
var data = {
"greetings": "Hello, " + event.firstName + " " + event.lastName + "."
};
callback(null, data);
}

Note
The code sample is compliant with the Node.js runtimes v6.10 or v4.3. For more
information, see Programming Model (Node.js) (p. 9)
2. Save the le as AndroidBackendLambdaFunction.js.
3. Zip the AndroidBackendLambdaFunction.js le as AndroidBackendLambdaFunction.zip.

Next Step

Step 2.2: Create the Execution Role (IAM Role) (p. 278)

Java

Use the following Java code to create your Lambda function (AndroidBackendLambdaFunction). The code
receives Android app event data as the rst parameter to the handler. Then, the code processes event
data (for illustration this code writes some of the event data to CloudWatch Logs and returns a string in
response).

In the code, the handler (myHandler) uses the RequestClass and ResponseClass types for the input and
output. The code provides implementation for these types.
Important
You use the same classes (POJOs) to handle the input and output data when you create the
sample mobile application in the next section.

package example;

276
AWS Lambda Developer Guide
Tutorial

import com.amazonaws.services.lambda.runtime.Context;

public class HelloPojo {

// Define two classes/POJOs for use with Lambda function.


public static class RequestClass {
String firstName;
String lastName;

public String getFirstName() {


return firstName;
}

public void setFirstName(String firstName) {


this.firstName = firstName;
}

public String getLastName() {


return lastName;
}

public void setLastName(String lastName) {


this.lastName = lastName;
}

public RequestClass(String firstName, String lastName) {


this.firstName = firstName;
this.lastName = lastName;
}

public RequestClass() {
}
}

public static class ResponseClass {


String greetings;

public String getGreetings() {


return greetings;
}

public void setGreetings(String greetings) {


this.greetings = greetings;
}

public ResponseClass(String greetings) {


this.greetings = greetings;
}

public ResponseClass() {
}

public static ResponseClass myHandler(RequestClass request, Context context){


String greetingString = String.format("Hello %s, %s.", request.firstName,
request.lastName);
context.getLogger().log(greetingString);
return new ResponseClass(greetingString);
}
}

Save the preceding code in a le (HelloPojo.java). Your can now create a deployment package. You
need to include the following dependency:

277
AWS Lambda Developer Guide
Tutorial

aws-lambda-java-core

Your deployment package can be a .zip le or a standalone .jar. You can use any build and packaging
tool you are familiar with to create a deployment package. For examples of how to use the Maven build
tool to create a standalone .jar, see Creating a .jar Deployment Package Using Maven without any IDE
(Java) (p. 66) and Creating a .jar Deployment Package Using Maven and Eclipse IDE (Java) (p. 68). For an
example of how to use the Gradle build tool to create a .zip le, see Creating a .zip Deployment Package
(Java) (p. 70).

After you verify that your deployment package (lambda-java-example-1.0-SNAPSHOT.jar) is created,


go to the next section to create an IAM role (execution role). You specify the role when you create your
Lambda function.

Next Step

Step 2.2: Create the Execution Role (IAM Role) (p. 278)

Step 2.2: Create the Execution Role (IAM Role)


In this section, you create an IAM role using the following predened role type and access policy:

AWS service role of the type AWS Lambda This role grants AWS Lambda permissions to assume the
role.
AWSLambdaBasicExecute This is the access permissions policy that you attach to the role. This
Lambda function only writes logs to CloudWatch Logs. So it only needs permission for specic
CloudWatch actions. This policy provides these permissions.

For more information about IAM roles, see IAM Roles in the IAM User Guide. Use the following procedure
to create the IAM role.

To create an IAM role (execution role)

1. Sign in to the AWS Management Console and open the IAM console at https://
console.aws.amazon.com/iam/.
2. Follow the steps in Creating a Role to Delegate Permissions to an AWS Service in the IAM User Guide
to create an IAM role (execution role). As you follow the steps to create a role, note the following:

In Role Name, use a name that is unique within your AWS account (for example, lambda-android-
execution-role).
In Select Role Type, choose AWS Service Roles, and then choose AWS Lambda. This grants the
AWS Lambda service permissions to assume the role.
In Attach Policy, choose AWSLambdaBasicExecute. The permissions in this policy are sucient
for the Lambda function in this tutorial.
3. Write down the role ARN. You will need it in the next step when you create your Lambda function.

Next Step

Step 2.3: Create the Lambda Function and Invoke It Manually (Using Sample Event Data) (p. 278)

Step 2.3: Create the Lambda Function and Invoke It Manually (Using Sample
Event Data)
In this section, you do the following:

Create a Lambda function, by uploading the deployment package.

278
AWS Lambda Developer Guide
Tutorial

Test the Lambda function by invoking it manually. Instead of creating an event source, you use sample
event data. In the next section, you create an Android mobile app and test the end-to-end experience.

Step 2.3.1: Create a Lambda Function (Upload the Deployment Package)

In this step, you upload the deployment package using the AWS CLI.

At the command prompt, run the following Lambda CLI create-function command using the adminuser
profile.

You need to update the command by providing the .zip le path and the execution role ARN. The --
runtime parameter value can be nodejs6.10, nodejs4.3, or java8, depending on the language you chose
to author your code.

$ aws lambda create-function \


--region us-east-1 \
--function-name AndroidBackendLambdaFunction \
--zip-file fileb://file-path-to-jar-or-zip-deployment-package \
--role execution-role-arn \
--handler handler-name \
--runtime runtime-value \
--profile adminuser

Optionally, you can upload the .zip le to an Amazon S3 bucket in the same AWS region, and then
specify the bucket and object name in the preceding command. You need to replace the --zip-file
parameter by the --code parameter, as shown following:

--code S3Bucket=bucket-name,S3Key=zip-file-object-key

Note
You can create the Lambda function using the AWS Lambda console, in which case note the
value of the create-function AWS CLI command parameters. You provide the same values in
the console UI.

Step 2.3.2: Test the Lambda Function (Invoke Manually)

Invoke the function manually using the sample event data. We recommend that you invoke the function
using the console because the console UI provides a user-friendly interface for reviewing the execution
results, including the execution summary, logs written by your code, and the results returned by the
function (because the console always performs synchronous executioninvokes the Lambda function
using the RequestResponse invocation type).

To test the Lambda function (AWS Management Console)

1. Follow the steps in the Getting Started exercise to create and invoke the Lambda function at Step
2.2: Invoke the Lambda Function Manually and Verify Results, Logs, and Metrics (p. 192). After you
choose the Lambda function, choose Congure test event from the Actions menu to specify the
following sample event data:

{ "firstName": "first-name", "lastName": "last-name" }

2. Verify the results in the console.

Execution result should be Succeeded with the following return value:

{
"greetings": "Hello first-name, last-name."

279
AWS Lambda Developer Guide
Tutorial

Review the Summary and the Log output sections.

To test the Lambda function (AWS CLI)

1. Save the following sample event JSON in a le, input.txt.

{ "firstName": "first-name", "lastName": "last-name" }

2. Execute the following invoke command:

$ aws lambda invoke \


--invocation-type Event \
--function-name AndroidBackendLambdaFunction \
--region us-east-1 \
--payload file://file-path/input.txt \
--profile adminuser
outputfile.txt

Note
In this tutorial example, the message is saved in the outputfile.txt le. If you request
synchronous execution (RequestResponse as the invocation type), the function returns the
string message in the response body.
For Node.js, it could be one of the following (whatever one you specify in the code):
context.succeed("message")
context.fail("message")
context.done(null, "message)
For Java, it is the message in the return statement:
return "message"

Next Step

Step 3: Create an Amazon Cognito Identity Pool (p. 280)

Step 3: Create an Amazon Cognito Identity Pool


In this section, you create an Amazon Cognito identity pool. The identity pool has two IAM
roles. You update the IAM role for unauthenticated users and grant permissions to execute the
AndroidBackendLambdaFunction Lambda function.

For more information about IAM roles, see IAM Roles in the IAM User Guide. For more information about
Amazon Cognito services, see the Amazon Cognito product detail page.

To create an identity pool

1. Using the IAM User Sign-In URL, sign in to the Amazon Cognito console as adminuser.
2. Create a new identity pool called JavaFunctionAndroidEventHandlerPool. Before you follow the
procedure to create an identity pool, note the following:

The identity pool you are creating must allow access to unauthenticated identities because
our example mobile application does not require a user log in (the application users are
unauthenticated). Therefore, make sure to select the Enable access to unauthenticated
identities option.
The unauthenticated application users need permission to invoke the Lambda function. To
enable this, you will add the following statement to the permission policy associated with the

280
AWS Lambda Developer Guide
Tutorial

unauthenticated identities (it allows permission for the for the lambda:InvokeFunction action on
the specic Lambda function (you must update the resource ARN by providing your account ID).

{
"Effect": "Allow",
"Action": [
"lambda:InvokeFunction"
],
"Resource": [
"arn:aws:lambda:us-east-1:account-
id:function:AndroidBackendLambdaFunction"
]
}

The resulting policy will be as follows:

{
"Version":"2012-10-17",
"Statement":[
{
"Effect":"Allow",
"Action":[
"mobileanalytics:PutEvents",
"cognito-sync:*"
],
"Resource":[
"*"
]
},
{
"Effect":"Allow",
"Action":[
"lambda:invokefunction"
],
"Resource":[
"arn:aws:lambda:us-east-1:account-
id:function:AndroidBackendLambdaFunction"
]
}
]
}

Note
You can update policy at the time of creating the identity pool. You can also update the
policy after you create the identity pool, in which case make sure you write down the IAM
role name for the unauthenticated users from the Amazon Cognito console. Then, go to
the IAM console and search for the specic role and edit the access permissions policy.

For instructions about how to create an identity pool, log in to the Amazon Cognito console and
follow the New Identity Pool wizard.
3. Note down the identity pool ID. You specify this ID in your mobile application you create in the next
section. The app uses this ID when it sends request to Amazon Cognito to request for temporary
security credentials.

Next Step
Step 4: Create a Mobile Application for Android (p. 282)

281
AWS Lambda Developer Guide
Tutorial

Step 4: Create a Mobile Application for Android


Now you can create a simple Android mobile application that generates events and invokes Lambda
functions by passing the event data as parameters.

The following instructions have been veried using Android studio.

1. Create a new Android project called AndroidEventGenerator using the following conguration:

Select the Phone and Tablet platform.


Choose Blank Activity.
2. In the build.gradle (Module:app) le, add the following in the dependencies section:

compile 'com.amazonaws:aws-android-sdk-core:2.2.+'
compile 'com.amazonaws:aws-android-sdk-lambda:2.2.+'

3. Build the project so that the required dependencies are downloaded, as needed.
4. In the Android application manifest (AndroidManifest.xml), add the following permissions so that
your application can connect to the Internet. You can add them just before the </manifest> end tag.

<uses-permission android:name="android.permission.INTERNET" />


<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />

5. In MainActivity, add the following imports:

import com.amazonaws.mobileconnectors.lambdainvoker.*;
import com.amazonaws.auth.CognitoCachingCredentialsProvider;
import com.amazonaws.regions.Regions;

6. In the package section, add the following two classes (RequestClass and ResponseClass). Note that
the POJO is same as the POJO you created in your Lambda function in the preceding section.

RequestClass. The instances of this class act as the POJO (Plain Old Java Object) for event data
which consists of rst and last name. If you are using Java example for your Lambda function
you created in the preceding section, this POJO is same as the POJO you created in your Lambda
function code.

package com.example....lambdaeventgenerator;
public class RequestClass {
String firstName;
String lastName;

public String getFirstName() {


return firstName;
}

public void setFirstName(String firstName) {


this.firstName = firstName;
}

public String getLastName() {


return lastName;
}

public void setLastName(String lastName) {


this.lastName = lastName;
}

public RequestClass(String firstName, String lastName) {


this.firstName = firstName;

282
AWS Lambda Developer Guide
Tutorial

this.lastName = lastName;
}

public RequestClass() {
}
}

ResponseClass

package com.example....lambdaeventgenerator;
public class ResponseClass {
String greetings;

public String getGreetings() {


return greetings;
}

public void setGreetings(String greetings) {


this.greetings = greetings;
}

public ResponseClass(String greetings) {


this.greetings = greetings;
}

public ResponseClass() {
}
}

7. In the same package, create interface called MyInterface for invoking the
AndroidBackendLambdaFunction Lambda function.

Note
The @LambdaFunction annotation in the code maps the specic client method to the same-
name Lambda function. For more information about this annotation, see AWS Lambda in
the AWS Mobile SDK for Android Developer Guide.

package com.example.....lambdaeventgenerator;
import com.amazonaws.mobileconnectors.lambdainvoker.LambdaFunction;
public interface MyInterface {

/**
* Invoke the Lambda function "AndroidBackendLambdaFunction".
* The function name is the method name.
*/
@LambdaFunction
ResponseClass AndroidBackendLambdaFunction(RequestClass request);

8. To keep the application simple, we are going to add code to invoke the Lambda function in
the onCreate() event handler. In MainActivity, add the following code toward the end of the
onCreate() code.

// Create an instance of CognitoCachingCredentialsProvider


CognitoCachingCredentialsProvider cognitoProvider = new
CognitoCachingCredentialsProvider(
this.getApplicationContext(), "identity-pool-id", Regions.US_WEST_2);

// Create LambdaInvokerFactory, to be used to instantiate the Lambda proxy.


LambdaInvokerFactory factory = new LambdaInvokerFactory(this.getApplicationContext(),
Regions.US_WEST_2, cognitoProvider);

283
AWS Lambda Developer Guide
Scheduled Events

// Create the Lambda proxy object with a default Json data binder.
// You can provide your own data binder by implementing
// LambdaDataBinder.
final MyInterface myInterface = factory.build(MyInterface.class);

RequestClass request = new RequestClass("John", "Doe");


// The Lambda function invocation results in a network call.
// Make sure it is not called from the main thread.
new AsyncTask<RequestClass, Void, ResponseClass>() {
@Override
protected ResponseClass doInBackground(RequestClass... params) {
// invoke "echo" method. In case it fails, it will throw a
// LambdaFunctionException.
try {
return myInterface.AndroidBackendLambdaFunction(params[0]);
} catch (LambdaFunctionException lfe) {
Log.e("Tag", "Failed to invoke echo", lfe);
return null;
}
}

@Override
protected void onPostExecute(ResponseClass result) {
if (result == null) {
return;
}

// Do a toast
Toast.makeText(MainActivity.this, result.getGreetings(),
Toast.LENGTH_LONG).show();
}
}.execute(request);

9. Run the code and verify it as follows:

The Toast.makeText() displays the response returned.


Verify that CloudWatch Logs shows the log created by the Lambda function. It should show the
event data (rst name and last name). You can also verify this in the AWS Lambda console.

Using AWS Lambda with Scheduled Events


You can create a Lambda function and direct AWS Lambda to execute it on a regular schedule. You
can specify a xed rate (for example, execute a Lambda function every hour or 15 minutes), or you can
specify a Cron expression. For more information on expressions schedules, see Schedule Expressions
Using Rate or Cron (p. 288).

This functionality is available when you create a Lambda function using the AWS Lambda console or the
AWS CLI. To congure it using the AWS CLI, see Run an AWS Lambda Function on a Schedule Using the
AWS CLI. The console provides the CloudWatch Events - Schedule as an event source. At the time of
creating a Lambda function, you choose this event source and specify a time interval.

If you have made any manual changes to the permissions on your function, you may need to reapply the
scheduled event access to your function. You can do that by using the following CLI command.

aws lambda add-permission \


--statement-id 'statement id' \
--action 'lambda:InvokeFunction' \
--principal events.amazonaws.com \
--source-arn arn:aws:events:region:account-id:rule/rule_name
--function-name function:MyFunction

284
AWS Lambda Developer Guide
Tutorial

--region region

Note
Each AWS account can have up to 100 unique event sources of the CloudWatch Events -
Schedule source type. Each of these can be the event source for up to ve Lambda functions.
That is, you can have up to 500 Lambda functions that can be executing on a schedule in your
AWS account.

The console also provides a blueprint (lambda-canary) that uses the CloudWatch Events - Schedule
source type. Using this blueprint, you can create a sample Lambda function and test this feature. The
example code that the blueprint provides checks for the presence of a specic webpage and specic text
string on the webpage. If either the webpage or the text string is not found, the Lambda function throws
an error.

For a tutorial that walks you through an example setup, see Tutorial: Using AWS Lambda with Scheduled
Events (p. 285).

Tutorial: Using AWS Lambda with Scheduled Events


In this tutorial, you do the following:

Create a Lambda function using the lambda-canary blueprint. You congure the Lambda function
to run every minute. Note that if the function returns an error, AWS Lambda logs error metrics to
CloudWatch.
Congure a CloudWatch alarm on the Errors metric of your Lambda function to post a message to
your Amazon SNS topic when AWS Lambda emits error metrics to CloudWatch. You subscribe to the
Amazon SNS topics to get email notication. In this tutorial, you do the following to set this up:
Create an Amazon SNS topic.
Subscribe to the topic so you can get email notications when a new message is posted to the topic.
In Amazon CloudWatch, set an alarm on the Errors metric of your Lambda function to publish a
message to your SNS topic when errors occur.

Next Step
Step 1: Create a Lambda Function (p. 285)

Step 1: Create a Lambda Function


1. Sign in to the AWS Management Console and open the AWS Lambda console at https://
console.aws.amazon.com/lambda/.
2. Choose Create a Lambda function.
3. In Select blueprint, choose the lambda-canary blueprint.
4. In Congure triggers:

Choose CloudWatch Events - Schedule.


In Rule name, type a name (for example, CheckWebsiteScheduledEvent).
In Rule description, type a description (for example, CheckWebsiteScheduledEvent trigger).
In Schedule expression, specify rate(1 minute). Note that you can specify the value as a rate or
in the cron expression format. All schedules use the UTC time zone, and the minimum precision
for schedules is one minute.

285
AWS Lambda Developer Guide
Tutorial

Note
When setting a rate expression, the rst execution is immediate and subsequent
executions occur based on the rate schedule. In the preceding example, the subsequent
execution rate would be every minute.

For more information on expressions schedules, see Schedule Expressions Using Rate or
Cron (p. 288).


In Enable trigger, we recommend that you leave the trigger in a disabled state until you have
tested it.
Choose Next.
5. In Congure function, do the following:

Specify your Lambda function name (for example, CheckWebsitePeriodically).


In Runtime, specify Python3.6, Python 2.7, Node.js 6.10 or Node.js 4.3, depending on your
preferred language.
Review the code provided by the template. Later in this tutorial, you will update the function
code so that the function will return an error. You can either specify a non-existing URL or replace
search text to a string that is not on the page.
In Role*, choose Create new role from template(s).
In Role name, type a name for the role.
In Policy templates, Lambda provides a list of optional, additional templates that extend the basic
Lambda permissions. For the purpose of this tutorial, you can leave this eld blank because your
Lambda function already has the basic execution permission it needs.
In Advanced settings, leave the default congurations and choose Next.
6. In Review, review the conguration and then choose Create Function.

Next Step
Step 2: Test the Lambda Function (Using a Sample Test Event) (p. 286)

Step 2: Test the Lambda Function (Using a Sample Test Event)


1. Choose the function you created in the previous step and then choose Test.
2. On the Input sample event page, choose Scheduled Event in the Sample event list.

Note the event time in the sample event. This value will be dierent when AWS Lambda invokes the
function at scheduled intervals. The sample Lambda function code logs this time to CloudWatch
Logs.
3. Choose Save and test and verify that the Execution result section shows success.

Next Step
Step 3: Create an Amazon SNS Topic and Subscribe to It (p. 286)

Step 3: Create an Amazon SNS Topic and Subscribe to It


1. Create an SNS topic using the Amazon SNS console. For instructions, see Create a Topicin the
Amazon Simple Notication Service Developer Guide.
2. Subscribe to the topic. For this exercise, use email as the communication protocol. For instructions,
see Subscribe to a Topic in the Amazon Simple Notication Service Developer Guide.

286
AWS Lambda Developer Guide
Tutorial

You use this Amazon SNS topic in the next step when you congure a CloudWatch alarm so that when
AWS Lambda emits an error the alarm will publish a notication to this topic.

Next Step
Step 4: Congure a CloudWatch Alarm (p. 287)

Step 4: Congure a CloudWatch Alarm


To congure a CloudWatch alarm, follow the instructions at Create Alarm in the Amazon CloudWatch
User Guide. As you follow the steps, note the following:

In Create Alarm (1. Select Metric step), choose Lambda Metrics, and then choose the Errors (Metric
Name is Errors) for the Lambda function you created. Also, on the statistics drop-down, change the
settings from Average to Sum statistics.
In Create Alarm (2. Dene Metric step), set the alarm threshold to Whenever: Errors is >= 1 and
select your Amazon SNS topic from the Send notication to: list.

Next Step
Step 5: Test the Lambda Function Again (p. 287)

Step 5: Test the Lambda Function Again


Now test the Lambda function again. This time, update the code by specifying either a non-existing
webpage URL or a text string. This causes the function to return an error that AWS Lambda sends to
CloudWatch error metrics. CloudWatch posts this message to the Amazon SNS topic and you get an
email notication.

Step 6: Deploy With AWS SAM and AWS CloudFormation


In the previous section, you used AWS Lambda APIs to create and update a Lambda function by
providing a deployment package as a ZIP le. However, this mechanism may not be convenient for
automating deployment steps for functions, or coordinating deployments and updates to other elements
of a serverless application, like event sources and downstream resources.

You can use AWS CloudFormation to easily specify, deploy, and congure serverless applications. AWS
CloudFormation is a service that helps you model and set up your Amazon Web Services resources so
that you can spend less time managing those resources and more time focusing on your applications
that run in AWS. You create a template that describes all the AWS resources that you want (like Lambda
functions and DynamoDB tables), and AWS CloudFormation takes care of provisioning and conguring
those resources for you.

In addition, you can use the AWS Serverless Application Model to express resources that comprise the
serverless application. These resource types, such as Lambda functions and APIs, are fully supported by
AWS CloudFormation and make it easier for you to dene and deploy your serverless application.

For more information, see Deploying Lambda-based Applications (p. 144).

Specication for Scheduled Event Application


The following contains the SAM template for this application. Copy the text below to a .yaml le and
save it next to the ZIP package you created previously. Make sure the Runtime: parameter value matches
the one you chose in the previous section.

AWSTemplateFormatVersion: '2010-09-09'
Transform: AWS::Serverless-2016-10-31
Parameters:

287
AWS Lambda Developer Guide
Tutorial

NotificationEmail:
Type: String
Resources:
CheckWebsitePeriodically:
Type: AWS::Serverless::Function
Properties:
Handler: LambdaFunctionOverHttps.handler
Runtime: runtime
Policies: AmazonDynamoDBFullAccess
Events:
CheckWebsiteScheduledEvent:
Type: Schedule
Properties:
Schedule: rate(1 minute)

AlarmTopic:
Type: AWS::SNS::Topic
Properties:
Subscription:
- Protocol: email
Endpoint: !Ref NotificationEmail

Alarm:
Type: AWS::CloudWatch::Alarm
Properties:
AlarmActions:
- !Ref AlarmTopic
ComparisonOperator: GreaterThanOrEqualToThreshold
Dimensions:
- Name: FunctionName
Value: !Ref CheckWebsitePeriodically
EvaluationPeriods: String
MetricName: Errors
Namespace: AWS/Lambda
Period: '60'
Statistic: Sum
Threshold: '1'

Deploying the Serverless Application


For information on how to package and deploy your serverless application using the package and deploy
commands, see Packaging and Deployment (p. 150).

Schedule Expressions Using Rate or Cron


Rate expression

rate(Value Unit)

Where:

Value can be a positive integer.

Unit can be minute(s), hour(s), or day(s).

For example:

Example Cron expression

Invoke Lambda function every 5 minutes


rate(5 minutes)

288
AWS Lambda Developer Guide
Tutorial

Example Cron expression

Invoke Lambda function every hour


rate(1 hour)

Invoke Lambda function every seven days


rate(7 days)

Note the following:

Rate frequencies of less than one minute are not supported.


For a singular value the unit must be singular (for example, rate(1 day)), otherwise plural (for
example, rate(5 days)).

Cron expression

cron(Minutes Hours Day-of-month Month Day-of-week Year)

All elds are required and time zone is UTC only. The following table describes these elds.

Field Values Wildcards

Minutes 0-59 ,-*/

Hours 0-23 ,-*/

Day-of-month 1-31 ,-*?/LW

Month 1-12 or JAN-DEC ,-*/

Day-of-week 1-7 or SUN-SAT ,-*?/L#

Year 1970-2199 ,-*/

The following table describes the wildcard characters.

Character Denition Example

/ Species 0/15 in the minutes eld directs execution to occur every 15


increments minutes.

L Species "Last" If used in Day-of-month eld, species last day of the


month. If used in Day-of-week eld, species last day of the
week (Saturday).

W Species Weekday When used with a date, such as 5/W, species the closest
weekday to 5th day of the month. If the 5th falls on a
Saturday, execution occurs on Friday. If the 5th falls on a
Sunday, execution occurs on Monday.

# Species the nd Specifying 3#2 means the second Tuesday of the month
or nth day of the (Tuesday is the third day of the 7-day week).
month

289
AWS Lambda Developer Guide
Custom User Applications

Character Denition Example

* Species All values If used in the Day-of-month eld, it means all days in the
month.

? No specied value Used in conjunction with another specied value. For


example, if a specic date is specied, but you don't care
what day of the week it falls on.

- Species ranges 10-12 would mean 10, 11 and 12

, Species SUN, MON, TUE means Sunday, Monday and Tuesday


additional values

/ Species 5/10 means 5, 15, 25, 35, etc.


increments

The following table lists common examples of cron expressions.

Example Cron expression

Invoke a Lambda function at


cron(0 10 * * ? *)
10:00am (UTC) everyday

Invoke a Lambda function


cron(15 12 * * ? *)
12:15pm (UTC) everyday

Invoke a Lambda function at


cron(0 18 ? * MON-FRI *)
06:00pm (UTC) every Mon-Fri

Invoke a Lambda function at


cron(0 8 1 * ? *)
8:00am (UTC) every rst day of
the month

Invoke a Lambda function every


cron(0/10 * ? * MON-FRI *)
10 min Mon-Fri

Invoke a Lambda function every


cron(0/5 8-17 ? * MON-FRI *)
5 minutes Mon-Fri between
8:00am and 5:55pm (UTC)

Invoke a Lambda function at 9


cron(0 9 ? * 2#1 *)
a.m. (UTC) the rst Monday of
each month

Note the following:

Cron expressions that lead to rates faster than one minute are not supported.
One of the day-of-month or day-of-week values must be a question mark (?).

Using AWS Lambda with Custom User Applications


One of the use cases for using AWS Lambda is to process events generated by a user application. For
demonstration purposes, you don't need to write a user application that invokes your Lambda function.

290
AWS Lambda Developer Guide
Tutorial

Instead, the tutorial provided in this section provides sample event data that you can use and then you
invoke your Lambda function manually.

When a user application invokes a Lambda function, it's an example of the AWS Lambda request-response
model in which an application invokes a Lambda function and receives a response in real time. For more
information, see How It Works (p. 175).

For a tutorial that walks you through an example setup, see Tutorial: Using AWS Lambda with Custom
User Applications (p. 291).

Tutorial: Using AWS Lambda with Custom User


Applications
In this tutorial, you use the AWS CLI to create and invoke a Lambda function and explore other AWS
Lambda APIs.

You'll do the following:

Create a Lambda function to process an event it receives as a parameter. You use the following
example Node.js code to create your Lambda function.

console.log('Loading function');

exports.handler = function(event, context, callback) {


console.log('value1 =', event.key1);
console.log('value2 =', event.key2);
console.log('value3 =', event.key3);
callback(null,"Success");

};

Note
The code sample is compliant with the Node.js runtime v4.3. For more information, see
Programming Model (Node.js) (p. 9)

The function is simple. It processes incoming event data by logging it (these logs are available in
Amazon CloudWatch), and in the request-response model, you can request the log data be returned in
the response.
Simulate a user application that sends an event to your Lambda function by invoking your Lambda
function manually using the following sample event data.

{
"key1": "value1",
"key2": "value2",
"key3": "value3"
}

Note
This example is similar to the Getting Started exercise (see Getting Started (p. 185)). The
dierence is that the Getting Started exercise provides a console-based experience. The console
does many things for you, which simplies the experience. When using the AWS CLI, you get
the experience of making the API calls, which can help you develop a better understanding of
the AWS Lambda operations. In addition to creating and invoking a Lambda function, you can
explore other Lambda APIs.

291
AWS Lambda Developer Guide
Tutorial

Next Step
Step 1: Prepare (p. 292)

Step 1: Prepare
Make sure you have completed the following steps:

Signed up for an AWS account and created an administrator user in the account.
Installed and set up the AWS CLI.

For instructions, see Step 1: Set Up an AWS Account and the AWS CLI (p. 185).

Next Step
Step 2: Create a Lambda Function and Invoke It Manually (p. 292)

Step 2: Create a Lambda Function and Invoke It Manually


In this section, you do the following:

Create a deployment package. A deployment package is a .zip le that contains your code and any
dependencies. For this tutorial there are no dependencies, you only have a simple example code.
Create an IAM role (execution role). At the time you upload the deployment package, you need to
specify an IAM role (execution role) that Lambda can assume to execute the function on your behalf.

You also grant this role the permissions that your Lambda function needs. The code in this tutorial
writes logs to Amazon CloudWatch Logs. So you need to grant permissions for CloudWatch actions.
For more information, see AWS Lambda Watch Logs.
Create a Lambda function (HelloWorld) using the create-function CLI command. For more
information about the underlying API and related parameters, see CreateFunction (p. 366).

Topics
Step 2.1: Create a Lambda Function Deployment Package (p. 292)
Step 2.2: Create the Execution Role (IAM Role) (p. 293)
Step 2.3: Create a Lambda Function (p. 294)
Next Step (p. 294)

Step 2.1: Create a Lambda Function Deployment Package


Follow the instructions to create an AWS Lambda function deployment package.

1. Open a text editor, and then copy the following code.

console.log('Loading function');

exports.handler = function(event, context, callback) {


console.log('value1 =', event.key1);
console.log('value2 =', event.key2);
console.log('value3 =', event.key3);
callback(null, "Success");

};

292
AWS Lambda Developer Guide
Tutorial

Note
The code sample is compliant with the Node.js runtimes v6.10 ore v4.3. For more
information, see Programming Model (Node.js) (p. 9)
2. Save the le as helloworld.js.
3. Zip the helloworld.js le as helloworld.zip.

Note
To see more examples of using other AWS services within your function, including calling other
Lambda functions, see AWS SDK for JavaScript

Step 2.2: Create the Execution Role (IAM Role)


When the Lambda function in this tutorial executes, it needs permissions to write logs to Amazon
CloudWatch. You grant these permissions by creating an IAM role (execution role). AWS Lambda assumes
this role when executing your Lambda function on your behalf. In this section, you create an IAM role
using the following predened role type and access policy:

AWS service role of the "AWS Lambda" type. This role grants AWS Lambda permission to assume the
role.
"AWSLambdaBasicExecutionRole" access policy that you attach to the role. This existing policy grants
permissions that include permissions for Amazon CloudWatch actions that your Lambda function
needs.

For more information about IAM roles, see IAM Roles in the IAM User Guide.

In this section, you create an IAM role using the following predened role type and access permissions
policy:

AWS service role of the type AWS Lambda This role grants AWS Lambda permissions to assume the
role.
AWSLambdaBasicExecutionRole access permissions policy that you attach to the role.

For more information about IAM roles, see IAM Roles in the IAM User Guide. Use the following procedure
to create the IAM role.

To create an IAM role (execution role)

1. Sign in to the AWS Management Console and open the IAM console at https://
console.aws.amazon.com/iam/.
2. Follow the steps in Creating a Role to Delegate Permissions to an AWS Service in the IAM User Guide
to create an IAM role (execution role). As you follow the steps to create a role, note the following:

In Role Name, use a name that is unique within your AWS account (for example, lambda-custom-
app-execution-role).
In Select Role Type, choose AWS Service Roles, and then choose AWS Lambda. This grants the
AWS Lambda service permissions to assume the role.
In Attach Policy, choose AWSLambdaBasicExecutionRole.
3. Write down the role ARN. You will need it in the next step when you create your Lambda function.

293
AWS Lambda Developer Guide
Tutorial

Step 2.3: Create a Lambda Function


Execute the following Lambda CLI create-function command to create a Lambda function. You provide
the deployment package and IAM role ARN as parameters. Note that the Runtime parameter uses
nodejs6.10 but you can also specify nodejs4.3.

$ aws lambda create-function \


--region us-west-2 \
--function-name helloworld \
--zip-file fileb://file-path/helloworld.zip \
--role role-arn \
--handler helloworld.handler \
--runtime nodejs6.10 \
--profile adminuser

Optionally, you can upload the .zip le to an Amazon S3 bucket in the same AWS region, and then
specify the bucket and object name in the preceding command. You need to replace the --zip-file
parameter by the --code parameter, as shown following:

--code S3Bucket=bucket-name,S3Key=zip-file-object-key

For more information, see CreateFunction (p. 366). AWS Lambda creates the function and returns
function conguration information as shown in the following example:

{
"FunctionName": "helloworld",
"CodeSize": 351,
"MemorySize": 128,
"FunctionArn": "function-arn",
"Handler": "helloworld.handler",
"Role": "arn:aws:iam::account-id:role/LambdaExecRole",
"Timeout": 3,
"LastModified": "2015-04-07T22:02:58.854+0000",
"Runtime": "nodejs6.10",
"Description": ""
}

Next Step
Step 3: Invoke the Lambda Function (AWS CLI) (p. 294)

Step 3: Invoke the Lambda Function (AWS CLI)


In this section, you invoke your Lambda function manually using the invoke AWS CLI command.

$ aws lambda invoke \


--invocation-type RequestResponse \
--function-name helloworld \
--region us-west-2 \
--log-type Tail \
--payload '{"key1":"value1", "key2":"value2", "key3":"value3"}' \
--profile adminuser \
outputfile.txt

If you want you can save the payload to a le (for example, input.txt) and provide the le name as a
parameter.

294
AWS Lambda Developer Guide
Tutorial

--payload file://input.txt \

The preceding invoke command species RequestResponse as the invocation type, which returns a
response immediately in response to the function execution. Alternatively, you can specify Event as the
invocation type to invoke the function asynchronously.

By specifying the --log-type parameter, the command also requests the tail end of the log produced
by the function. The log data in the response is base64-encoded as shown in the following example
response:

{
"LogResult": "base64-encoded-log",
"StatusCode": 200
}

On Linux and Mac, you can use the base64 command to decode the log.

$ echo base64-encoded-log | base64 --decode

The following is a decoded version of an example log.

START RequestId: 16d25499-d89f-11e4-9e64-5d70fce44801


2015-04-01T18:44:12.323Z 16d25499-d89f-11e4-9e64-5d70fce44801 value1 = value1
2015-04-01T18:44:12.323Z 16d25499-d89f-11e4-9e64-5d70fce44801 value2 = value2
2015-04-01T18:44:12.323Z 16d25499-d89f-11e4-9e64-5d70fce44801 value3 = value3
2015-04-01T18:44:12.323Z 16d25499-d89f-11e4-9e64-5d70fce44801 result: "value1"
END RequestId: 16d25499-d89f-11e4-9e64-5d70fce44801
REPORT RequestId: 16d25499-d89f-11e4-9e64-5d70fce44801
Duration: 13.35 ms Billed Duration: 100 ms Memory Size: 128 MB
Max Memory Used: 9 MB

For more information, see Invoke (p. 401).

Because you invoked the function using the RequestResponse invocation type, the function executes and
returns the object you passed to the context.succeed() in real time when it is called. In this tutorial, you
see the following text written to the outputfile.txt you specied in the CLI command:

"value1"

Note
You are able to execute this function because you are using the same AWS account to create
and invoke the Lambda function. However, if you want to grant cross-account permissions to
another AWS account or grant permissions to another an AWS service to execute the function,
you must add a permissions to the access permissions policy associated with the function. The
Amazon S3 tutorial, which uses Amazon S3 as the event source (see Tutorial: Using AWS Lambda
with Amazon S3 (p. 202)), grants such permissions to Amazon S3 to invoke the function.

You can monitor the activity of your Lambda function in the AWS Lambda console.

Sign in to the AWS Management Console and open the AWS Lambda console at https://
console.aws.amazon.com/lambda/.

The AWS Lambda console shows a graphical representation of some of the CloudWatch metrics in the
Cloudwatch Metrics at a glance section for your function.
For each graph, you can also choose the logs link to view the CloudWatch logs directly.

295
AWS Lambda Developer Guide
Tutorial

Next Step
Step 4: Try More CLI Commands (AWS CLI) (p. 296)

Step 4: Try More CLI Commands (AWS CLI)


Step 4.1: List the Lambda Functions in Your Account
In this section, you try AWS Lambda list function operations. Execute the following AWS CLI list-
functions command to retrieve a list of functions that you uploaded.

$ aws lambda list-functions \


--max-items 10 \
--profile adminuser

To illustrate the use of pagination, the command species the optional --max-items parameter to limit
the number of functions returned in the response. For more information, see ListFunctions (p. 414).
The following is an example response.

{
"Functions": [
{
"FunctionName": "helloworld",
"MemorySize": 128,
"CodeSize": 412,
"FunctionArn": "arn:aws:lambda:us-east-1:account-
id:function:ProcessKinesisRecords",
"Handler": "ProcessKinesisRecords.handler",
"Role": "arn:aws:iam::account-id:role/LambdaExecRole",
"Timeout": 3,
"LastModified": "2015-02-22T21:03:01.172+0000",
"Runtime": "nodejs6.10",
"Description": ""
},
{
"FunctionName": "ProcessKinesisRecords",
"MemorySize": 128,
"CodeSize": 412,
"FunctionArn": "arn:aws:lambda:us-east-1:account-
id:function:ProcessKinesisRecords",
"Handler": "ProcessKinesisRecords.handler",
"Role": "arn:aws:iam::account-id:role/lambda-execute-test-kinesis",
"Timeout": 3,
"LastModified": "2015-02-22T21:03:01.172+0000",
"Runtime": "nodejs6.10",
"Description": ""
},
...
],
"NextMarker": null

In response, Lambda returns a list of up to 10 functions. If there are more functions you can retrieve,
NextMarker provides a marker you can use in the next list-functions request; otherwise, the value is
null. The following list-functions AWS CLI command is an example that shows the --next-marker
parameter.

$ aws lambda list-functions \


--max-items 10 \

296
AWS Lambda Developer Guide
Tutorial

--marker value-of-NextMarker-from-previous-response \
--profile adminuser

Step 4.2: Get Metadata and a URL to Download Previously Uploaded Lambda
Function Deployment Packages
The Lambda CLI get-function command returns Lambda function metadata and a presigned URL that
you can use to download the function's .zip le (deployment package) that you uploaded to create the
function. For more information, see GetFunction (p. 390).

$ aws lambda get-function \


--function-name helloworld \
--region us-west-2 \
--profile adminuser

The following is an example response.

{
"Code": {
"RepositoryType": "S3",
"Location": "pre-signed-url"
},
"Configuration": {
"FunctionName": "helloworld",
"MemorySize": 128,
"CodeSize": 287,
"FunctionArn": "arn:aws:lambda:us-west-2:account-id:function:helloworld",
"Handler": "helloworld.handler",
"Role": "arn:aws:iam::account-id:role/LambdaExecRole",
"Timeout": 3,
"LastModified": "2015-04-07T22:02:58.854+0000",
"Runtime": "nodejs6.10",
"Description": ""
}

If you want the function conguration information only (not the presigned URL), you can use the
Lambda CLI get-function-configuration command.

$ aws lambda get-function-configuration \


--function-name helloworld \
--region us-west-2 \
--profile adminuser

Next Step

Step 5: Delete the Lambda Function and IAM Role (AWS CLI) (p. 297)

Step 5: Delete the Lambda Function and IAM Role (AWS CLI)
Execute the following delete-function command to delete the helloworld function.

$ aws lambda delete-function \


--function-name helloworld \
--region us-west-2 \
--profile adminuser

297
AWS Lambda Developer Guide
Tutorial

Delete the IAM Role


After you delete the Lambda function you can also delete the IAM role you created in the IAM console.
For information about deleting a role, see Deleting Roles or Instance Proles in the IAM User Guide.

298
AWS Lambda Developer Guide

AWS Lambda@Edge

Lambda@Edge lets you run Lambda functions at AWS Regions and Amazon CloudFront edge locations in
response to CloudFront events, without provisioning or managing servers. You can use Lambda functions
to change CloudFront requests and responses at the following points:

After CloudFront receives a request from a viewer (viewer request)


Before CloudFront forwards the request to the origin (origin request)
After CloudFront receives the response from the origin (origin response)
Before CloudFront forwards the response to the viewer (viewer response)

You can also generate responses to viewers without ever sending the request to the origin.

You write Lambda functions for CloudFront in Node.js 6.10. With Lambda@Edge, you can build a variety
of solutions, for example:

Inspect cookies to rewrite URLs to dierent versions of a site for A/B testing.
Send dierent objects to your users based on the User-Agent header, which contains information
about the device that submitted the request. For example, you can send images in dierent resolutions
to users based on their devices.

299
AWS Lambda Developer Guide
How You Create Lambda Functions for Lambda@Edge

Inspect headers or authorized tokens, inserting a corresponding header and allowing access control
before forwarding a request to the origin.
Add, delete, and modify headers, and rewrite the URL path to direct users to dierent objects in the
cache.
Generate new HTTP responses to do things like redirect unauthenticated users to login pages, or
create and deliver static webpages right from the edge. For more information, see Using Lambda
Functions to Generate HTTP Responses to Viewer and Origin Requests in the Amazon CloudFront
Developer Guide.

For more information about setting up CloudFront with Lambda@Edge, including sample code, see
Using CloudFront with Lambda@Edge in the Amazon CloudFront Developer Guide.

Topics
How You Create Lambda Functions for Lambda@Edge (p. 300)
Setting IAM Permissions and Roles for Lambda@Edge (p. 301)
Creating a Lambda@Edge Function and Creating a Trigger for a CloudFront Event (p. 303)
Adding Triggers for a Lambda@Edge Function (AWS Lambda Console) (p. 304)
Writing Functions for Lambda@Edge (p. 306)
Editing a Lambda Function for Lambda@Edge (p. 307)
Testing and Debugging (p. 309)
Lambda@Edge Limits (p. 309)

How You Create Lambda Functions for


Lambda@Edge
Here's an overview of how you create Lambda functions for Lambda@Edge:

1. You use Node.js 6.10 to write the code for your Lambda function.
2. Using the AWS Lambda console, you create a Lambda function in the US East (N. Virginia) Region. (You
can also create the function programmatically, for example, by using one of the AWS SDKs.) When you
create the function, you specify the following values:
The CloudFront distribution that you want the function to apply to
A cache behavior in the distribution
3. You publish a numbered version of the function.

If you want to edit the function, you edit it in the US East (N. Virginia) Region. You then publish a new
numbered version.
4. You specify one or more CloudFront events, known as triggers, that cause the function to execute.
For example, you can create a trigger that causes the function to execute when CloudFront receives a
request from a viewer.

When you create a trigger, Lambda replicates the function to AWS Regions and CloudFront edge
locations around the globe. Note that replicas can't be edited or deleted.

300
AWS Lambda Developer Guide
Setting IAM Permissions and Roles for Lambda@Edge

Setting IAM Permissions and Roles for


Lambda@Edge
To congure Lambda@Edge, you need IAM permissions and an IAM execution role:

IAM Permissions Required to Associate Lambda Functions with CloudFront Distributions

In addition to the IAM permissions that you need to use AWS Lambda, you need the following IAM
permissions to associate Lambda functions with CloudFront distributions:
lambda:GetFunction

For the resource, specify the ARN of the function version that you want to execute when a
CloudFront event occurs, as shown in the following example:

301
AWS Lambda Developer Guide
Setting IAM Permissions and Roles for Lambda@Edge

arn:aws:lambda:us-east-1:123456789012:function:TestFunction:2
lambda:EnableReplication*

For the resource, specify the ARN of the function version that you want to execute when a
CloudFront event occurs, as shown in the following example:

arn:aws:lambda:us-east-1:123456789012:function:TestFunction:2
iam:CreateServiceLinkedRole
cloudfront:UpdateDistribution or cloudfront:CreateDistribution

Choose cloudfront:UpdateDistribution to update a distribution or


cloudfront:CreateDistribution to create a distribution.

For more information, see the following documentation:


Authentication and Access Control for AWS Lambda (p. 320) in this guide
Authentication and Access Control for CloudFront in the Amazon CloudFront Developer Guide
Execution Role

You must create an IAM role that can be assumed by the service principals lambda.amazonaws.com
and edgelambda.amazonaws.com. This role is assumed by the service principals when they execute
your function. For more information, see Creating the Roles and Attaching the Policies (Console) in
the topic "AWS Managed Policies for Job Functions" in the IAM User Guide.

Here's an example role trust policy:

{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Principal": {
"Service": [
"lambda.amazonaws.com",
"edgelambda.amazonaws.com"
]
},
"Action": "sts:AssumeRole"
}
]
}

For information about the permissions that you need to grant to the execution role, see Manage
Permissions: Using an IAM Role (Execution Role) in the AWS Lambda Developer Guide. Note the
following:
By default, whenever a CloudFront event triggers a Lambda function, data is written to
CloudWatch Logs. If you want to use these logs, the execution role needs permission to write
data to CloudWatch Logs. You can use the predened AWSLambdaBasicExecutionRole to grant
permission to the execution role.

For more information about CloudWatch Logs, see CloudWatch Metrics and CloudWatch Logs for
Lambda Functions in the Amazon CloudFront Developer Guide.
If your Lambda function code accesses other AWS resources, such as reading an object from an S3
bucket, the execution role needs permission to perform that operation.

302
AWS Lambda Developer Guide
Creating a Lambda@Edge Function and
Creating a Trigger for a CloudFront Event

AWSServiceRoleForLambdaReplicator Role

When you rst create a trigger, a role named AWSServiceRoleForLambdaReplicator is automatically


created to allow Lambda to replicate Lambda@Edge functions to AWS Regions. This role is required
to use Lambda@Edge. The ARN for the AWSServiceRoleForLambdaReplicator role looks like this:

arn:aws:iam::123456789012:role/aws-service-role/replicator.lambda.amazonaws.com/
AWSServiceRoleForLambdaReplicator

Creating a Lambda@Edge Function and Creating a


Trigger for a CloudFront Event
To set up AWS Lambda to execute Lambda functions based on CloudFront events, perform the following
procedure:

To create a Lambda@Edge function and a trigger for a CloudFront event

1. Sign in to the AWS Management Console and open the AWS Lambda console at https://
console.aws.amazon.com/lambda/.
2. If you already have one or more Lambda functions, choose Create a Lambda function.

If you've don't have any functions, choose Get Started Now.


3. In the region list at the top of the page, choose US East (N. Virginia).
4. For Select runtime, choose Node.js 6.10.
5. For Filter, type cloudfront.
6. Choose the applicable blueprint.
7. On the Congure triggers page, you can optionally add a trigger to the function.
Important
If you add a trigger now, the function will start to execute after the function nishes
replicating to AWS Regions and edge locations, and the corresponding distribution is
deployed. We recommend that you test and debug the function before you add triggers. For
more information, see Testing and Debugging (p. 309).

If you don't want to add a trigger now:

If you chose Blank function, choose Next.


If you chose a dierent blueprint, choose Remove, and then choose Next.

If you do want to add a trigger now:

If you chose Blank function, choose the dotted box next to the Lambda icon, and then choose
CloudFront. Then enter the following values.
If you chose one of the cloudfront-* blueprints, enter the following values.

Note
You can add only one trigger when you create a Lambda function. You can add more
triggers later.

Distribution ID

Choose the ID of the distribution that you want to add the trigger to.

303
AWS Lambda Developer Guide
Adding Triggers for a Lambda@Edge
Function (AWS Lambda Console)

Cache behavior

Choose the cache behavior that species the objects that you want to execute the function on.
CloudFront event

Choose the CloudFront event that causes the function to execute.


Enable trigger and replicate

Select this check box so that AWS Lambda replicates the function to regions globally.
8. Choose Next.
9. In the Congure function section, specify the following values:

Name

Type a name for the function.


Description

The description that you type here is displayed in the list of functions that appears when you
open the Lambda console.
Runtime

You can't change the value from Node.js 6.10.


10. In the Lambda function code section, edit or import your code.
11. In the Lambda function handler and role section, specify the following values:

Handle

Specify the module-name.export value in your function.


Role

Choose Create new role from template(s).


Role name

Type a name for the new role.


Policy templates

Choose Basic Edge Lambda permissions.


12. In the Tags section, add tags if applicable.
13. Choose Next. (You can't change any settings in the Advanced settings section.)
14. On the Review page, choose Create function.
15. To add more triggers for the same function, see the following documentation:

Adding Triggers for a Lambda@Edge Function (AWS Lambda Console) (p. 304)
Adding Triggers for CloudFront Events (CloudFront Console) in the Amazon CloudFront Developer
Guide

Adding Triggers for a Lambda@Edge Function


(AWS Lambda Console)
When you create a Lambda function, you can specify only one triggeronly one combination of
CloudFront distribution, cache behavior, and event that causes the function to execute. You can add

304
AWS Lambda Developer Guide
Adding Triggers for a Lambda@Edge
Function (AWS Lambda Console)

more triggers to the same function by using the Lambda console or by editing the distribution in the
CloudFront console:

To use the Lambda console, perform the following procedure. This method works well if you want to
add more triggers to a function for the same CloudFront distribution.
To use the CloudFront console, see Adding Triggers for CloudFront Events to a Lambda Function in the
Amazon CloudFront Developer Guide. This method works well if you want to add triggers for multiple
distributions because it's easier to nd the distribution that you want to update. You can also update
other CloudFront settings at the same time.

To add triggers to a Lambda@Edge function (AWS Lambda console)

1. Sign in to the AWS Management Console and open the AWS Lambda console at https://
console.aws.amazon.com/lambda/.
2. In the region list at the top of the page, choose US East (N. Virginia).
3. On the Functions page, choose the name of the function that you want to add triggers for.
4. Choose Qualiers, and then choose the Versions tab.
5. Choose the version that you want to add triggers to.
Important
You can't create triggers for the $LATEST version, you must create them for a numbered
version.

After you choose a version, the name of the button changes to Version: $LATEST or Version: version
number.
6. Choose the Triggers tab.
7. Choose Add triggers.
8. In the Add trigger dialog box, choose the dotted box, and then choose CloudFront.
Note
If you've already created one or more triggers, CloudFront is the default service.
9. Specify the following values to indicate when you want the Lambda function to execute.

Distribution ID

Choose the ID of the distribution that you want to add the trigger to.
Cache behavior

Choose the cache behavior that species the objects that you want to execute the function on.
CloudFront event

Choose the CloudFront event that causes the function to execute.


Enable trigger and replicate

Select this check box so that AWS Lambda replicates the function to regions globally.
10. Choose Submit.

The function starts to process requests for the specied CloudFront events when the updated
CloudFront distribution is deployed. To determine whether a distribution is deployed, choose
Distributions in the navigation pane. When a distribution is deployed, the value of the Status
column for the distribution changes from In Progress to Deployed.

305
AWS Lambda Developer Guide
Writing Functions for Lambda@Edge

Writing Functions for Lambda@Edge


The programming model for using Node.js with Lambda@Edge is the same as using Lambda in an AWS
Region. For more information, see Programming Model (Node.js) (p. 9).

For more information about writing functions for Lambda@Edge, see Requirements and Restrictions on
Lambda Functions in the Amazon CloudFront Developer Guide.

We recommend that you include the callback parameter and return the applicable object:

Request events Include the cf.request object in the response.

If you're generating a response, include the cf.response object in the response. For more information,
see Using Lambda Functions to Generate HTTP Responses to Viewer and Origin Requests.
Response events Include the cf.response object in the response.

Examples
Example: A/B Testing (p. 306)
Example: HTTP Redirect (p. 307)

Example: A/B Testing


The following example shows how to use Lambda@Edge for A/B testing.

'use strict';

exports.handler = (event, context, callback) => {


const request = event.Records[0].cf.request;
const headers = request.headers;

if (request.uri !== '/experiment-pixel.jpg') {


// do not process if this is not an A-B test request
callback(null, request);
return;
}

const cookieExperimentA = 'X-Experiment-Name=A';


const cookieExperimentB = 'X-Experiment-Name=B';
const pathExperimentA = '/experiment-group/control-pixel.jpg';
const pathExperimentB = '/experiment-group/treatment-pixel.jpg';

/*
* Lambda at the Edge headers are array objects.
*
* Client may send multiple Cookie headers, i.e.:
* > GET /viewerRes/test HTTP/1.1
* > User-Agent: curl/7.18.1 (x86_64-unknown-linux-gnu) libcurl/7.18.1 OpenSSL/1.0.1u
zlib/1.2.3
* > Cookie: First=1; Second=2
* > Cookie: ClientCode=abc
* > Host: example.com
*
* You can access the first Cookie header at headers["cookie"][0].value
* and the second at headers["cookie"][1].value.
*
* Header values are not parsed. In the example above,
* headers["cookie"][0].value is equal to "First=1; Second=2"
*/
let experimentUri;

306
AWS Lambda Developer Guide
Example: HTTP Redirect

if (headers.cookie) {
for (let i = 0; i < headers.cookie.length; i++) {
if (headers.cookie[i].value.indexOf(cookieExperimentA) >= 0) {
console.log('Experiment A cookie found');
experimentUri = pathExperimentA;
break;
} else if (headers.cookie[i].value.indexOf(cookieExperimentB) >= 0) {
console.log('Experiment B cookie found');
experimentUri = pathExperimentB;
break;
}
}
}

if (!experimentUri) {
console.log('Experiment cookie has not been found. Throwing dice...');
if (Math.random() < 0.75) {
experimentUri = pathExperimentA;
} else {
experimentUri = pathExperimentB;
}
}

request.uri = experimentUri;
console.log(`Request uri set to "${request.uri}"`);
callback(null, request);
};

Example: HTTP Redirect


The following example shows how to generate HTTP redirect responses using Lambda functions that are
associated with CloudFront viewer request and origin request events. If you associate the function with
origin requests, the response is cached.
Note
You can generate HTTP responses only for viewer request and origin request events. For more
information, see Generating HTTP Responses in the Amazon CloudFront Developer Guide.

'use strict';

exports.handler = (event, context, callback) => {


/*
* Generate HTTP redirect response with 302 status code and Location header.
*/
const response = {
status: '302',
statusDescription: 'Found',
headers: {
location: [{
key: 'Location',
value: 'http://docs.aws.amazon.com/lambda/latest/dg/lambda-edge.html',
}],
},
};
callback(null, response);
};

Editing a Lambda Function for Lambda@Edge


When you want to edit a Lambda function, note the following:

307
AWS Lambda Developer Guide
Editing a Lambda Function for Lambda@Edge

The original version is labeled $LATEST.


You can edit only the $LATEST version.
Each time you edit the $LATEST version, you must publish a new numbered version.
You can't create triggers for $LATEST.
When you publish a new version of a function, Lambda doesn't automatically copy triggers from the
previous version to the new version. You must reproduce the triggers for the new version.
When you add a trigger for a CloudFront event to a function, if there's already a trigger for the same
distribution, cache behavior, and event for an earlier version of the same function, Lambda deletes the
trigger from the earlier version.

To edit a Lambda function (AWS Lambda console)

1. Sign in to the AWS Management Console and open the AWS Lambda console at https://
console.aws.amazon.com/lambda/.
2. In the region list at the top of the page, choose US East (N. Virginia).
3. In the list of functions, choose the name of the function that you want to edit.

By default, the console displays the $LATEST version. You can view earlier versions (choose
Qualiers), but you can only edit $LATEST.
4. On the Code tab, for Code entry type, choose to edit the code in the browser, upload a .zip le, or
upload a le from Amazon S3.
5. Choose either Save or Save and test.
6. Choose Actions, and choose Publish new version.
7. In the Publish new version from $LATEST dialog box, enter a description of the new version. This
description appears in the list of versions, along with an automatically generated version number.
8. Choose Publish.

The new version automatically becomes the latest version. The version number appears on the
Version button in the upper-left corner of the page.
9. Choose the Triggers tab.
10. Choose Add trigger.
11. In the Add trigger dialog box, choose the dotted box, and then choose CloudFront.
Note
If you've already created one or more triggers for a function, CloudFront is the default
service.
12. Specify the following values to indicate when you want the Lambda function to execute.

Distribution ID

Choose the ID of the distribution that you want to add the trigger to.
Cache behavior

Choose the cache behavior that species the objects that you want to execute the function on.
CloudFront event

Choose the CloudFront event that causes the function to execute.


Enable trigger and replicate

Select this check box so Lambda replicates the function to regions globally.
13. Choose Submit.
14. To add more triggers for this function, repeat steps 10 through 13.

308
AWS Lambda Developer Guide
Testing and Debugging

Testing and Debugging


You can test Lambda@Edge functions on the Lambda console with test events modeled on the
CloudFront events. However, the testing in the console only validates logic, and does not apply service
limits that are specic to Lambda@Edge.

You can create logging statements for Lambda functions running on Lambda@Edge that will write to
CloudWatch Logs. For more information, see CloudWatch Metrics and CloudWatch Logs for Lambda
Functions.

For more information, see the following topics in the Amazon CloudFront Developer Guide:

Lambda@Edge Event Structure


Requirements and Restrictions on Lambda Functions

Lambda@Edge Limits
Due to the constrained execution environment, Lambda@Edge has restrictions in addition to the default
Lambda limits. For more information, see the following documentation:

AWS Lambda Limits (p. 317) in this guide


Requirements and Restrictions on Lambda Functions in the Amazon CloudFront Developer Guide

Item Limit

Memory 128 MB

Timeout for CloudFront origin request and origin response 3 seconds


events. (The function can make network calls to resources
such as S3 buckets, DynamoDB tables, or EC2 instances in
AWS Regions.)

Timeout for CloudFront viewer request and viewer response 1 second


events. (The function can't make network calls.)

Maximum compressed size of your Lambda function and any 1 MB


included libraries

309
AWS Lambda Developer Guide
AWS Lambda Information in CloudTrail

Logging AWS Lambda API Calls By


Using AWS CloudTrail

AWS Lambda is integrated with AWS CloudTrail, a service that captures API calls made by or on behalf
of AWS Lambda in your AWS account and delivers the log les to an Amazon S3 bucket that you specify.
CloudTrail captures API calls made from the AWS Lambda console or from the AWS Lambda API. Using
the information collected by CloudTrail, you can determine what request was made to AWS Lambda,
the source IP address from which the request was made, who made the request, when it was made, and
so on. To learn more about CloudTrail, including how to congure and enable it, see the AWS CloudTrail
User Guide.

AWS Lambda Information in CloudTrail


When CloudTrail logging is enabled in your AWS account, API calls made to AWS Lambda actions are
tracked in log les. AWS Lambda records are written together with other AWS service records in a log
le. CloudTrail determines when to create and write to a new le based on a time period and le size.

The following actions are supported:

AddPermission (p. 354)


CreateEventSourceMapping (p. 361)
CreateFunction (p. 366)

(The ZipFile parameter is omitted from the CloudTrail logs for CreateFunction.)
DeleteEventSourceMapping (p. 376)
DeleteFunction (p. 379)
GetEventSourceMapping (p. 387)
GetFunction (p. 390)
GetFunctionConguration (p. 393)
GetPolicy (p. 398)
ListEventSourceMappings (p. 411)
ListFunctions (p. 414)
RemovePermission (p. 427)

310
AWS Lambda Developer Guide
Understanding AWS Lambda Log File Entries

UpdateEventSourceMapping (p. 436)


UpdateFunctionCode (p. 440)

(The ZipFile parameter is omitted from the CloudTrail logs for UpdateFunctionCode.)
UpdateFunctionConguration (p. 446)

Every log entry contains information about who generated the request. The user identity information
in the log helps you determine whether the request was made with root or IAM user credentials,
with temporary security credentials for a role or federated user, or by another AWS service. For more
information, see the userIdentity eld in the CloudTrail Event Reference.

You can store your log les in your bucket for as long as you want, but you can also dene Amazon S3
lifecycle rules to archive or delete log les automatically. By default, your log les are encrypted by using
Amazon S3 server-side encryption (SSE).

You can choose to have CloudTrail publish Amazon SNS notications when new log les are delivered if
you want to take quick action upon log le delivery. For more information, see Conguring Amazon SNS
Notications for CloudTrail.

You can also aggregate AWS Lambda log les from multiple AWS regions and multiple AWS accounts
into a single S3 bucket. For more information, see Working with CloudTrail Log Files.

Understanding AWS Lambda Log File Entries


CloudTrail log les contain one or more log entries where each entry is made up of multiple JSON-
formatted events. A log entry represents a single request from any source and includes information
about the requested action, any parameters, the date and time of the action, and so on. The log entries
are not guaranteed to be in any particular order. That is, they are not an ordered stack trace of the public
API calls.

The following example shows CloudTrail log entries for the GetFunction and DeleteFunction actions.

{
"Records": [
{
"eventVersion": "1.03",
"userIdentity": {
"type": "IAMUser",
"principalId": "A1B2C3D4E5F6G7EXAMPLE",
"arn": "arn:aws:iam::999999999999:user/myUserName",
"accountId": "999999999999",
"accessKeyId": "AKIAIOSFODNN7EXAMPLE",
"userName": "myUserName"
},
"eventTime": "2015-03-18T19:03:36Z",
"eventSource": "lambda.amazonaws.com",
"eventName": "GetFunction",
"awsRegion": "us-east-1",
"sourceIPAddress": "127.0.0.1",
"userAgent": "Python-httplib2/0.8 (gzip)",
"errorCode": "AccessDenied",
"errorMessage": "User: arn:aws:iam::999999999999:user/myUserName" is
not authorized to perform: lambda:GetFunction on resource: arn:aws:lambda:us-
west-2:999999999999:function:other-acct-function",
"requestParameters": null,
"responseElements": null,
"requestID": "7aebcd0f-cda1-11e4-aaa2-e356da31e4ff",
"eventID": "e92a3e85-8ecd-4d23-8074-843aabfe89bf",

311
AWS Lambda Developer Guide
Understanding AWS Lambda Log File Entries

"eventType": "AwsApiCall",
"recipientAccountId": "999999999999"
},
{
"eventVersion": "1.03",
"userIdentity": {
"type": "IAMUser",
"principalId": "A1B2C3D4E5F6G7EXAMPLE",
"arn": "arn:aws:iam::999999999999:user/myUserName",
"accountId": "999999999999",
"accessKeyId": "AKIAIOSFODNN7EXAMPLE",
"userName": "myUserName"
},
"eventTime": "2015-03-18T19:04:42Z",
"eventSource": "lambda.amazonaws.com",
"eventName": "DeleteFunction",
"awsRegion": "us-east-1",
"sourceIPAddress": "127.0.0.1",
"userAgent": "Python-httplib2/0.8 (gzip)",
"requestParameters": {
"functionName": "basic-node-task"
},
"responseElements": null,
"requestID": "a2198ecc-cda1-11e4-aaa2-e356da31e4ff",
"eventID": "20b84ce5-730f-482e-b2b2-e8fcc87ceb22",
"eventType": "AwsApiCall",
"recipientAccountId": "999999999999"
}
]
}

Note
The eventName may include date and version information, such as "GetFunction20150331", but
it is still referring to the same public API.

312
AWS Lambda Developer Guide
Function Code

Best Practices for Working with AWS


Lambda Functions

The following are recommended best practices for using AWS Lambda:

Topics
Function Code (p. 313)
Function Conguration (p. 314)
Alarming and Metrics (p. 314)
Stream Event Invokes (p. 315)
Async Invokes (p. 315)
Lambda VPC (p. 315)

Function Code
Separate the Lambda handler (entry point) from your core logic. This allows you to make a more
unit-testable function. In Node.js this may look like:

exports.myHandler = function(event, context, callback) {


var foo = event.foo;
var bar = event.bar;
var result = MyLambdaFunction (foo, bar);

callback(null, result);
}

function MyLambdaFunction (foo, bar) {


// MyLambdaFunction logic here
}

Take advantage of container re-use to improve the performance of your function. Make sure
any externalized conguration or dependencies that your code retrieves are stored and referenced
locally after initial execution. Limit the re-initialization of variables/objects on every invocation.
Instead use static initialization/constructor, global/static variables and singletons. Keep alive and reuse
connections (HTTP, database, etc.) that were established during a previous invocation.
Use Environment Variables (p. 92) to pass operational parameters to your function. For example, if
you are writing to an Amazon S3 bucket, instead of hard-coding the bucket name you are writing to,
congure the bucket name as an environment variable.

313
AWS Lambda Developer Guide
Function Conguration

Control the dependencies in your function's deployment package. The AWS Lambda execution
environment contains a number of libraries such the AWS SDK for the Node.js and Python runtimes (a
full list can be found here: Lambda Execution Environment and Available Libraries (p. 182)). To enable
the latest set of features and security updates, Lambda will periodically update these libraries. These
updates may introduce subtle changes to the behavior of your Lambda function. To have full control
of the dependencies your function uses, we recommend packaging all your dependencies with your
deployment package.
Minimize your deployment package size to its runtime necessities. This will reduce the amount of
time that it takes for your deployment package to be downloaded and unpacked ahead of invocation.
For functions authored in Java or .NET Core, avoid uploading the entire AWS SDK library as part of
your deployment package. Instead, selectively depend on the modules which pick up components of
the SDK you need (e.g. DynamoDB, Amazon S3 SDK modules and Lambda core libraries).
Reduce the time it takes Lambda to unpack deployment packages authored in Java by putting your
dependency .jar les in a separate /lib directory. This is faster than putting all your functions code in
a single jar with a large number of .class les.
Minimize the complexity of your dependencies. Prefer simpler frameworks that load quickly on
container startup. For example, prefer simpler Java dependency injection (IoC) frameworks like Dagger
or Guice, over more complex ones like Spring Framework.

Function Conguration
Performance testing your Lambda function is a crucial part in ensuring you pick the optimum
memory size conguration. Any increase in memory size triggers an equivalent increase in CPU
availabile to your function. The memory usage for your function is determined per-invoke and can be
viewed in AWS CloudWatch Logs. On each invoke a REPORT: entry will be made, as shown below:

REPORT RequestId: 3604209a-e9a3-11e6-939a-754dd98c7be3 Duration: 12.34 ms Billed


Duration: 100 ms Memory Size: 128 MB Max Memory Used: 18 MB

By analyzing the Max Memory Used: eld, you can determine if your function needs more memory or if
you over-provisioned your function's memory size.
Load test your Lambda function to determine an optimum timeout value. It is important to analyze
how long your function runs so that you can better determine any problems with a dependency
service that may increase the concurrency of the function beyond what you expect. This is especially
important when your Lambda function makes network calls to resources that may not handle
Lambda's scaling.
Use most-restrictive permissions when setting IAM policies. Understand the resources and
operations your Lambda function needs, and limit the execution role to these permissions. For more
information, see Authentication and Access Control for AWS Lambda (p. 320).
Be familiar with AWS Lambda Limits (p. 317). Payload size, le descriptors and /tmp space are
often overlooked when determining runtime resource limits.
Delete Lambda functions that you are no longer using. By doing so, the unused functions won't
needlessly count against your deployment package size limit.

Alarming and Metrics


Use AWS Lambda Metrics (p. 119) and CloudWatch Alarms instead of creating or updating a metric
from within your Lambda function code. It's a much more ecient way to track the health of your
Lambda functions, allowing you to catch issues early in the development process. For instance, you can
congure an alarm based on the expected duration of your Lambda function exection time in order to
address any bottlenecks or latencies attributable to your function code.

314
AWS Lambda Developer Guide
Stream Event Invokes

Leverage your logging library and AWS Lambda Metrics and Dimensions to catch app errors (e.g.
ERR, ERROR, WARNING, etc.)

Stream Event Invokes


Test with dierent batch and record sizes so that the polling frequency of each event source is tuned
to how quickly your function is able to complete its task. BatchSize controls the maximum number
of records that can be sent to your function with each invoke. A larger batch size can often more
eciently absorb the invoke overhead across a larger set of records, increasing your throughput.
Note
When there are not enough records to process, instead of waiting, the stream processing
function will be invoked with a smaller number of records.
Increase Kinesis stream processing throughput by adding shards. A Kinesis stream is composed
of one or more shards. Lambda will poll each shard with at most one concurrent invocation. For
example, if your stream has 100 active shards, there will be at most 100 Lambda function invocations
running concurrently. Increasing the number of shards will directly increase the number of maximum
concurrent Lambda function invocations and can increase your Kinesis stream processing throughput.
If you are increasing the number of shards in a Kinesis stream, make sure you have picked a good
partition key (see Partition Keys) for your data, so that related records end up on the same shards and
your data is well distributed.
Use Amazon CloudWatch on IteratorAge to determine if your Kinesis stream is being processed. For
example, congure a CloudWatch alarm with a maximum setting to 300000 (30 seconds).

Async Invokes
Create and use Dead Letter Queues (p. 121) to address and replay async function errors.

Lambda VPC
The following diagram guides you through a decision tree as to whether you should use a VPC (Virtual
Private Cloud):

315
AWS Lambda Developer Guide
Lambda VPC

Don't put your Lambda function in a VPC unless you have to. There is no benet outside of using
this to access resources you cannot expose publicly, like a private Amazon Relational Database
instance. Services like Amazon Elasticsearch Service can be secured over IAM with access policies, so
exposing the endpoint publicly is safe and wouldn't require you to run your function in the VPC to
secure it.
Lambda creates elastic network interfaces (ENIs) in your VPC to access your internal resources.
Before requesting a concurrency increase, ensure you have enough ENI capacity (the formula for this
can be found here: Conguring a Lambda Function to Access Resources in an Amazon VPC (p. 103))
and IP address space. If you do not have enough ENI capacity, you will need to request an increase. If
you do not have enough IP address space, you may need to create a larger subnet.
Create dedicated Lambda subnets in your VPC:
This will make it easier to apply a custom route table for NAT Gateway trac without changing your
other private/public subnets. For more information, see Conguring a Lambda Function to Access
Resources in an Amazon VPC (p. 103)
This also allows you to dedicate an address space to Lambda without sharing it with other resources.

316
AWS Lambda Developer Guide
List of AWS Lambda Limits

AWS Lambda Limits

This section discusses AWS Lambda limits.

Topics
List of AWS Lambda Limits (p. 317)
AWS Lambda Limit Errors (p. 318)

List of AWS Lambda Limits


Every Lambda function is allocated with a xed amount of specic resources regardless of the memory
allocation, and each function is allocated with a xed amount of code storage per function and per
account.

The following table lists the runtime resource limits for a Lambda function per invocation.

AWS Lambda Resource Limits per Invocation

Resource Limits

Memory allocation range Minimum = 128 MB / Maximum = 1536


MB (with 64 MB increments)

Ephemeral disk capacity ("/tmp" space) 512 MB

Number of le descriptors 1,024

Number of processes and threads (combined total) 1,024

Maximum execution duration per request 300 seconds

Invoke (p. 401) request body payload size 6 MB


(RequestResponse)

Invoke (p. 401) request body payload size (Event) 128 K

Invoke (p. 401) response body payload size 6 MB


(RequestResponse)

317
AWS Lambda Developer Guide
AWS Lambda Limit Errors

The following table lists the Lambda account limits per region.

AWS Lambda Account Limits Per Region

Resource Default Limit

Concurrent executions (see Lambda Function Concurrent 1000


Executions (p. 176))

To request a limit increase for concurrent execution

1. Open the AWS Support Center page, sign in, if necessary, and then click Create case.
2. Under Regarding, select Service Limit Increase.
3. Under Limit Type, select Lambda, ll in the necessary elds in the form, and then click the button at
the bottom of the page for your preferred method of contact.

Note
AWS may automatically raise the concurrent execution limit on your behalf to enable your
function to match the incoming event rate, as in the case of triggering the function from an
Amazon S3 bucket.

The following table lists service limits for deploying a Lambda function.

AWS Lambda Deployment Limits

Item Default Limit

Lambda function deployment package size 50 MB


(compressed .zip/.jar le)

Total size of all the deployment packages that can be 75 GB


uploaded per region

Size of code/dependencies that you can zip into a 250 MB


deployment package (uncompressed .zip/.jar size).
Note
Each Lambda function receives an additional
500MB of non-persistent disk space in its own
/tmp directory. The /tmp directory can be used
for loading additional resources like dependency
libraries or data sets during function initialization.

Total size of environment variables set 4 KB

AWS Lambda Limit Errors


Functions that exceed any of the limits listed in the previous limits tables will fail with an exceeded
limits exception. These limits are xed and cannot be changed at this time. For example, if you receive
the exception CodeStorageExceededException or an error message similar to "Code storage limit
exceeded" from AWS Lambda, you need to reduce the size of your code storage.

To reduce the size of your code storage

1. Remove the functions that you no longer use.

318
AWS Lambda Developer Guide
AWS Lambda Limit Errors

2. Reduce the code size of the functions that you do not want to remove. You can nd the code size of
a Lambda function by using the AWS Lambda console, the AWS Command Line Interface, or AWS
SDKs.

319
AWS Lambda Developer Guide
Authentication

Authentication and Access Control


for AWS Lambda

Access to AWS Lambda requires credentials that AWS can use to authenticate your requests. Those
credentials must have permissions to access AWS resources, such as an AWS Lambda function or an
Amazon S3 bucket. The following sections provide details on how you can use AWS Identity and Access
Management (IAM) and Lambda to help secure your resources by controlling who can access them:

Authentication (p. 320)


Access Control (p. 321)

Authentication
You can access AWS as any of the following types of identities:

AWS account root user When you sign up for AWS, you provide an email address and password
that is associated with your AWS account. This is your AWS account root user. Its credentials provide
complete access to all of your AWS resources.
Important
For security reasons, we recommend that you use the root user only to create an
administrator, which is an IAM user with full permissions to your AWS account. You can then
use this administrator user to create other IAM users and roles with limited permissions. For
more information, see IAM Best Practices and Creating an Admin User and Group in the IAM
User Guide.
IAM user An IAM user is simply an identity within your AWS account that has specic custom
permissions (for example, permissions to create a function in Lambda). You can use an IAM user name
and password to sign in to secure AWS webpages like the AWS Management Console, AWS Discussion
Forums, or the AWS Support Center.

320
AWS Lambda Developer Guide
Access Control

In addition to a user name and password, you can also generate access keys for each user. You can
use these keys when you access AWS services programmatically, either through one of the several
SDKs or by using the AWS Command Line Interface (CLI). The SDK and CLI tools use the access keys to
cryptographically sign your request. If you dont use the AWS tools, you must sign the request yourself.
Lambda supports Signature Version 4, a protocol for authenticating inbound API requests. For more
information about authenticating requests, see Signature Version 4 Signing Process in the AWS General
Reference.


IAM role An IAM role is another IAM identity that you can create in your account that has specic
permissions. It is similar to an IAM user, but it is not associated with a specic person. An IAM role
enables you to obtain temporary access keys that can be used to access AWS services and resources.
IAM roles with temporary credentials are useful in the following situations:


Federated user access Instead of creating an IAM user, you can use preexisting user identities from
AWS Directory Service, your enterprise user directory, or a web identity provider. These are known as
federated users. AWS assigns a role to a federated user when access is requested through an identity
provider. For more information about federated users, see Federated Users and Roles in the IAM User
Guide.


Cross-account access You can use an IAM role in your account to grant another AWS account
permissions to access your accounts resources. For an example, see Tutorial: Delegate Access Across
AWS Accounts Using IAM Roles in the IAM User Guide.


AWS service access You can use an IAM role in your account to grant an AWS service permissions
to access your accounts resources. For example, you can create a role that allows Amazon Redshift
to access an Amazon S3 bucket on your behalf and then load data from that bucket into an Amazon
Redshift cluster. For more information, see Creating a Role to Delegate Permissions to an AWS
Service in the IAM User Guide.


Applications running on Amazon EC2 You can use an IAM role to manage temporary credentials
for applications running on an EC2 instance and making AWS API requests. This is preferable to
storing access keys within the EC2 instance. To assign an AWS role to an EC2 instance and make it
available to all of its applications, you create an instance prole that is attached to the instance.
An instance prole contains the role and enables programs running on the EC2 instance to get
temporary credentials. For more information, see Using Roles for Applications on Amazon EC2 in the
IAM User Guide.

Access Control
You can have valid credentials to authenticate your requests, but unless you have permissions you cannot
create or access AWS Lambda resources. For example, you must have permissions to create a Lambda
function, add an event source, and publish a version of your Lambda function.

The following sections describe how to manage permissions for AWS Lambda. We recommend that you
read the overview rst.

Overview of Managing Access Permissions to Your AWS Lambda Resources (p. 322)
Using Identity-Based Policies (IAM Policies) for AWS Lambda (p. 326)
Using Resource-Based Policies for AWS Lambda (Lambda Function Policies) (p. 338)

321
AWS Lambda Developer Guide
Overview of Managing Access

Overview of Managing Access Permissions to Your


AWS Lambda Resources
Every AWS resource is owned by an AWS account, and permissions to create or access a resource are
governed by permissions policies. An account administrator can attach permissions policies to IAM
identities (that is, users, groups, and roles), and some services (such as AWS Lambda) also support
attaching permissions policies to resources.
Note
An account administrator (or administrator user) is a user with administrator privileges. For more
information, see IAM Best Practices in the IAM User Guide.

When granting permissions, you decide who is getting the permissions, the resources they get
permissions for, and the specic actions that you want to allow on those resources.

Topics
AWS Lambda Resources and Operations (p. 322)
Understanding Resource Ownership (p. 322)
Managing Access to Resources (p. 323)
Specifying Policy Elements: Actions, Eects, Resources, and Principals (p. 325)
Specifying Conditions in a Policy (p. 325)

AWS Lambda Resources and Operations


In AWS Lambda, the primary resources are a Lambda function and an event source mapping. You create
an event source mapping in the AWS Lambda pull model to associate a Lambda function with an event
source. For more information, see Event Source Mapping (p. 127).

AWS Lambda also supports additional resource types, alias and version. However, you can create aliases
and versions only in the context of an existing Lambda function. These are referred to as subresources.

These resources and subresources have unique Amazon Resource Names (ARNs) associated with them as
shown in the following table.

Resource Type ARN Format

Function arn:aws:lambda:region:account-id:function:function-name

Function alias arn:aws:lambda:region:account-id:function:function-name:alias-name

Function version arn:aws:lambda:region:account-id:function:function-name:version

Event source mapping arn:aws:lambda:region:account-id:event-source-mapping:event-


source-mapping-id

AWS Lambda provides a set of operations to work with the Lambda resources. For a list of available
operations, see Actions (p. 352).

Understanding Resource Ownership


A resource owner is the AWS account that created the resource. That is, the resource owner is the AWS
account of the principal entity (the root account, an IAM user, or an IAM role) that authenticates the
request that creates the resource. The following examples illustrate how this works:

322
AWS Lambda Developer Guide
Managing Access to Resources

If you use the root account credentials of your AWS account to create a Lambda function, your AWS
account is the owner of the resource (in Lambda, the resource is the Lambda function).
If you create an IAM user in your AWS account and grant permissions to create a Lambda function
to that user, the user can create a Lambda function. However, your AWS account, to which the user
belongs, owns the Lambda function resource.
If you create an IAM role in your AWS account with permissions to create a Lambda function, anyone
who can assume the role can create a Lambda function. Your AWS account, to which the role belongs,
owns the Lambda function resource.

Managing Access to Resources


A permissions policy describes who has access to what.The following section explains the available
options for creating permissions policies.
Note
This section discusses using IAM in the context of AWS Lambda. It doesn't provide detailed
information about the IAM service. For complete IAM documentation, see What Is IAM? in the
IAM User Guide. For information about IAM policy syntax and descriptions, see AWS IAM Policy
Reference in the IAM User Guide.

Policies attached to an IAM identity are referred to as identity-based policies (IAM polices) and policies
attached to a resource are referred to as resource-based policies. AWS Lambda supports both identity-
based (IAM policies) and resource-based policies.

Topics
Identity-Based Policies (IAM Policies) (p. 323)
Resource-Based Policies (Lambda Function Policies) (p. 324)

Identity-Based Policies (IAM Policies)


You can attach policies to IAM identities. For example, you can do the following:

Attach a permissions policy to a user or a group in your account An account administrator can
use a permissions policy that is associated with a particular user to grant permissions for that user to
create a Lambda function.
Attach a permissions policy to a role (grant cross-account permissions) You can attach an
identity-based permissions policy to an IAM role to grant cross-account permissions. For example,
the administrator in Account A can create a role to grant cross-account permissions to another AWS
account (for example, Account B) or an AWS service as follows:
1. Account A administrator creates an IAM role and attaches a permissions policy to the role that
grants permissions on resources in Account A.
2. Account A administrator attaches a trust policy to the role identifying Account B as the principal
who can assume the role.
3. Account B administrator can then delegate permissions to assume the role to any users in Account
B. Doing this allows users in Account B to create or access resources in Account A. The principal
in the trust policy can also be an AWS service principal if you want to grant an AWS service
permissions to assume the role.

For more information about using IAM to delegate permissions, see Access Management in the IAM
User Guide.

The following is an example policy that grants permissions for the lambda:ListFunctions action on all
resources. In the current implementation, Lambda doesn't support identifying specic resources using

323
AWS Lambda Developer Guide
Managing Access to Resources

the resource ARNs (also referred to as resource-level permissions) for some of the API actions, so you
must specify a wildcard character (*).

{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "ListExistingFunctions",
"Effect": "Allow",
"Action": [
"lambda:ListFunctions"
],
"Resource": "*"
}
]
}

For more information about using identity-based policies with Lambda, see Using Identity-Based
Policies (IAM Policies) for AWS Lambda (p. 326). For more information about users, groups, roles, and
permissions, see Identities (Users, Groups, and Roles) in the IAM User Guide.

Resource-Based Policies (Lambda Function Policies)


Each Lambda function can have resource-based permissions policies associated with it. For Lambda, a
Lambda function is the primary resource and these policies are referred to as Lambda function policies.
You can use a Lambda function policy to grant cross-account permissions as an alternative to using
identity-based policies with IAM roles. For example, you can grant Amazon S3 permissions to invoke your
Lambda function by simply adding permissions to the Lambda function policy instead of creating an IAM
role.
Important
Lambda function policies are primarily used when you are setting up an event source in AWS
Lambda to grant a service or an event source permissions to invoke your Lambda function
(see Invoke (p. 401)). An exception to this is when an event source (for example, Amazon
DynamoDB or Kinesis) uses the pull model, where permissions are managed in the Lambda
function execution role instead. For more information, see Event Source Mapping (p. 127).

The following is an example Lambda function policy that has one statement. The statement allows the
Amazon S3 service principal permission for the lambda:InvokeFunction action on a Lambda function
called HelloWorld. The condition ensures that the bucket where the event occurred is owned by the same
account that owns the Lambda function.

{
"Policy":{
"Version":"2012-10-17",
"Statement":[
{
"Effect":"Allow",
"Principal":{
"Service":"s3.amazonaws.com"
},
"Action":"lambda:InvokeFunction",
"Resource":"arn:aws:lambda:region:account-id:function:HelloWorld",
"Sid":"65bafc90-6a1f-42a8-a7ab-8aa9bc877985",
"Condition":{
"StringEquals":{
"AWS:SourceAccount":"account-id"
},
"ArnLike":{
"AWS:SourceArn":"arn:aws:s3:::ExampleBucket"

324
AWS Lambda Developer Guide
Specifying Policy Elements: Actions,
Eects, Resources, and Principals

}
}
}
]
}
}

For more information about using resource-based policies with Lambda, see Using Resource-Based
Policies for AWS Lambda (Lambda Function Policies) (p. 338). For additional information about using
IAM roles (identity-based policies) as opposed to resource-based policies, see How IAM Roles Dier from
Resource-based Policies in the IAM User Guide.

Specifying Policy Elements: Actions, Eects,


Resources, and Principals
For each AWS Lambda resource (see AWS Lambda Resources and Operations (p. 322)), the service
denes a set of API operations (see Actions (p. 352)). To grant permissions for these API operations,
Lambda denes a set of actions that you can specify in a policy. Note that, performing an API operation
can require permissions for more than one action. When granting permissions for specic actions, you
also identify the resource on which the actions are allowed or denied.

The following are the most basic policy elements:

Resource In a policy, you use an Amazon Resource Name (ARN) to identify the resource to which the
policy applies. For more information, see AWS Lambda Resources and Operations (p. 322).
Action You use action keywords to identify resource operations that you want to allow or deny. For
example, the lambda:InvokeFunction permission allows the user permissions to perform the AWS
Lambda Invoke operation.
Eect You specify the eect when the user requests the specic actionthis can be either allow or
deny. If you don't explicitly grant access to (allow) a resource, access is implicitly denied. You can also
explicitly deny access to a resource, which you might do to make sure that a user cannot access it, even
if a dierent policy grants access.
Principal In identity-based policies (IAM policies), the user that the policy is attached to is the
implicit principal. For resource-based policies, you specify the user, account, service, or other entity
that you want to receive permissions (applies to resource-based policies only).

To learn more about IAM policy syntax and descriptions, see AWS IAM Policy Reference in the IAM User
Guide.

For a table showing all of the AWS Lambda API actions and the resources that they apply to, see Lambda
API Permissions: Actions, Resources, and Conditions Reference (p. 341).

Specifying Conditions in a Policy


When you grant permissions, you can use the IAM policy language to specify the conditions when a
policy should take eect. For example, you might want a policy to be applied only after a specic date.
For more information about specifying conditions in a policy language, see Condition in the IAM User
Guide.

To express conditions, you use predened condition keys. There are no condition keys specic to Lambda.
However, there are AWS-wide condition keys that you can use as appropriate. For a complete list of AWS-
wide keys, see Available Keys for Conditions in the IAM User Guide.

325
AWS Lambda Developer Guide
Using Identity-Based Policies (IAM Policies)

Using Identity-Based Policies (IAM Policies) for


AWS Lambda
This topic provides examples of identity-based policies in which an account administrator can attach
permissions policies to IAM identities (that is, users, groups, and roles).
Important
We recommend that you rst review the introductory topics that explain the basic concepts
and options available for you to manage access to your AWS Lambda resources. For
more information, see Overview of Managing Access Permissions to Your AWS Lambda
Resources (p. 322).

The sections in this topic cover the following:

Permissions Required to Use the AWS Lambda Console (p. 327)


AWS Managed (Predened) Policies for AWS Lambda (p. 327)
Customer Managed Policy Examples (p. 327)

The following shows an example of a permissions policy.

{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "CreateFunctionPermissions",
"Effect": "Allow",
"Action": [
"lambda:CreateFunction"
],
"Resource": "*"
},
{
"Sid": "PermissionToPassAnyRole",
"Effect": "Allow",
"Action": [
"iam:PassRole"
],
"Resource": "arn:aws:iam::account-id:role/*"
}
]
}

The policy has two statements:

The rst statement grants permissions for the AWS Lambda action (lambda:CreateFunction) on a
resource by using theAmazon Resource Name (ARN) for the Lambda function. Currently, AWS Lambda
doesn't support permissions for this particular action at the resource-level. Therefore, the policy
species a wildcard character (*) as the Resource value.
The second statement grants permissions for the IAM action (iam:PassRole) on IAM roles. The wildcard
character (*) at the end of the Resource value means that the statement allows permission for the
iam:PassRole action on any IAM role. To limit this permission to a specic role, replace the wildcard
character (*) in the resource ARN with the specic role name.

The policy doesn't specify the Principal element because in an identity-based policy you don't specify
the principal who gets the permission. When you attach policy to a user, the user is the implicit principal.

326
AWS Lambda Developer Guide
Permissions Required to Use the AWS Lambda Console

When you attach a permission policy to an IAM role, the principal identied in the role's trust policy gets
the permissions.

For a table showing all of the AWS Lambda API actions and the resources and conditions that they apply
to, seeLambda API Permissions: Actions, Resources, and Conditions Reference (p. 341).

Permissions Required to Use the AWS Lambda


Console
The AWS Lambda console provides an integrated environment for you to create and manage Lambda
functions. The console provides many features and workows that often require permissions to create a
Lambda function in addition to the API-specic permissions documented in the Lambda API Permissions:
Actions, Resources, and Conditions Reference (p. 341). For more information about these additional
console permissions, see Permissions Required to Use the AWS Lambda Console (p. 331).

AWS Managed (Predened) Policies for AWS Lambda


AWS addresses many common use cases by providing standalone IAM policies that are created and
administered by AWS. Managed policies grant necessary permissions for common use cases so you can
avoid having to investigate what permissions are needed. For more information, see AWS Managed
Policies in the IAM User Guide.

The following AWS managed policies, which you can attach to users in your account, are specic to AWS
Lambda and are grouped by use case scenario:

AWSLambdaReadOnlyAccess Grants read-only access to AWS Lambda resources. Note that this
policy doesn't grant permission for the lambda:InvokeFunction action. If you want a user to invoke a
Lambda function, you can also attach the AWSLambdaRole AWS managed policy.
AWSLambdaFullAccess Grants full access to AWS Lambda resources.
AWSLambdaRole Grants permissions to invoke any Lambda function.

Note
You can review these permissions policies by signing in to the IAM console and searching for
specic policies there.

In addition, there are other AWS-managed policies that are suitable for use with IAM role (execution
role) you specify at the time of creating a Lambda function. For more information, see AWS Lambda
Permissions Model (p. 179).

You can also create your own custom IAM policies to allow permissions for AWS Lambda API actions
and resources. You can attach these custom policies to the IAM users or groups that require those
permissions or to custom execution roles (IAM roles) that you create for your Lambda functions.

Customer Managed Policy Examples


The examples in this section provide a group of sample policies that you can attach to a user. If you are
new to creating policies, we recommend that you rst create an IAM user in your account and attach the
policies to the user in sequence, as outlined in the steps in this section.

You can use the console to verify the eects of each policy as you attach the policy to the user. Initially,
the user doesn't have permissions and the user won't be able to do anything in the console. As you
attach policies to the user, you can verify that the user can perform various actions in the console.

We recommend that you use two browser windows: one to create the user and grant permissions, and
the other to sign in to the AWS Management Console using the user's credentials and verify permissions
as you grant them to the user.

327
AWS Lambda Developer Guide
Customer Managed Policy Examples

For examples that show how to create an IAM role that you can use as an execution role for your Lambda
function, see Creating IAM Roles in the IAM User Guide.

Example Steps
Step 1: Create an IAM User (p. 328)
Step 2: Allow a User to List Lambda Functions (p. 328)
Step 3: Allow a User to View Details of a Lambda Function (p. 328)
Step 4: Allow a User to Invoke a Lambda Function (p. 329)
Step 5: Allow a User to Monitor a Lambda Function and View CloudWatch Logs (p. 329)
Step 6: Allow a User to Create a Lambda Function (p. 330)

Step 1: Create an IAM User


First, you need to create an IAM user, add the user to an IAM group with administrative permissions, and
then grant administrative permissions to the IAM user that you created. You can then access AWS using a
special URL and that IAM user's credentials.

For instructions, see Creating Your First IAM User and Administrators Group in the IAM User Guide.

Step 2: Allow a User to List Lambda Functions


An IAM user in your account must have permissions for the lambda:ListFunctions action before the
user can see anything in the console. When you grant these permissions, the console can show the list of
Lambda functions in the AWS account created in the specic AWS Region the user belongs to.

{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "ListExistingFunctions",
"Effect": "Allow",
"Action": [
"lambda:ListFunctions"
],
"Resource": "*"
}
]
}

Step 3: Allow a User to View Details of a Lambda Function


A user can select a Lambda function and view details of the function (such as aliases, versions, and
other conguration information), provided that the user has permissions for the following AWS Lambda
actions:

{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "DisplayFunctionDetailsPermissions",
"Effect": "Allow",
"Action": [
"lambda:ListVersionsByFunction",
"lambda:ListAliases",

328
AWS Lambda Developer Guide
Customer Managed Policy Examples

"lambda:GetFunction",
"lambda:GetFunctionConfiguration",
"lambda:ListEventSourceMapping",
"lambda:GetPolicy"
],
"Resource": "*"
}
]
}

Step 4: Allow a User to Invoke a Lambda Function


If you want to allow a user permissions to manually invoke a function, you need to grant permissions for
the lambda:InvokeFunction action, as shown following:

{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "InvokePermission",
"Effect": "Allow",
"Action": [
"lambda:InvokeFunction"
],
"Resource": "*"
}
]
}

Step 5: Allow a User to Monitor a Lambda Function and View


CloudWatch Logs
When a user invokes a Lambda function, AWS Lambda executes it and returns results. The user needs
additional permissions to monitor the Lambda function.

To enable the user to see the Lambda function's CloudWatch metrics on the console's Monitoring tab, or
on the grid view on the console home page, you must grant the following permissions:

{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "CloudWatchPermission",
"Effect": "Allow",
"Action": [
"cloudwatch:GetMetricStatistics"
],
"Resource": "*"
}
]
}

To enable a user to click the links to CloudWatch Logs in the AWS Lambda console and view log output
in CloudWatch Logs, you must grant the following permissions:

{
"Version": "2012-10-17",
"Statement": [

329
AWS Lambda Developer Guide
Customer Managed Policy Examples

{
"Sid": "CloudWatchLogsPerms",
"Effect": "Allow",
"Action": [
"cloudwatchlog:DescribeLogGroups",
"cloudwatchlog:DescribeLogStreams",
"cloudwatchlog:GetLogEvents"

],
"Resource": "arn:aws:logs:region:account-id:log-group:/aws/lambda/*"
}
]
}

Step 6: Allow a User to Create a Lambda Function


If you want a user to be able to create a Lambda function, you must grant the following permissions. The
permissions for IAM-related actions are required because when a user creates a Lambda function, the
user needs to select an IAM execution role, which AWS Lambda assumes to execute the Lambda function.

{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "ListExistingRolesAndPolicies",
"Effect": "Allow",
"Action": [
"iam:ListRolePolicies",
"iam:ListRoles"
],
"Resource": "*"
},
{
"Sid": "CreateFunctionPermissions",
"Effect": "Allow",
"Action": [
"lambda:CreateFunction"
],
"Resource": "*"
},
{
"Sid": "PermissionToPassAnyRole",
"Effect": "Allow",
"Action": [
"iam:PassRole"
],
"Resource": "arn:aws:iam::account-id:role/*"
}
]
}

If you want a user to be able to create an IAM role when the user is creating a Lambda function, the user
needs permissions to perform the iam:PutRolePolicy action, as shown following:

{
"Sid": "CreateARole",
"Effect": "Allow",
"Action": [
"iam:CreateRole"
"iam:CreatePolicy"
"iam:AttachRolePolicy"
],

330
AWS Lambda Developer Guide
Console Permissions

"Resource": "arn:aws:iam::account-id:role/*"
}

Important
Each IAM role has a permissions policy attached to it, which grants specic permissions to the
role. Regardless of whether the user creates a new role or uses an existing role, the user must
have permissions for all of the actions granted in the permissions policy associated with the
role. You must grant the user additional permissions accordingly.

Permissions Required to Use the AWS Lambda


Console
To take advantage of the integrated experience provided by the AWS Lambda console, a user must often
have more permissions than the API-specic permissions described in the references table, depending
on what you want the user to be able to do. For more information about Lambda API operations, see
Lambda API Permissions: Actions, Resources, and Conditions Reference (p. 341).

For example, suppose you allow an IAM user in your account permissions to create a Lambda function
to process Amazon S3 object-created events. To enable the user to congure Amazon S3 as the event
source, the console drop-down list will display a list of your buckets. However, the console can show the
bucket list only if the signed-in user has permissions for the relevant Amazon S3 actions.

The following sections describe required additional permissions for dierent integration points. For
information about integration points, see How It Works (p. 175).

If you are new to managing permissions, we recommend that you start with the example walkthrough
where you create an IAM user, grant the user incremental permissions, and verify the permissions work
using the AWS Lambda console (see Customer Managed Policy Examples (p. 327)).

Topics
Amazon API Gateway (p. 331)
Amazon CloudWatch Events (p. 332)
Amazon CloudWatch Logs (p. 333)
Amazon Cognito (p. 333)
Amazon DynamoDB (p. 334)
Amazon Kinesis Streams (p. 335)
Amazon S3 (p. 336)
Amazon SNS (p. 336)
AWS IoT (p. 337)

Note
All of these permissions policies grant the specic AWS services permissions to invoke a
Lambda function. The user who is conguring this integration must have permissions to invoke
the Lambda function. Otherwise, the user can't set the conguration. You can attach the
AWSLambdaRole AWS managed (predened) permissions policy to the user to provide these
permissions.

Amazon API Gateway


When you congure an API endpoint in the console, the console makes several API Gateway API calls.
These calls require permissions for the apigateway:* action, as shown following:

331
AWS Lambda Developer Guide
Console Permissions

{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "ApiGatewayPermissions",
"Effect": "Allow",
"Action": [
"apigateway:*"
],
"Resource": "*"
},
{
"Sid": "AddPermissionToFunctionPolicy",
"Effect": "Allow",
"Action": [
"lambda:AddPermission",
"lambda:RemovePermission",
"lambda:GetPolicy"
],
"Resource": "arn:aws:lambda:region:account-id:function:*"
},
{
"Sid": "ListEventSourcePerm",
"Effect": "Allow",
"Action": [
"lambda:ListEventSourceMappings"
],
"Resource": "*"
}
]
}

Amazon CloudWatch Events


You can schedule when to invoke a Lambda function. After you select an existing CloudWatch Events
rule (or create a new one), AWS Lambda creates a new target in CloudWatch that invokes your Lambda
function. For target creation to work, you need to grant the following additional permissions:

{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "EventPerms",
"Effect": "Allow",
"Action": [
"events:PutRule",
"events:ListRules",
"events:ListRuleNamesByTarget",
"events:PutTargets",
"events:RemoveTargets",
"events:DescribeRule",
"events:TestEventPattern",
"events:ListTargetsByRule",
"events:DeleteRule"

],
"Resource": "arn:aws:events:region:account-id:*"
},
{
"Sid": "AddPermissionToFunctionPolicy",
"Effect": "Allow",
"Action": [
"lambda:AddPermission",

332
AWS Lambda Developer Guide
Console Permissions

"lambda:RemovePermission",
"lambda:GetPolicy"
],
"Resource": "arn:aws:lambda:region:account-id:function:*"
}
]
}

Amazon CloudWatch Logs


You can have the Amazon CloudWatch Logs service publish events and invoke your Lambda function.
When you congure this service as an event source, the console lists log groups in your account. For this
listing to occur, you need to grant the logs:DescribeLogGroups permissions, as shown following:

{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "CloudWatchLogsPerms",
"Effect": "Allow",
"Action": [
"logs:FilterLogEvents",
"logs:DescribeLogGroups",
"logs:PutSubscriptionFilter",
"logs:DescribeSubscriptionFilters",
"logs:DeleteSubscriptionFilter",
"logs:TestMetricFilter"
],
"Resource": "arn:aws:logs:region:account-id:*"
},
{
"Sid": "AddPermissionToFunctionPolicy",
"Effect": "Allow",
"Action": [
"lambda:AddPermission",
"lambda:RemovePermission",
"lambda:GetPolicy"
],
"Resource": "arn:aws:lambda:region:account-id:function:*"
},
{
"Sid": "ListEventSourceMappingsPerms",
"Effect": "Allow",
"Action": [
"lambda:ListEventSourceMappings"
],
"Resource": "*"
}
]
}

Note
The additional permissions shown are required for managing subscription lters.

Amazon Cognito
The console lists identity pools in your account. After you select a pool, you can congure the pool to
have the Cognito sync trigger as the event source type. To do this, you need to grant the following
additional permissions:

333
AWS Lambda Developer Guide
Console Permissions

"Version": "2012-10-17",
"Statement": [
{
"Sid": "CognitoPerms1",
"Effect": "Allow",
"Action": [
"cognito-identity:ListIdentityPools"
],
"Resource": [
"arn:aws:cognito-identity:region:account-id:*"
]
},
{
"Sid": "CognitoPerms2",
"Effect": "Allow",
"Action": [
"cognito-sync:GetCognitoEvents",
"cognito-sync:SetCognitoEvents"
],
"Resource": [
"arn:aws:cognito-sync:region:account-id:*"
]
},
{
"Sid": "AddPermissionToFunctionPolicy",
"Effect": "Allow",
"Action": [
"lambda:AddPermission",
"lambda:RemovePermission",
"lambda:GetPolicy"
],
"Resource": "arn:aws:lambda:region:account-id:function:*"
},
{
"Sid": "ListEventSourcePerms",
"Effect": "Allow",
"Action": [
"lambda:ListEventSourceMappings"
],
"Resource": "*"
}
]
}

Amazon DynamoDB
The console lists all of the tables in your account. After you select a table, the console checks to see if
a DynamoDB stream exists for that table. If not, it creates the stream. If you want the user to be able
to congure a DynamoDB stream as an event source for a Lambda function, you need to grant the
following additional permissions:

{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "DDBpermissions1",
"Effect": "Allow",
"Action": [
"dynamodb:DescribeStream",
"dynamodb:DescribeTable",
"dynamodb:UpdateTable"
],
"Resource": "arn:aws:dynamodb:region:account-id:table/*"

334
AWS Lambda Developer Guide
Console Permissions

},
{
"Sid": "DDBpermissions2",
"Effect": "Allow",
"Action": [
"dynamodb:ListStreams",
"dynamodb:ListTables"
],
"Resource": "*"
},
{
"Sid": "LambdaGetPolicyPerm",
"Effect": "Allow",
"Action": [
"lambda:GetPolicy"
],
"Resource": "arn:aws:lambda:region:account-id:function:*"
},
{
"Sid": "LambdaEventSourcePerms",
"Effect": "Allow",
"Action": [
"lambda:CreateEventSourceMapping",
"lambda:DeleteEventSourceMapping",
"lambda:GetEventSourceMapping",
"lambda:ListEventSourceMappings",
"lambda:UpdateEventSourceMapping"
],
"Resource": "*"
}
]
}

Important
For a Lambda function to read from a DynamoDB stream, the execution role associated with
the Lambda function must have the correct permissions. Therefore, the user must also have the
same permissions before you can grant the permissions to the execution role. You can grant
these permissions by attaching the AWSLambdaDynamoDBExecutionRole predened policy, rst to
the user and then to the execution role.

Amazon Kinesis Streams


The console lists all Kinesis streams in your account. After you select a stream, the console creates
event source mappings in AWS Lambda. For this to work, you need to grant the following additional
permissions:

{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "PermissionForDescribeStream",
"Effect": "Allow",
"Action": [
"kinesis:DescribeStream"
],
"Resource": "arn:aws:kinesis:region:account-id:stream/*"
},
{
"Sid": "PermissionForListStreams",
"Effect": "Allow",
"Action": [
"kinesis:ListStreams"
],

335
AWS Lambda Developer Guide
Console Permissions

"Resource": "*"
},
{
"Sid": "PermissionForGetFunctionPolicy",
"Effect": "Allow",
"Action": [
"lambda:GetPolicy"
],
"Resource": "arn:aws:lambda:region:account-id:function:*"
},
{
"Sid": "LambdaEventSourcePerms",
"Effect": "Allow",
"Action": [
"lambda:CreateEventSourceMapping",
"lambda:DeleteEventSourceMapping",
"lambda:GetEventSourceMapping",
"lambda:ListEventSourceMappings",
"lambda:UpdateEventSourceMapping"
],
"Resource": "*"
}
]
}

Amazon S3
The console prepopulates the list of buckets in the AWS account and nds the bucket location for each
bucket. When you congure Amazon S3 as an event source, the console updates the bucket notication
conguration. For this to work, you need to grant the following additional permissions:

{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "S3Permissions",
"Effect": "Allow",
"Action": [
"s3:GetBucketLocation",
"s3:GetBucketNotification",
"s3:PutBucketNotification",
"s3:ListAllMyBuckets"
],
"Resource": "arn:aws:s3:::*"
},
{
"Sid": "AddPermissionToFunctionPolicy",
"Effect": "Allow",
"Action": [
"lambda:AddPermission",
"lambda:RemovePermission"
],
"Resource": "arn:aws:lambda:region:account-id:function:*"
}
]
}

Amazon SNS
The console lists Amazon Simple Notication Service (Amazon SNS) topics in your account. After you
select a topic, AWS Lambda subscribes your Lambda function to that Amazon SNS topic. For this work,
you need to grant the following additional permissions:

336
AWS Lambda Developer Guide
Console Permissions

{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "SNSPerms",
"Effect": "Allow",
"Action": [
"sns:ListSubscriptions",
"sns:ListSubscriptionsByTopic",
"sns:ListTopics",
"sns:Subscribe",
"sns:Unsubscribe"
],
"Resource": "arn:aws:sns:region:account-id:*"
},
{
"Sid": "AddPermissionToFunctionPolicy",
"Effect": "Allow",
"Action": [
"lambda:AddPermission",
"lambda:RemovePermission",
"lambda:GetPolicy"
],
"Resource": "arn:aws:lambda:region:account-id:function:*"
},
{
"Sid": "LambdaListESMappingsPerms",
"Effect": "Allow",
"Action": [
"lambda:ListEventSourceMappings"
],
"Resource": "*"
}
]
}

AWS IoT
The console lists all of the AWS IoT rules. After you select a rule, the console populates the rest of the
information associated with that rule in the user interface. If you select an existing rule, the console
updates it with information so that events are sent to AWS Lambda. You can also create a new rule. To
do these things, the user must have the following additional permissions:

{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "IoTperms",
"Effect": "Allow",
"Action": [
"iot:GetTopicRule",
"iot:CreateTopicRule",
"iot:ReplaceTopicRule"
],
"Resource": "arn:aws:iot:region:account-id:*"
},
{
"Sid": "IoTlistTopicRulePerms",
"Effect": "Allow",
"Action": [
"iot:ListTopicRules"
],
"Resource": "*"

337
AWS Lambda Developer Guide
Using Resource-Based Policies (Lambda Function Policies)

},
{
"Sid": "LambdaPerms",
"Effect": "Allow",
"Action": [
"lambda:AddPermission",
"lambda:RemovePermission",
"lambda:GetPolicy"
],
"Resource": "arn:aws:lambda:region:account-id:function:*"
}
]
}

Using Resource-Based Policies for AWS Lambda


(Lambda Function Policies)
A Lambda function is one of the resources in AWS Lambda. You can add permissions to the policy
associated with a Lambda function. Permissions policies attached to Lambda functions are referred to
as resource-based policies (or Lambda function policies in Lambda). You use Lambda function policies to
manage Lambda function invocation permissions (see Invoke (p. 401)).
Important
Before you create resource-based policies, we recommend that you rst review the introductory
topics that explain the basic concepts and options available for you to manage access to your
AWS Lambda resources. For more information, see Overview of Managing Access Permissions to
Your AWS Lambda Resources (p. 322).

Lambda function policies are primarily used when you are setting up an event source in AWS Lambda to
grant a service or an event source permissions to invoke your Lambda function (see Invoke (p. 401)).
An exception to this is when an event source (for example, Amazon DynamoDB or Kinesis) uses the
pull model, where permissions are managed in the Lambda function execution role instead. For more
information, see Event Source Mapping (p. 127).

Lambda function policies also make it easy to grant cross-account permissions to invoke your Lambda
function. Suppose you want to grant cross-account permissions (for example, permissions to Amazon S3)
to invoke your Lambda function. Instead of creating an IAM role to grant cross-account permissions, you
can add the relevant permissions in a Lambda function policy.
Note
If the custom application and the Lambda function it invokes belong to the same AWS account,
you don't need to grant explicit permissions using the policy attached to the Lambda function.

AWS Lambda provides the following API operations to manage a permissions policy associated with a
Lambda function:

AddPermission (p. 354)


GetPolicy (p. 398)
RemovePermission (p. 427)

Note
The AWS Lambda console is the easiest way to manage event sources and their permissions in
a Lambda function policy. If the AWS service console for the event source supports conguring
event source mapping, you can use that console too. As you congure new event sources or
modify existing event sources, the console automatically modies the permissions policy
associated with the Lambda function.

338
AWS Lambda Developer Guide
Allow Amazon S3 to Invoke a Lambda Function

You can use the console to view your function policy by choosing the Triggers tab on your function's
details page and then choosing View function policy. The console doesn't support directly modifying
permissions in a function policy. You must use either the AWS CLI or the AWS SDKs. The following are
AWS CLI examples of the API operations listed earlier in this topic:

Examples
Example 1: Allow Amazon S3 to Invoke a Lambda Function (p. 339)
Example 2: Allow Amazon API Gateway to Invoke a Lambda Function (p. 340)
Example 3: Allow a User Application Created by Another AWS Account to Invoke a Lambda Function
(Cross-Account Scenario) (p. 340)
Example 4: Retrieve a Lambda Function Policy (p. 341)
Example 5: Remove Permissions from a Lambda Function Policy (p. 341)
Example 6: Working with Lambda Function Versioning, Aliases, and Permissions (p. 341)

Example 1: Allow Amazon S3 to Invoke a Lambda


Function
To grant Amazon S3 permission to invoke a Lambda function, you congure permissions as follows:

Specify s3.amazonaws.com as the principal value.


Specify lambda:InvokeFunction as the action for which you are granting permissions.

To ensure that the event is generated from a specic bucket that is owned by a specic AWS account, you
also specify the following:

Specify the bucket ARN as the source-arn value to restrict events from a specic bucket.
Specify the AWS account ID that owns the bucket, to ensure that the named bucket is owned by the
account.

The following example AWS CLI command adds a permission to the helloworld Lambda function policy
granting Amazon S3 permissions to invoke the function.

aws lambda add-permission \


--region us-west-2 \
--function-name helloworld \
--statement-id 1 \
--principal s3.amazonaws.com \
--action lambda:InvokeFunction \
--source-arn arn:aws:s3:::examplebucket \
--source-account 111111111111 \
--profile adminuser

The example assumes that the adminuser (who has full permissions) is adding this permission. Therefore,
the --profile parameter species the adminuser prole.

In response, AWS Lambda returns the following JSON code. The Statement value is a JSON string version
of the statement added to the Lambda function policy.

{
"Statement": "{\"Condition\":{\"StringEquals\":{\"AWS:SourceAccount\":
\"111111111111\"},
\"ArnLike\":{\"AWS:SourceArn\":\"arn:aws:s3:::examplebucket\"}},

339
AWS Lambda Developer Guide
Allow Amazon API Gateway to Invoke a Lambda Function

\"Action\":[\"lambda:InvokeFunction\"],
\"Resource\":\"arn:aws:lambda:us-west-2:111111111111:function:helloworld
\",
\"Effect\":\"Allow\",\"Principal\":{\"Service\":\"s3.amazonaws.com\"},
\"Sid\":\"1\"}"
}

For information about the push model, see Event Source Mapping (p. 127).

Example 2: Allow Amazon API Gateway to Invoke a


Lambda Function
To grant permissions to allow Amazon API Gateway to invoke a Lambda function, do the following:

Specify apigateway.amazonaws.com as the principal value.


Specify lambda:InvokeFunction as the action for which you are granting permissions.
Specify the API Gateway endpoint ARN as the source-arn value.

The following example AWS CLI command adds a permission to the helloworld Lambda function policy
granting API Gateway permissions to invoke the function.

aws lambda add-permission \


--region us-west-2 \
--function-name helloworld \
--statement-id 5 \
--principal apigateway.amazonaws.com \
--action lambda:InvokeFunction \
--source-arn arn:aws:execute-api:region:account-id:api-id/stage/method/resource-path \
--profile adminuser

In response, AWS Lambda returns the following JSON code. The Statement value is a JSON string version
of the statement added to the Lambda function policy.

{
"Statement": "{\"Condition\":{\"ArnLike\":{\"AWS:SourceArn\":\"arn:aws:apigateway:us-
east-1::my-api-id:/test/petstorewalkthrough/pets\"}},
\"Action\":[\"lambda:InvokeFunction\"],
\"Resource\":\"arn:aws:lambda:us-west-2:account-id:function:helloworld\",
\"Effect\":\"Allow\",
\"Principal\":{\"Service\":\"apigateway.amazonaws.com\"},
\"Sid\":\"5\"}"
}

Example 3: Allow a User Application Created by


Another AWS Account to Invoke a Lambda Function
(Cross-Account Scenario)
To grant permissions to another AWS account (that is, to create a cross-account scenario), you specify the
AWS account ID as the principal value as shown in the following AWS CLI command:

aws lambda add-permission \


--region us-west-2 \

340
AWS Lambda Developer Guide
Retrieve a Lambda Function Policy

--function-name helloworld \
--statement-id 3 \
--principal 111111111111 \
--action lambda:InvokeFunction \
--profile adminuser

In response, AWS Lambda returns the following JSON code. The Statement value is a JSON string version
of the statement added to the Lambda function policy.

{
"Statement": "{\"Action\":[\"lambda:InvokeFunction\"],
\"Resource\":\"arn:aws:lambda:us-west-2:account-id:function:helloworld
\",
\"Effect\":\"Allow\",
\"Principal\":{\"AWS\":\"account-id\"},
\"Sid\":\"3\"}"
}

Example 4: Retrieve a Lambda Function Policy


To retrieve your Lambda function policy, you use the get-policy command:

aws lambda get-policy \


--function-name example \
--profile adminuser

Example 5: Remove Permissions from a Lambda


Function Policy
To remove permissions from your Lambda function policy, you use the remove-permission command,
specifying the function name and statement ID:

aws lambda remove-permission \


--function-name example \
--statement-id 1 \
--profile adminuser

Example 6: Working with Lambda Function


Versioning, Aliases, and Permissions
For more information about permissions policies for Lambda function versions and aliases, see
Versioning, Aliases, and Resource Policies (p. 88).

Lambda API Permissions: Actions, Resources, and


Conditions Reference
When you are setting up Access Control (p. 321) and writing permissions policies that you can attach to
an IAM identity (identity-based policies), you can use the following table as a reference. The list includes

341
AWS Lambda Developer Guide
Lambda API Permissions Reference

each AWS Lambda API operation, the corresponding actions for which you can grant permissions to
perform the action, the AWS resource for which you can grant the permissions and condition keys for
specied API actions. You specify the actions in the policy's Action eld, the resource value in the policy's
Resource eld and a condition key in the policy's Condition keys eld.

To specify an action, use the lambda: prex followed by the API operation name (for example,
lambda:CreateFunction).

Note
Permissions for the AWS Lambda Invoke API in the following table can also be granted by
using resource-based policies. For more information, see Using Resource-Based Policies for AWS
Lambda (Lambda Function Policies) (p. 338).

You can use AWS-wide condition keys in your AWS Lambda policies to express conditions. For a complete
list of AWS-wide keys, see Available Keys for Conditions in the IAM User Guide.

AWS Lambda also oers predened condition keys to a limited set of API operations. For example, you
can:

Restrict access based on the Lambda function ARN (Amazon Resource Name) to the following
operations:
CreateEventSourceMapping
DeleteEventSourceMapping
UpdateEventSourceMapping

The following is an example policy that applies this condition:

"Version": "2012-10-17",
"Statement": [
{
"Sid": " DeleteEventSourceMappingPolicy",
"Effect": "Allow",
"Action": [
"lambda:DeleteEventSourceMapping"
],
"Resource": "arn:aws:lambda:region:account-id:event-source-mapping:UUID",
"Condition": {"StringEquals": {"lambda:FunctionArn":
"arn:aws:lambda:region:account-id:function:function-name}}
}
]

Restrict mapping based on the AWS service principal to the following operations:
AddPermission
RemovePermission

The following is an example policy that applies this condition:

"Version": "2012-10-17",
"Statement": [
{
"Sid": "AddPermissionPolicy",
"Effect": "Allow",
"Action": [
"lambda:AddPermission"
],
"Resource": "arn:aws:lambda:region:account-id:function:function-name",
"Condition": {"StringEquals": {"lambda:Principal": "s3.amazonaws.com"}}
}
]

342
AWS Lambda Developer Guide
Lambda API Permissions Reference

AWS Lambda API and Required Permissions for Actions

AddPermission (p. 354)

Action(s): lambda:AddPermission

Resource: arn:aws:lambda:region:account-id:?/*
CreateEventSourceMapping (p. 361)

Action(s): lambda:CreateEventSourceMapping

Resource: arn:aws:lambda:region:account-id:?
CreateFunction (p. 366)

Action(s): lambda:CreateFunction

Resource: arn:aws:lambda:region:account-id:?
DeleteEventSourceMapping (p. 376)

Action(s): lambda:DeleteEventSourceMapping

Resource: arn:aws:lambda:region:account-id:?
DeleteFunction (p. 379)

Action(s): lambda:DeleteFunction,

Resource: arn:aws:lambda:region:account-id:?
GetEventSourceMapping (p. 387)

Action(s): lambda:GetEventSourceMapping

Resource: arn:aws:lambda:region:account-id:?
GetFunction (p. 390)

Action(s): lambda:GetFunction

Resource: arn:aws:lambda:region:account-id:?
GetFunctionConguration (p. 393)

Action(s): lambda:DescribeMountTargetSecurityGroups,

Resource: arn:aws:lambda:region:account-id:?
GetPolicy (p. 398)

Action(s): lambda:DescribeMountTargets

Resource: arn:aws:lambda:region:account-id:?
Invoke (p. 401)

Action(s): lambda:DescribeTags

Resource: arn:aws:lambda:region:account-id:?
InvokeAsync (p. 406)

Action(s): lambda:ModifyMountTargetSecurityGroups

343
AWS Lambda Developer Guide
Policy Templates

Resource: arn:aws:lambda:region:account-id:?
ListEventSourceMappings (p. 411)

Action(s): lambda:ListEventSourceMappings

Resource: arn:aws:lambda:region:account-id:?
ListFunctions (p. 414)

Action(s): lambda:ListFunctions

Resource: arn:aws:lambda:region:account-id:?
RemovePermission (p. 427)

Action(s): lambda:RemovePermission

Resource: arn:aws:lambda:region:account-id:?
UpdateEventSourceMapping (p. 436)

Action(s): lambda:UpdateEventSourceMapping

Resource: arn:aws:lambda:region:account-id:?
UpdateFunctionCode (p. 440)

Action(s): lambda:UpdateFunctionCode

Resource: arn:aws:lambda:region:account-id:?
UpdateFunctionConguration (p. 446)

Action(s): lambda:UpdateFunctionConfiguration

Resource: arn:aws:lambda:region:account-id:?

Policy Templates
When you create an AWS Lambda function in the console using one of the blueprints, Lambda allows
you to create a role for your function from a list of Lambda policy templates. By selecting one of these
templates, your Lambda function automatically creates the role with the requisite permissions attached
to that policy.

The following lists the permissions that are applied to each policy template in the Policy templates
list. The policy templates are named after the blueprints to which they correspond. Lambda will
automatically populate the placeholder items (such as region and accountID) with the appropriate
information. For more information on creating a Lambda function using policy templates, see Step 2.1:
Create a Hello World Lambda Function (p. 189).

The following templates are automatically applied depending upon the type of Lambda function you are
creating:

Basic: 'Basic Lambda Permissions'


{
"Version":"2012-10-17",
"Statement":[

344
AWS Lambda Developer Guide
VPCAccess: 'Lambda VPC Access Permissions'

{
"Effect":"Allow",
"Action":"logs:CreateLogGroup",
"Resource":"arn:aws:logs:region:accountId:*"
},
{
"Effect":"Allow",
"Action":[
"logs:CreateLogStream",
"logs:PutLogEvents"
],
"Resource":[
"arn:aws:logs:region:accountId:log-group:[[logGroups]]:*"
]
}
]
}

VPCAccess: 'Lambda VPC Access Permissions'


{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"ec2:CreateNetworkInterface",
"ec2:DeleteNetworkInterface",
"ec2:DescribeNetworkInterfaces"
],
"Resource": "*"
}
]
}

Kinesis: 'Lambda Kinesis stream poller permissions'


{
"Version":"2012-10-17",
"Statement":[
{
"Effect":"Allow",
"Action":"lambda:InvokeFunction",
"Resource":"arn:aws:lambda:region:accountId:function:functionName*"
},
{
"Effect":"Allow",
"Action":"kinesis:ListStreams",
"Resource":"arn:aws:kinesis:region:accountId:stream/*"
},
{
"Effect":"Allow",
"Action":[
"kinesis:DescribeStream",
"kinesis:GetRecords",
"kinesis:GetShardIterator"
],
"Resource":"arn:aws:kinesis:region:accountId:
stream/streamName"
}
]

345
AWS Lambda Developer Guide
DynamoDB: 'Lambda DynamoDB stream poller permissions'

DynamoDB: 'Lambda DynamoDB stream poller


permissions'
{
"Version":"2012-10-17",
"Statement":[
{
"Effect":"Allow",
"Action":"lambda:InvokeFunction",
"Resource":"arn:aws:lambda:region:accountId:function:functionName*"
},
{
"Effect":"Allow",
"Action":[
"dynamodb:DescribeStream",
"dynamodb:GetRecords",
"dynamodb:GetShardIterator",
"dynamodb:ListStreams"
],
"Resource":"arn:aws:dynamodb:region:accountId:table/tableName/stream/*"
}
]
}

Edge: 'Basic Edge Lambda permissions'


{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"logs:CreateLogGroup",
"logs:CreateLogStream",
"logs:PutLogEvents"
],
"Resource": [
"arn:aws:logs:*:*:*"
]
}
]
}

RedrivePolicySNS: Dead letter queue SNS


permissions
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"sns:Publish"
],

346
AWS Lambda Developer Guide
RedrivePolicySQS: 'Dead letter queue SQS permissions'

"Resource": "arn:aws:sns:region:accountId:topicName"
}
]
}

RedrivePolicySQS: 'Dead letter queue SQS


permissions'
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"sqs:SendMessage"
],
"Resource": "arn:aws:sqs:region:accountId:queueName"
}
]
}

The following templates are selected depending upon which blueprint you choose. You can also select
them from the dropdown to add extra permissions:

CloudFormation: 'CloudFormation stack read-only


permissions'
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"cloudformation:DescribeStacks"
],
"Resource": "*"
}
]
}

AMI: 'AMI read-only permissions'


{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"ec2:DescribeImages"
],
"Resource": "*"
}
]
}

347
AWS Lambda Developer Guide
KMS: 'KMS decryption permissions'

KMS: 'KMS decryption permissions'


{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"kms:Decrypt"
],
"Resource": "*"
}
]
}

S3: 'S3 object read-only permissions'


{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"s3:GetObject"
],
"Resource": "arn:aws:s3:::*"
}
]
}

Elasticsearch: 'Elasticsearch permissions'


{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"es:ESHttpPost"
],
"Resource": "*"
}
]
}

SES: 'SES bounce permissions'


{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"ses:SendBounce"
],
"Resource": "*"
}

348
AWS Lambda Developer Guide
TestHarness: 'Test Harness permissions'

]
}

TestHarness: 'Test Harness permissions'


{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"dynamodb:PutItem"
],
"Resource": "arn:aws:dynamodb:region:accountId:table/*"
},
{
"Effect": "Allow",
"Action": [
"lambda:InvokeFunction"
],
"Resource": "arn:aws:lambda:region:accountId:function:*"
}
]
}

Microservice: 'Simple Microservice permissions'


{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"dynamodb:DeleteItem",
"dynamodb:GetItem",
"dynamodb:PutItem",
"dynamodb:Scan",
"dynamodb:UpdateItem"
],
"Resource": "arn:aws:dynamodb:region:accountId:table/*"
}
]
}

VPN: 'VPN Connection Monitor permissions'


{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"cloudwatch:PutMetricData"
],
"Resource": "*"
},
{
"Effect": "Allow",
"Action": [

349
AWS Lambda Developer Guide
SQS: 'SQS Poller permissions'

"ec2:DescribeRegions",
"ec2:DescribeVpnConnections"
],
"Resource": "*"
}
]
}

SQS: 'SQS Poller permissions'


{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"sqs:DeleteMessage",
"sqs:ReceiveMessage"
],
"Resource": "arn:aws:sqs:*"
},
{
"Effect": "Allow",
"Action": [
"lambda:InvokeFunction"
],
"Resource": "arn:aws:lambda:region:accountId:function:functionName*"
}
]
}

IoTButton: 'AWS IoT Button permissions'


{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"sns:ListSubscriptionsByTopic",
"sns:CreateTopic",
"sns:SetTopicAttributes",
"sns:Subscribe",
"sns:Publish"
],
"Resource": "*"
}
]
}

RekognitionNoDataAccess:'Amazon Rekognition no
data permissions'
{
"Version": "2012-10-17",
"Statement": [
{

350
AWS Lambda Developer Guide
RekognitionReadOnlyAccess: 'Amazon
Rekognition read-only permissions'

"Effect": "Allow",
"Action": [
"rekognition:CompareFaces",
"rekognition:DetectFaces",
"rekognition:DetectLabels"
],
"Resource": "*"
}
]
}

RekognitionReadOnlyAccess: 'Amazon Rekognition


read-only permissions'
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"rekognition:ListCollections",
"rekognition:ListFaces",
"rekognition:SearchFaces",
"rekognition:SearchFacesByImage"
],
"Resource": "*"
}
]
}

RekognitionWriteOnlyAccess: 'Amazon Rekognition


write-only permissions'
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"rekognition:CreateCollection",
"rekognition:IndexFaces"
],
"Resource": "*"
}
]
}

351
AWS Lambda Developer Guide
Actions

API Reference

This section contains the AWS Lambda API Reference documentation. When making the API calls, you
will need to authenticate your request by providing a signature. AWS Lambda supports signature version
4. For more information, see Signature Version 4 Signing Process in the Amazon Web Services General
Reference.

For an overview of the service, see What Is AWS Lambda? (p. 1). For information about how the service
works, see How It Works (p. 175).

You can use the AWS CLI to explore the AWS Lambda API. This guide provides several tutorials that use
the AWS CLI.

Topics

Actions (p. 352)


Data Types (p. 453)

Actions
The following actions are supported:

AddPermission (p. 354)


CreateAlias (p. 358)
CreateEventSourceMapping (p. 361)
CreateFunction (p. 366)
DeleteAlias (p. 374)
DeleteEventSourceMapping (p. 376)
DeleteFunction (p. 379)
GetAccountSettings (p. 382)
GetAlias (p. 384)
GetEventSourceMapping (p. 387)
GetFunction (p. 390)
GetFunctionConguration (p. 393)
GetPolicy (p. 398)
Invoke (p. 401)

352
AWS Lambda Developer Guide
Actions

InvokeAsync (p. 406)


ListAliases (p. 408)
ListEventSourceMappings (p. 411)
ListFunctions (p. 414)
ListTags (p. 417)
ListVersionsByFunction (p. 419)
PublishVersion (p. 422)
RemovePermission (p. 427)
TagResource (p. 429)
UntagResource (p. 431)
UpdateAlias (p. 433)
UpdateEventSourceMapping (p. 436)
UpdateFunctionCode (p. 440)
UpdateFunctionConguration (p. 446)

353
AWS Lambda Developer Guide
AddPermission

AddPermission
Adds a permission to the resource policy associated with the specied AWS Lambda function. You use
resource policies to grant permissions to event sources that use push model. In a push model, event
sources (such as Amazon S3 and custom applications) invoke your Lambda function. Each permission you
add to the resource policy allows an event source, permission to invoke the Lambda function.

For information about the push model, see AWS Lambda: How it Works.

If you are using versioning, the permissions you add are specic to the Lambda function version or alias
you specify in the AddPermission request via the Qualifier parameter. For more information about
versioning, see AWS Lambda Function Versioning and Aliases.

This operation requires permission for the lambda:AddPermission action.

Request Syntax
POST /2015-03-31/functions/FunctionName/policy?Qualifier=Qualifier HTTP/1.1
Content-type: application/json

{
"Action": "string",
"EventSourceToken": "string",
"Principal": "string",
"SourceAccount": "string",
"SourceArn": "string",
"StatementId": "string"
}

URI Request Parameters


The request requires the following URI parameters.

FunctionName (p. 354)

Name of the Lambda function whose resource policy you are updating by adding a new permission.

You can specify a function name (for example, Thumbnail) or you can specify Amazon
Resource Name (ARN) of the function (for example, arn:aws:lambda:us-west-2:account-
id:function:ThumbNail). AWS Lambda also allows you to specify partial ARN (for example,
account-id:Thumbnail). Note that the length constraint applies only to the ARN. If you specify only
the function name, it is limited to 64 characters in length.

Length Constraints: Minimum length of 1. Maximum length of 140.

Pattern: (arn:aws:lambda:)?([a-z]{2}-[a-z]+-\d{1}:)?(\d{12}:)?(function:)?([a-zA-Z0-9-
_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Qualier (p. 354)

You can use this optional query parameter to describe a qualied ARN using a function version or
an alias name. The permission will then apply to the specic qualied ARN. For example, if you
specify function version 2 as the qualier, then permission applies only when request is made using
qualied function ARN:

arn:aws:lambda:aws-region:acct-id:function:function-name:2

If you specify an alias name, for example PROD, then the permission is valid only for requests made
using the alias ARN:

354
AWS Lambda Developer Guide
AddPermission

arn:aws:lambda:aws-region:acct-id:function:function-name:PROD

If the qualier is not specied, the permission is valid only when requests is made using unqualied
function ARN.

arn:aws:lambda:aws-region:acct-id:function:function-name

Length Constraints: Minimum length of 1. Maximum length of 128.

Pattern: (|[a-zA-Z0-9$_-]+)

Request Body
The request accepts the following data in JSON format.

Action (p. 354)

The AWS Lambda action you want to allow in this statement. Each Lambda action is a string starting
with lambda: followed by the API name (see Actions) . For example, lambda:CreateFunction. You can
use wildcard (lambda:*) to grant permission for all AWS Lambda actions.

Type: String

Pattern: (lambda:[*]|lambda:[a-zA-Z]+|[*])

Required: Yes
EventSourceToken (p. 354)

A unique token that must be supplied by the principal invoking the function. This is currently only
used for Alexa Smart Home functions.

Type: String

Length Constraints: Minimum length of 0. Maximum length of 256.

Pattern: [a-zA-Z0-9._\-]+

Required: No
Principal (p. 354)

The principal who is getting this permission. It can be Amazon S3 service Principal
(s3.amazonaws.com) if you want Amazon S3 to invoke the function, an AWS account ID if you are
granting cross-account permission, or any valid AWS service principal such as sns.amazonaws.com.
For example, you might want to allow a custom application in another AWS account to push events
to AWS Lambda by invoking your function.

Type: String

Pattern: .*

Required: Yes
SourceAccount (p. 354)

This parameter is used for S3 and SES. The AWS account ID (without a hyphen) of the source owner.
For example, if the SourceArn identies a bucket, then this is the bucket owner's account ID. You can
use this additional condition to ensure the bucket you specify is owned by a specic account (it is
possible the bucket owner deleted the bucket and some other AWS account created the bucket). You
can also use this condition to specify all sources (that is, you don't specify the SourceArn) owned by a
specic account.

Type: String

355
AWS Lambda Developer Guide
AddPermission

Pattern: \d{12}

Required: No
SourceArn (p. 354)

This is optional; however, when granting permission to invoke your function, you should specify this
eld with the Amazon Resource Name (ARN) as its value. This ensures that only events generated
from the specied source can invoke the function.
Important
If you add a permission without providing the source ARN, any AWS account that creates a
mapping to your function ARN can send events to invoke your Lambda function.

Type: String

Pattern: arn:aws:([a-zA-Z0-9\-])+:([a-z]{2}-[a-z]+-\d{1})?:(\d{12})?:(.*)

Required: No
StatementId (p. 354)

A unique statement identier.

Type: String

Length Constraints: Minimum length of 1. Maximum length of 100.

Pattern: ([a-zA-Z0-9-_]+)

Required: Yes

Response Syntax
HTTP/1.1 201
Content-type: application/json

{
"Statement": "string"
}

Response Elements
If the action is successful, the service sends back an HTTP 201 response.

The following data is returned in JSON format by the service.

Statement (p. 356)

The permission statement you specied in the request. The response returns the same as a string
using a backslash ("\") as an escape character in the JSON.

Type: String

Errors
InvalidParameterValueException

One of the parameters in the request is invalid. For example, if you provided an IAM role for AWS
Lambda to assume in the CreateFunction or the UpdateFunctionConfiguration API, that AWS

356
AWS Lambda Developer Guide
AddPermission

Lambda is unable to assume you will get this exception. You will also get this exception if you have
selected a deprecated runtime, such as Node v0.10.42.

HTTP Status Code: 400


PolicyLengthExceededException

Lambda function access policy is limited to 20 KB.

HTTP Status Code: 400


ResourceConictException

The resource already exists.

HTTP Status Code: 409


ResourceNotFoundException

The resource (for example, a Lambda function or access policy statement) specied in the request
does not exist.

HTTP Status Code: 404


ServiceException

The AWS Lambda service encountered an internal error.

HTTP Status Code: 500


TooManyRequestsException

HTTP Status Code: 429

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS Command Line Interface


AWS SDK for .NET
AWS SDK for C++
AWS SDK for Go
AWS SDK for Java
AWS SDK for JavaScript
AWS SDK for PHP V3
AWS SDK for Python
AWS SDK for Ruby V2

357
AWS Lambda Developer Guide
CreateAlias

CreateAlias
Creates an alias that points to the specied Lambda function version. For more information, see
Introduction to AWS Lambda Aliases.

Alias names are unique for a given function. This requires permission for the lambda:CreateAlias action.

Request Syntax
POST /2015-03-31/functions/FunctionName/aliases HTTP/1.1
Content-type: application/json

{
"Description": "string",
"FunctionVersion": "string",
"Name": "string"
}

URI Request Parameters


The request requires the following URI parameters.

FunctionName (p. 358)

Name of the Lambda function for which you want to create an alias. Note that the length constraint
applies only to the ARN. If you specify only the function name, it is limited to 64 characters in
length.

Length Constraints: Minimum length of 1. Maximum length of 140.

Pattern: (arn:aws:lambda:)?([a-z]{2}-[a-z]+-\d{1}:)?(\d{12}:)?(function:)?([a-zA-Z0-9-
_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?

Request Body
The request accepts the following data in JSON format.

Description (p. 358)

Description of the alias.

Type: String

Length Constraints: Minimum length of 0. Maximum length of 256.

Required: No
FunctionVersion (p. 358)

Lambda function version for which you are creating the alias.

Type: String

Length Constraints: Minimum length of 1. Maximum length of 1024.

Pattern: (\$LATEST|[0-9]+)

Required: Yes

358
AWS Lambda Developer Guide
CreateAlias

Name (p. 358)

Name for the alias you are creating.

Type: String

Length Constraints: Minimum length of 1. Maximum length of 128.

Pattern: (?!^[0-9]+$)([a-zA-Z0-9-_]+)

Required: Yes

Response Syntax
HTTP/1.1 201
Content-type: application/json

{
"AliasArn": "string",
"Description": "string",
"FunctionVersion": "string",
"Name": "string"
}

Response Elements
If the action is successful, the service sends back an HTTP 201 response.

The following data is returned in JSON format by the service.

AliasArn (p. 359)

Lambda function ARN that is qualied using the alias name as the sux. For example, if you create
an alias called BETA that points to a helloworld function version, the ARN is arn:aws:lambda:aws-
regions:acct-id:function:helloworld:BETA.

Type: String

Pattern: arn:aws:lambda:[a-z]{2}-[a-z]+-\d{1}:\d{12}:function:[a-zA-Z0-9-_]+(:(\$LATEST|
[a-zA-Z0-9-_]+))?
Description (p. 359)

Alias description.

Type: String

Length Constraints: Minimum length of 0. Maximum length of 256.


FunctionVersion (p. 359)

Function version to which the alias points.

Type: String

Length Constraints: Minimum length of 1. Maximum length of 1024.

Pattern: (\$LATEST|[0-9]+)
Name (p. 359)

Alias name.

359
AWS Lambda Developer Guide
CreateAlias

Type: String

Length Constraints: Minimum length of 1. Maximum length of 128.

Pattern: (?!^[0-9]+$)([a-zA-Z0-9-_]+)

Errors
InvalidParameterValueException

One of the parameters in the request is invalid. For example, if you provided an IAM role for AWS
Lambda to assume in the CreateFunction or the UpdateFunctionConfiguration API, that AWS
Lambda is unable to assume you will get this exception. You will also get this exception if you have
selected a deprecated runtime, such as Node v0.10.42.

HTTP Status Code: 400


ResourceConictException

The resource already exists.

HTTP Status Code: 409


ResourceNotFoundException

The resource (for example, a Lambda function or access policy statement) specied in the request
does not exist.

HTTP Status Code: 404


ServiceException

The AWS Lambda service encountered an internal error.

HTTP Status Code: 500


TooManyRequestsException

HTTP Status Code: 429

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS Command Line Interface


AWS SDK for .NET
AWS SDK for C++
AWS SDK for Go
AWS SDK for Java
AWS SDK for JavaScript
AWS SDK for PHP V3
AWS SDK for Python
AWS SDK for Ruby V2

360
AWS Lambda Developer Guide
CreateEventSourceMapping

CreateEventSourceMapping
Identies a stream as an event source for a Lambda function. It can be either an Amazon Kinesis stream
or an Amazon DynamoDB stream. AWS Lambda invokes the specied function when records are posted
to the stream.

This association between a stream source and a Lambda function is called the event source mapping.
Important
This event source mapping is relevant only in the AWS Lambda pull model, where AWS Lambda
invokes the function. For more information, see AWS Lambda: How it Works in the AWS Lambda
Developer Guide.

You provide mapping information (for example, which stream to read from and which Lambda function
to invoke) in the request body.

Each event source, such as an Amazon Kinesis or a DynamoDB stream, can be associated with multiple
AWS Lambda function. A given Lambda function can be associated with multiple AWS event sources.

If you are using versioning, you can specify a specic function version or an alias via the function name
parameter. For more information about versioning, see AWS Lambda Function Versioning and Aliases.

This operation requires permission for the lambda:CreateEventSourceMapping action.

Request Syntax
POST /2015-03-31/event-source-mappings/ HTTP/1.1
Content-type: application/json

{
"BatchSize": number,
"Enabled": boolean,
"EventSourceArn": "string",
"FunctionName": "string",
"StartingPosition": "string",
"StartingPositionTimestamp": number
}

URI Request Parameters


The request does not use any URI parameters.

Request Body
The request accepts the following data in JSON format.

BatchSize (p. 361)

The largest number of records that AWS Lambda will retrieve from your event source at the time of
invoking your function. Your function receives an event with all the retrieved records. The default is
100 records.

Type: Integer

Valid Range: Minimum value of 1. Maximum value of 10000.

Required: No

361
AWS Lambda Developer Guide
CreateEventSourceMapping

Enabled (p. 361)

Indicates whether AWS Lambda should begin polling the event source. By default, Enabled is true.

Type: Boolean

Required: No
EventSourceArn (p. 361)

The Amazon Resource Name (ARN) of the Amazon Kinesis or the Amazon DynamoDB stream that is
the event source. Any record added to this stream could cause AWS Lambda to invoke your Lambda
function, it depends on the BatchSize. AWS Lambda POSTs the Amazon Kinesis event, containing
records, to your Lambda function as JSON.

Type: String

Pattern: arn:aws:([a-zA-Z0-9\-])+:([a-z]{2}-[a-z]+-\d{1})?:(\d{12})?:(.*)

Required: Yes
FunctionName (p. 361)

The Lambda function to invoke when AWS Lambda detects an event on the stream.

You can specify the function name (for example, Thumbnail) or you can specify Amazon
Resource Name (ARN) of the function (for example, arn:aws:lambda:us-west-2:account-
id:function:ThumbNail).

If you are using versioning, you can also provide a qualied function ARN (ARN that is qualied with
function version or alias name as sux). For more information about versioning, see AWS Lambda
Function Versioning and Aliases

AWS Lambda also allows you to specify only the function name with the account ID qualier (for
example, account-id:Thumbnail).

Note that the length constraint applies only to the ARN. If you specify only the function name, it is
limited to 64 characters in length.

Type: String

Length Constraints: Minimum length of 1. Maximum length of 140.

Pattern: (arn:aws:lambda:)?([a-z]{2}-[a-z]+-\d{1}:)?(\d{12}:)?(function:)?([a-zA-Z0-9-
_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?

Required: Yes
StartingPosition (p. 361)

The position in the stream where AWS Lambda should start reading. Valid only for Kinesis streams.
For more information, see ShardIteratorType in the Amazon Kinesis API Reference.

Type: String

Valid Values: TRIM_HORIZON | LATEST | AT_TIMESTAMP

Required: Yes
StartingPositionTimestamp (p. 361)

The timestamp of the data record from which to start reading. Used with shard iterator type
AT_TIMESTAMP. If a record with this exact timestamp does not exist, the iterator returned is for the
next (later) record. If the timestamp is older than the current trim horizon, the iterator returned is for
the oldest untrimmed data record (TRIM_HORIZON). Valid only for Kinesis streams.

362
AWS Lambda Developer Guide
CreateEventSourceMapping

Type: Timestamp

Required: No

Response Syntax
HTTP/1.1 202
Content-type: application/json

{
"BatchSize": number,
"EventSourceArn": "string",
"FunctionArn": "string",
"LastModified": number,
"LastProcessingResult": "string",
"State": "string",
"StateTransitionReason": "string",
"UUID": "string"
}

Response Elements
If the action is successful, the service sends back an HTTP 202 response.

The following data is returned in JSON format by the service.

BatchSize (p. 363)

The largest number of records that AWS Lambda will retrieve from your event source at the time of
invoking your function. Your function receives an event with all the retrieved records.

Type: Integer

Valid Range: Minimum value of 1. Maximum value of 10000.


EventSourceArn (p. 363)

The Amazon Resource Name (ARN) of the Amazon Kinesis stream that is the source of events.

Type: String

Pattern: arn:aws:([a-zA-Z0-9\-])+:([a-z]{2}-[a-z]+-\d{1})?:(\d{12})?:(.*)
FunctionArn (p. 363)

The Lambda function to invoke when AWS Lambda detects an event on the stream.

Type: String

Pattern: arn:aws:lambda:[a-z]{2}-[a-z]+-\d{1}:\d{12}:function:[a-zA-Z0-9-_]+(:(\$LATEST|
[a-zA-Z0-9-_]+))?
LastModied (p. 363)

The UTC time string indicating the last time the event mapping was updated.

Type: Timestamp
LastProcessingResult (p. 363)

The result of the last AWS Lambda invocation of your Lambda function.

Type: String

363
AWS Lambda Developer Guide
CreateEventSourceMapping

State (p. 363)

The state of the event source mapping. It can be Creating, Enabled, Disabled, Enabling, Disabling,
Updating, or Deleting.

Type: String
StateTransitionReason (p. 363)

The reason the event source mapping is in its current state. It is either user-requested or an AWS
Lambda-initiated state transition.

Type: String
UUID (p. 363)

The AWS Lambda assigned opaque identier for the mapping.

Type: String

Errors
InvalidParameterValueException

One of the parameters in the request is invalid. For example, if you provided an IAM role for AWS
Lambda to assume in the CreateFunction or the UpdateFunctionConfiguration API, that AWS
Lambda is unable to assume you will get this exception. You will also get this exception if you have
selected a deprecated runtime, such as Node v0.10.42.

HTTP Status Code: 400


ResourceConictException

The resource already exists.

HTTP Status Code: 409


ResourceNotFoundException

The resource (for example, a Lambda function or access policy statement) specied in the request
does not exist.

HTTP Status Code: 404


ServiceException

The AWS Lambda service encountered an internal error.

HTTP Status Code: 500


TooManyRequestsException

HTTP Status Code: 429

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS Command Line Interface


AWS SDK for .NET
AWS SDK for C++

364
AWS Lambda Developer Guide
CreateEventSourceMapping

AWS SDK for Go


AWS SDK for Java
AWS SDK for JavaScript
AWS SDK for PHP V3
AWS SDK for Python
AWS SDK for Ruby V2

365
AWS Lambda Developer Guide
CreateFunction

CreateFunction
Creates a new Lambda function. The function metadata is created from the request parameters, and the
code for the function is provided by a .zip le in the request body. If the function name already exists,
the operation will fail. Note that the function name is case-sensitive.

If you are using versioning, you can also publish a version of the Lambda function you are creating using
the Publish parameter. For more information about versioning, see AWS Lambda Function Versioning
and Aliases.

This operation requires permission for the lambda:CreateFunction action.

Request Syntax
POST /2015-03-31/functions HTTP/1.1
Content-type: application/json

{
"Code": {
"S3Bucket": "string",
"S3Key": "string",
"S3ObjectVersion": "string",
"ZipFile": blob
},
"DeadLetterConfig": {
"TargetArn": "string"
},
"Description": "string",
"Environment": {
"Variables": {
"string" : "string"
}
},
"FunctionName": "string",
"Handler": "string",
"KMSKeyArn": "string",
"MemorySize": number,
"Publish": boolean,
"Role": "string",
"Runtime": "string",
"Tags": {
"string" : "string"
},
"Timeout": number,
"TracingConfig": {
"Mode": "string"
},
"VpcConfig": {
"SecurityGroupIds": [ "string" ],
"SubnetIds": [ "string" ]
}
}

URI Request Parameters


The request does not use any URI parameters.

Request Body
The request accepts the following data in JSON format.

366
AWS Lambda Developer Guide
CreateFunction

Code (p. 366)

The code for the Lambda function.

Type: FunctionCode (p. 464) object

Required: Yes
DeadLetterCong (p. 366)

The parent object that contains the target ARN (Amazon Resource Name) of an Amazon SQS queue
or Amazon SNS topic.

Type: DeadLetterCong (p. 458) object

Required: No
Description (p. 366)

A short, user-dened function description. Lambda does not use this value. Assign a meaningful
description as you see t.

Type: String

Length Constraints: Minimum length of 0. Maximum length of 256.

Required: No
Environment (p. 366)

The parent object that contains your environment's conguration settings.

Type: Environment (p. 459) object

Required: No
FunctionName (p. 366)

The name you want to assign to the function you are uploading. The function names appear
in the console and are returned in the ListFunctions (p. 414) API. Function names are used to
specify functions to other AWS Lambda API operations, such as Invoke (p. 401). Note that the
length constraint applies only to the ARN. If you specify only the function name, it is limited to 64
characters in length.

Type: String

Length Constraints: Minimum length of 1. Maximum length of 140.

Pattern: (arn:aws:lambda:)?([a-z]{2}-[a-z]+-\d{1}:)?(\d{12}:)?(function:)?([a-zA-Z0-9-
_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?

Required: Yes
Handler (p. 366)

The function within your code that Lambda calls to begin execution. For Node.js, it is the
module-name.export value in your function. For Java, it can be package.class-name::handler or
package.class-name. For more information, see Lambda Function Handler (Java).

Type: String

Length Constraints: Maximum length of 128.

Pattern: [^\s]+

367
AWS Lambda Developer Guide
CreateFunction

Required: Yes
KMSKeyArn (p. 366)

The Amazon Resource Name (ARN) of the KMS key used to encrypt your function's environment
variables. If not provided, AWS Lambda will use a default service key.

Type: String

Pattern: (arn:aws:[a-z0-9-.]+:.*)|()

Required: No
MemorySize (p. 366)

The amount of memory, in MB, your Lambda function is given. Lambda uses this memory size to
infer the amount of CPU and memory allocated to your function. Your function use-case determines
your CPU and memory requirements. For example, a database operation might need less memory
compared to an image processing function. The default value is 128 MB. The value must be a
multiple of 64 MB.

Type: Integer

Valid Range: Minimum value of 128. Maximum value of 1536.

Required: No
Publish (p. 366)

This boolean parameter can be used to request AWS Lambda to create the Lambda function and
publish a version as an atomic operation.

Type: Boolean

Required: No
Role (p. 366)

The Amazon Resource Name (ARN) of the IAM role that Lambda assumes when it executes your
function to access any other Amazon Web Services (AWS) resources. For more information, see AWS
Lambda: How it Works.

Type: String

Pattern: arn:aws:iam::\d{12}:role/?[a-zA-Z_0-9+=,.@\-_/]+

Required: Yes
Runtime (p. 366)

The runtime environment for the Lambda function you are uploading.

To use the Python runtime v3.6, set the value to "python3.6". To use the Python runtime v2.7, set
the value to "python2.7". To use the Node.js runtime v6.10, set the value to "nodejs6.10". To use the
Node.js runtime v4.3, set the value to "nodejs4.3".
Note
Node v0.10.42 is currently marked as deprecated. You must migrate existing functions to
the newer Node.js runtime versions available on AWS Lambda (nodejs4.3 or nodejs6.10) as
soon as possible. You can request a one-time extension until June 30, 2017 by going to the
Lambda console and following the instructions provided. Failure to do so will result in an
invalid parmaeter error being returned. Note that you will have to follow this procedure for
each region that contains functions written in the Node v0.10.42 runtime.

Type: String

368
AWS Lambda Developer Guide
CreateFunction

Valid Values: nodejs | nodejs4.3 | nodejs6.10 | java8 | python2.7 | python3.6 |


dotnetcore1.0 | nodejs4.3-edge

Required: Yes
Tags (p. 366)

The list of tags (key-value pairs) assigned to the new function.

Type: String to string map

Required: No
Timeout (p. 366)

The function execution time at which Lambda should terminate the function. Because the execution
time has cost implications, we recommend you set this value based on your expected execution time.
The default is 3 seconds.

Type: Integer

Valid Range: Minimum value of 1.

Required: No
TracingCong (p. 366)

The parent object that contains your function's tracing settings.

Type: TracingCong (p. 470) object

Required: No
VpcCong (p. 366)

If your Lambda function accesses resources in a VPC, you provide this parameter identifying the list
of security group IDs and subnet IDs. These must belong to the same VPC. You must provide at least
one security group and one subnet ID.

Type: VpcCong (p. 472) object

Required: No

Response Syntax
HTTP/1.1 201
Content-type: application/json

{
"CodeSha256": "string",
"CodeSize": number,
"DeadLetterConfig": {
"TargetArn": "string"
},
"Description": "string",
"Environment": {
"Error": {
"ErrorCode": "string",
"Message": "string"
},
"Variables": {
"string" : "string"
}
},

369
AWS Lambda Developer Guide
CreateFunction

"FunctionArn": "string",
"FunctionName": "string",
"Handler": "string",
"KMSKeyArn": "string",
"LastModified": "string",
"MasterArn": "string",
"MemorySize": number,
"Role": "string",
"Runtime": "string",
"Timeout": number,
"TracingConfig": {
"Mode": "string"
},
"Version": "string",
"VpcConfig": {
"SecurityGroupIds": [ "string" ],
"SubnetIds": [ "string" ],
"VpcId": "string"
}
}

Response Elements
If the action is successful, the service sends back an HTTP 201 response.

The following data is returned in JSON format by the service.

CodeSha256 (p. 369)

It is the SHA256 hash of your function deployment package.

Type: String
CodeSize (p. 369)

The size, in bytes, of the function .zip le you uploaded.

Type: Long
DeadLetterCong (p. 369)

The parent object that contains the target ARN (Amazon Resource Name) of an Amazon SQS queue
or Amazon SNS topic.

Type: DeadLetterCong (p. 458) object


Description (p. 369)

The user-provided description.

Type: String

Length Constraints: Minimum length of 0. Maximum length of 256.


Environment (p. 369)

The parent object that contains your environment's conguration settings.

Type: EnvironmentResponse (p. 461) object


FunctionArn (p. 369)

The Amazon Resource Name (ARN) assigned to the function.

Type: String

370
AWS Lambda Developer Guide
CreateFunction

Pattern: arn:aws:lambda:[a-z]{2}-[a-z]+-\d{1}:\d{12}:function:[a-zA-Z0-9-_\.]+(:(\
$LATEST|[a-zA-Z0-9-_]+))?
FunctionName (p. 369)

The name of the function. Note that the length constraint applies only to the ARN. If you specify
only the function name, it is limited to 64 characters in length.

Type: String

Length Constraints: Minimum length of 1. Maximum length of 170.

Pattern: (arn:aws:lambda:)?([a-z]{2}-[a-z]+-\d{1}:)?(\d{12}:)?(function:)?([a-zA-Z0-9-_
\.]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Handler (p. 369)

The function Lambda calls to begin executing your function.

Type: String

Length Constraints: Maximum length of 128.

Pattern: [^\s]+
KMSKeyArn (p. 369)

The Amazon Resource Name (ARN) of the KMS key used to encrypt your function's environment
variables. If empty, it means you are using the AWS Lambda default service key.

Type: String

Pattern: (arn:aws:[a-z0-9-.]+:.*)|()
LastModied (p. 369)

The time stamp of the last time you updated the function. The time stamp is conveyed
as a string complying with ISO-8601 in this way YYYY-MM-DDThh:mm:ssTZD (e.g.,
1997-07-16T19:20:30+01:00). For more information, see Date and Time Formats.

Type: String
MasterArn (p. 369)

Returns the ARN (Amazon Resource Name) of the master function.

Type: String

Pattern: arn:aws:lambda:[a-z]{2}-[a-z]+-\d{1}:\d{12}:function:[a-zA-Z0-9-_]+(:(\$LATEST|
[a-zA-Z0-9-_]+))?
MemorySize (p. 369)

The memory size, in MB, you congured for the function. Must be a multiple of 64 MB.

Type: Integer

Valid Range: Minimum value of 128. Maximum value of 1536.


Role (p. 369)

The Amazon Resource Name (ARN) of the IAM role that Lambda assumes when it executes your
function to access any other Amazon Web Services (AWS) resources.

Type: String

371
AWS Lambda Developer Guide
CreateFunction

Pattern: arn:aws:iam::\d{12}:role/?[a-zA-Z_0-9+=,.@\-_/]+
Runtime (p. 369)

The runtime environment for the Lambda function.

Type: String

Valid Values: nodejs | nodejs4.3 | nodejs6.10 | java8 | python2.7 | python3.6 |


dotnetcore1.0 | nodejs4.3-edge
Timeout (p. 369)

The function execution time at which Lambda should terminate the function. Because the execution
time has cost implications, we recommend you set this value based on your expected execution time.
The default is 3 seconds.

Type: Integer

Valid Range: Minimum value of 1.


TracingCong (p. 369)

The parent object that contains your function's tracing settings.

Type: TracingCongResponse (p. 471) object


Version (p. 369)

The version of the Lambda function.

Type: String

Length Constraints: Minimum length of 1. Maximum length of 1024.

Pattern: (\$LATEST|[0-9]+)
VpcCong (p. 369)

VPC conguration associated with your Lambda function.

Type: VpcCongResponse (p. 473) object

Errors
CodeStorageExceededException

You have exceeded your maximum total code size per account. Limits

HTTP Status Code: 400


InvalidParameterValueException

One of the parameters in the request is invalid. For example, if you provided an IAM role for AWS
Lambda to assume in the CreateFunction or the UpdateFunctionConfiguration API, that AWS
Lambda is unable to assume you will get this exception. You will also get this exception if you have
selected a deprecated runtime, such as Node v0.10.42.

HTTP Status Code: 400


ResourceConictException

The resource already exists.

HTTP Status Code: 409

372
AWS Lambda Developer Guide
CreateFunction

ResourceNotFoundException

The resource (for example, a Lambda function or access policy statement) specied in the request
does not exist.

HTTP Status Code: 404


ServiceException

The AWS Lambda service encountered an internal error.

HTTP Status Code: 500


TooManyRequestsException

HTTP Status Code: 429

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS Command Line Interface


AWS SDK for .NET
AWS SDK for C++
AWS SDK for Go
AWS SDK for Java
AWS SDK for JavaScript
AWS SDK for PHP V3
AWS SDK for Python
AWS SDK for Ruby V2

373
AWS Lambda Developer Guide
DeleteAlias

DeleteAlias
Deletes the specied Lambda function alias. For more information, see Introduction to AWS Lambda
Aliases.

This requires permission for the lambda:DeleteAlias action.

Request Syntax
DELETE /2015-03-31/functions/FunctionName/aliases/Name HTTP/1.1

URI Request Parameters


The request requires the following URI parameters.

FunctionName (p. 374)

The Lambda function name for which the alias is created. Deleting an alias does not delete the
function version to which it is pointing. Note that the length constraint applies only to the ARN. If
you specify only the function name, it is limited to 64 characters in length.

Length Constraints: Minimum length of 1. Maximum length of 140.

Pattern: (arn:aws:lambda:)?([a-z]{2}-[a-z]+-\d{1}:)?(\d{12}:)?(function:)?([a-zA-Z0-9-
_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Name (p. 374)

Name of the alias to delete.

Length Constraints: Minimum length of 1. Maximum length of 128.

Pattern: (?!^[0-9]+$)([a-zA-Z0-9-_]+)

Request Body
The request does not have a request body.

Response Syntax
HTTP/1.1 204

Response Elements
If the action is successful, the service sends back an HTTP 204 response with an empty HTTP body.

Errors
InvalidParameterValueException

One of the parameters in the request is invalid. For example, if you provided an IAM role for AWS
Lambda to assume in the CreateFunction or the UpdateFunctionConfiguration API, that AWS
Lambda is unable to assume you will get this exception. You will also get this exception if you have
selected a deprecated runtime, such as Node v0.10.42.

374
AWS Lambda Developer Guide
DeleteAlias

HTTP Status Code: 400


ServiceException

The AWS Lambda service encountered an internal error.

HTTP Status Code: 500


TooManyRequestsException

HTTP Status Code: 429

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS Command Line Interface


AWS SDK for .NET
AWS SDK for C++
AWS SDK for Go
AWS SDK for Java
AWS SDK for JavaScript
AWS SDK for PHP V3
AWS SDK for Python
AWS SDK for Ruby V2

375
AWS Lambda Developer Guide
DeleteEventSourceMapping

DeleteEventSourceMapping
Removes an event source mapping. This means AWS Lambda will no longer invoke the function for
events in the associated source.

This operation requires permission for the lambda:DeleteEventSourceMapping action.

Request Syntax
DELETE /2015-03-31/event-source-mappings/UUID HTTP/1.1

URI Request Parameters


The request requires the following URI parameters.

UUID (p. 376)

The event source mapping ID.

Request Body
The request does not have a request body.

Response Syntax
HTTP/1.1 202
Content-type: application/json

{
"BatchSize": number,
"EventSourceArn": "string",
"FunctionArn": "string",
"LastModified": number,
"LastProcessingResult": "string",
"State": "string",
"StateTransitionReason": "string",
"UUID": "string"
}

Response Elements
If the action is successful, the service sends back an HTTP 202 response.

The following data is returned in JSON format by the service.

BatchSize (p. 376)

The largest number of records that AWS Lambda will retrieve from your event source at the time of
invoking your function. Your function receives an event with all the retrieved records.

Type: Integer

Valid Range: Minimum value of 1. Maximum value of 10000.


EventSourceArn (p. 376)

The Amazon Resource Name (ARN) of the Amazon Kinesis stream that is the source of events.

376
AWS Lambda Developer Guide
DeleteEventSourceMapping

Type: String

Pattern: arn:aws:([a-zA-Z0-9\-])+:([a-z]{2}-[a-z]+-\d{1})?:(\d{12})?:(.*)
FunctionArn (p. 376)

The Lambda function to invoke when AWS Lambda detects an event on the stream.

Type: String

Pattern: arn:aws:lambda:[a-z]{2}-[a-z]+-\d{1}:\d{12}:function:[a-zA-Z0-9-_]+(:(\$LATEST|
[a-zA-Z0-9-_]+))?
LastModied (p. 376)

The UTC time string indicating the last time the event mapping was updated.

Type: Timestamp
LastProcessingResult (p. 376)

The result of the last AWS Lambda invocation of your Lambda function.

Type: String
State (p. 376)

The state of the event source mapping. It can be Creating, Enabled, Disabled, Enabling, Disabling,
Updating, or Deleting.

Type: String
StateTransitionReason (p. 376)

The reason the event source mapping is in its current state. It is either user-requested or an AWS
Lambda-initiated state transition.

Type: String
UUID (p. 376)

The AWS Lambda assigned opaque identier for the mapping.

Type: String

Errors
InvalidParameterValueException

One of the parameters in the request is invalid. For example, if you provided an IAM role for AWS
Lambda to assume in the CreateFunction or the UpdateFunctionConfiguration API, that AWS
Lambda is unable to assume you will get this exception. You will also get this exception if you have
selected a deprecated runtime, such as Node v0.10.42.

HTTP Status Code: 400


ResourceNotFoundException

The resource (for example, a Lambda function or access policy statement) specied in the request
does not exist.

HTTP Status Code: 404


ServiceException

The AWS Lambda service encountered an internal error.

377
AWS Lambda Developer Guide
DeleteEventSourceMapping

HTTP Status Code: 500


TooManyRequestsException

HTTP Status Code: 429

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS Command Line Interface


AWS SDK for .NET
AWS SDK for C++
AWS SDK for Go
AWS SDK for Java
AWS SDK for JavaScript
AWS SDK for PHP V3
AWS SDK for Python
AWS SDK for Ruby V2

378
AWS Lambda Developer Guide
DeleteFunction

DeleteFunction
Deletes the specied Lambda function code and conguration.

If you are using the versioning feature and you don't specify a function version in your DeleteFunction
request, AWS Lambda will delete the function, including all its versions, and any aliases pointing to the
function versions. To delete a specic function version, you must provide the function version via the
Qualifier parameter. For information about function versioning, see AWS Lambda Function Versioning
and Aliases.

When you delete a function the associated resource policy is also deleted. You will need to delete the
event source mappings explicitly.

This operation requires permission for the lambda:DeleteFunction action.

Request Syntax
DELETE /2015-03-31/functions/FunctionName?Qualifier=Qualifier HTTP/1.1

URI Request Parameters


The request requires the following URI parameters.

FunctionName (p. 379)

The Lambda function to delete.

You can specify the function name (for example, Thumbnail) or you can specify Amazon
Resource Name (ARN) of the function (for example, arn:aws:lambda:us-west-2:account-
id:function:ThumbNail). If you are using versioning, you can also provide a qualied function ARN
(ARN that is qualied with function version or alias name as sux). AWS Lambda also allows you to
specify only the function name with the account ID qualier (for example, account-id:Thumbnail).
Note that the length constraint applies only to the ARN. If you specify only the function name, it is
limited to 64 characters in length.

Length Constraints: Minimum length of 1. Maximum length of 140.

Pattern: (arn:aws:lambda:)?([a-z]{2}-[a-z]+-\d{1}:)?(\d{12}:)?(function:)?([a-zA-Z0-9-
_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Qualier (p. 379)

Using this optional parameter you can specify a function version (but not the $LATEST version) to
direct AWS Lambda to delete a specic function version. If the function version has one or more
aliases pointing to it, you will get an error because you cannot have aliases pointing to it. You can
delete any function version but not the $LATEST, that is, you cannot specify $LATEST as the value of
this parameter. The $LATEST version can be deleted only when you want to delete all the function
versions and aliases.

You can only specify a function version, not an alias name, using this parameter. You cannot delete a
function version using its alias.

If you don't specify this parameter, AWS Lambda will delete the function, including all of its versions
and aliases.

Length Constraints: Minimum length of 1. Maximum length of 128.

Pattern: (|[a-zA-Z0-9$_-]+)

379
AWS Lambda Developer Guide
DeleteFunction

Request Body
The request does not have a request body.

Response Syntax
HTTP/1.1 204

Response Elements
If the action is successful, the service sends back an HTTP 204 response with an empty HTTP body.

Errors
InvalidParameterValueException

One of the parameters in the request is invalid. For example, if you provided an IAM role for AWS
Lambda to assume in the CreateFunction or the UpdateFunctionConfiguration API, that AWS
Lambda is unable to assume you will get this exception. You will also get this exception if you have
selected a deprecated runtime, such as Node v0.10.42.

HTTP Status Code: 400


ResourceConictException

The resource already exists.

HTTP Status Code: 409


ResourceNotFoundException

The resource (for example, a Lambda function or access policy statement) specied in the request
does not exist.

HTTP Status Code: 404


ServiceException

The AWS Lambda service encountered an internal error.

HTTP Status Code: 500


TooManyRequestsException

HTTP Status Code: 429

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS Command Line Interface


AWS SDK for .NET
AWS SDK for C++
AWS SDK for Go
AWS SDK for Java
AWS SDK for JavaScript

380
AWS Lambda Developer Guide
DeleteFunction

AWS SDK for PHP V3


AWS SDK for Python
AWS SDK for Ruby V2

381
AWS Lambda Developer Guide
GetAccountSettings

GetAccountSettings
Returns a customer's account settings.

You can use this operation to retrieve Lambda limits information, such as code size and concurrency
limits. For more information about limits, see AWS Lambda Limits. You can also retrieve resource usage
statistics, such as code storage usage and function count.

Request Syntax
GET /2016-08-19/account-settings/ HTTP/1.1

URI Request Parameters


The request does not use any URI parameters.

Request Body
The request does not have a request body.

Response Syntax
HTTP/1.1 200
Content-type: application/json

{
"AccountLimit": {
"CodeSizeUnzipped": number,
"CodeSizeZipped": number,
"ConcurrentExecutions": number,
"TotalCodeSize": number
},
"AccountUsage": {
"FunctionCount": number,
"TotalCodeSize": number
}
}

Response Elements
If the action is successful, the service sends back an HTTP 200 response.

The following data is returned in JSON format by the service.

AccountLimit (p. 382)

Provides limits of code size and concurrency associated with the current account and region.

Type: AccountLimit (p. 454) object


AccountUsage (p. 382)

Provides code size usage and function count associated with the current account and region.

Type: AccountUsage (p. 455) object

382
AWS Lambda Developer Guide
GetAccountSettings

Errors
ServiceException

The AWS Lambda service encountered an internal error.

HTTP Status Code: 500


TooManyRequestsException

HTTP Status Code: 429

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS Command Line Interface


AWS SDK for .NET
AWS SDK for C++
AWS SDK for Go
AWS SDK for Java
AWS SDK for JavaScript
AWS SDK for PHP V3
AWS SDK for Python
AWS SDK for Ruby V2

383
AWS Lambda Developer Guide
GetAlias

GetAlias
Returns the specied alias information such as the alias ARN, description, and function version it is
pointing to. For more information, see Introduction to AWS Lambda Aliases.

This requires permission for the lambda:GetAlias action.

Request Syntax
GET /2015-03-31/functions/FunctionName/aliases/Name HTTP/1.1

URI Request Parameters


The request requires the following URI parameters.

FunctionName (p. 384)

Function name for which the alias is created. An alias is a subresource that exists only in the
context of an existing Lambda function so you must specify the function name. Note that the
length constraint applies only to the ARN. If you specify only the function name, it is limited to 64
characters in length.

Length Constraints: Minimum length of 1. Maximum length of 140.

Pattern: (arn:aws:lambda:)?([a-z]{2}-[a-z]+-\d{1}:)?(\d{12}:)?(function:)?([a-zA-Z0-9-
_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Name (p. 384)

Name of the alias for which you want to retrieve information.

Length Constraints: Minimum length of 1. Maximum length of 128.

Pattern: (?!^[0-9]+$)([a-zA-Z0-9-_]+)

Request Body
The request does not have a request body.

Response Syntax
HTTP/1.1 200
Content-type: application/json

{
"AliasArn": "string",
"Description": "string",
"FunctionVersion": "string",
"Name": "string"
}

Response Elements
If the action is successful, the service sends back an HTTP 200 response.

The following data is returned in JSON format by the service.

384
AWS Lambda Developer Guide
GetAlias

AliasArn (p. 384)

Lambda function ARN that is qualied using the alias name as the sux. For example, if you create
an alias called BETA that points to a helloworld function version, the ARN is arn:aws:lambda:aws-
regions:acct-id:function:helloworld:BETA.

Type: String

Pattern: arn:aws:lambda:[a-z]{2}-[a-z]+-\d{1}:\d{12}:function:[a-zA-Z0-9-_]+(:(\$LATEST|
[a-zA-Z0-9-_]+))?
Description (p. 384)

Alias description.

Type: String

Length Constraints: Minimum length of 0. Maximum length of 256.


FunctionVersion (p. 384)

Function version to which the alias points.

Type: String

Length Constraints: Minimum length of 1. Maximum length of 1024.

Pattern: (\$LATEST|[0-9]+)
Name (p. 384)

Alias name.

Type: String

Length Constraints: Minimum length of 1. Maximum length of 128.

Pattern: (?!^[0-9]+$)([a-zA-Z0-9-_]+)

Errors
InvalidParameterValueException

One of the parameters in the request is invalid. For example, if you provided an IAM role for AWS
Lambda to assume in the CreateFunction or the UpdateFunctionConfiguration API, that AWS
Lambda is unable to assume you will get this exception. You will also get this exception if you have
selected a deprecated runtime, such as Node v0.10.42.

HTTP Status Code: 400


ResourceNotFoundException

The resource (for example, a Lambda function or access policy statement) specied in the request
does not exist.

HTTP Status Code: 404


ServiceException

The AWS Lambda service encountered an internal error.

HTTP Status Code: 500


TooManyRequestsException

385
AWS Lambda Developer Guide
GetAlias

HTTP Status Code: 429

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS Command Line Interface


AWS SDK for .NET
AWS SDK for C++
AWS SDK for Go
AWS SDK for Java
AWS SDK for JavaScript
AWS SDK for PHP V3
AWS SDK for Python
AWS SDK for Ruby V2

386
AWS Lambda Developer Guide
GetEventSourceMapping

GetEventSourceMapping
Returns conguration information for the specied event source mapping (see
CreateEventSourceMapping (p. 361)).

This operation requires permission for the lambda:GetEventSourceMapping action.

Request Syntax
GET /2015-03-31/event-source-mappings/UUID HTTP/1.1

URI Request Parameters


The request requires the following URI parameters.

UUID (p. 387)

The AWS Lambda assigned ID of the event source mapping.

Request Body
The request does not have a request body.

Response Syntax
HTTP/1.1 200
Content-type: application/json

{
"BatchSize": number,
"EventSourceArn": "string",
"FunctionArn": "string",
"LastModified": number,
"LastProcessingResult": "string",
"State": "string",
"StateTransitionReason": "string",
"UUID": "string"
}

Response Elements
If the action is successful, the service sends back an HTTP 200 response.

The following data is returned in JSON format by the service.

BatchSize (p. 387)

The largest number of records that AWS Lambda will retrieve from your event source at the time of
invoking your function. Your function receives an event with all the retrieved records.

Type: Integer

Valid Range: Minimum value of 1. Maximum value of 10000.


EventSourceArn (p. 387)

The Amazon Resource Name (ARN) of the Amazon Kinesis stream that is the source of events.

387
AWS Lambda Developer Guide
GetEventSourceMapping

Type: String

Pattern: arn:aws:([a-zA-Z0-9\-])+:([a-z]{2}-[a-z]+-\d{1})?:(\d{12})?:(.*)
FunctionArn (p. 387)

The Lambda function to invoke when AWS Lambda detects an event on the stream.

Type: String

Pattern: arn:aws:lambda:[a-z]{2}-[a-z]+-\d{1}:\d{12}:function:[a-zA-Z0-9-_]+(:(\$LATEST|
[a-zA-Z0-9-_]+))?
LastModied (p. 387)

The UTC time string indicating the last time the event mapping was updated.

Type: Timestamp
LastProcessingResult (p. 387)

The result of the last AWS Lambda invocation of your Lambda function.

Type: String
State (p. 387)

The state of the event source mapping. It can be Creating, Enabled, Disabled, Enabling, Disabling,
Updating, or Deleting.

Type: String
StateTransitionReason (p. 387)

The reason the event source mapping is in its current state. It is either user-requested or an AWS
Lambda-initiated state transition.

Type: String
UUID (p. 387)

The AWS Lambda assigned opaque identier for the mapping.

Type: String

Errors
InvalidParameterValueException

One of the parameters in the request is invalid. For example, if you provided an IAM role for AWS
Lambda to assume in the CreateFunction or the UpdateFunctionConfiguration API, that AWS
Lambda is unable to assume you will get this exception. You will also get this exception if you have
selected a deprecated runtime, such as Node v0.10.42.

HTTP Status Code: 400


ResourceNotFoundException

The resource (for example, a Lambda function or access policy statement) specied in the request
does not exist.

HTTP Status Code: 404


ServiceException

The AWS Lambda service encountered an internal error.

388
AWS Lambda Developer Guide
GetEventSourceMapping

HTTP Status Code: 500


TooManyRequestsException

HTTP Status Code: 429

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS Command Line Interface


AWS SDK for .NET
AWS SDK for C++
AWS SDK for Go
AWS SDK for Java
AWS SDK for JavaScript
AWS SDK for PHP V3
AWS SDK for Python
AWS SDK for Ruby V2

389
AWS Lambda Developer Guide
GetFunction

GetFunction
Returns the conguration information of the Lambda function and a presigned URL link to the .zip le
you uploaded with CreateFunction (p. 366) so you can download the .zip le. Note that the URL is valid
for up to 10 minutes. The conguration information is the same information you provided as parameters
when uploading the function.

Using the optional Qualifier parameter, you can specify a specic function version for which you want
this information. If you don't specify this parameter, the API uses unqualied function ARN which return
information about the $LATEST version of the Lambda function. For more information, see AWS Lambda
Function Versioning and Aliases.

This operation requires permission for the lambda:GetFunction action.

Request Syntax
GET /2015-03-31/functions/FunctionName?Qualifier=Qualifier HTTP/1.1

URI Request Parameters


The request requires the following URI parameters.

FunctionName (p. 390)

The Lambda function name.

You can specify a function name (for example, Thumbnail) or you can specify Amazon
Resource Name (ARN) of the function (for example, arn:aws:lambda:us-west-2:account-
id:function:ThumbNail). AWS Lambda also allows you to specify a partial ARN (for example,
account-id:Thumbnail). Note that the length constraint applies only to the ARN. If you specify only
the function name, it is limited to 64 characters in length.

Length Constraints: Minimum length of 1. Maximum length of 170.

Pattern: (arn:aws:lambda:)?([a-z]{2}-[a-z]+-\d{1}:)?(\d{12}:)?(function:)?([a-zA-Z0-9-_
\.]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Qualier (p. 390)

Using this optional parameter to specify a function version or an alias name. If you specify function
version, the API uses qualied function ARN for the request and returns information about the
specic Lambda function version. If you specify an alias name, the API uses the alias ARN and returns
information about the function version to which the alias points. If you don't provide this parameter,
the API uses unqualied function ARN and returns information about the $LATEST version of the
Lambda function.

Length Constraints: Minimum length of 1. Maximum length of 128.

Pattern: (|[a-zA-Z0-9$_-]+)

Request Body
The request does not have a request body.

Response Syntax
HTTP/1.1 200

390
AWS Lambda Developer Guide
GetFunction

Content-type: application/json

{
"Code": {
"Location": "string",
"RepositoryType": "string"
},
"Configuration": {
"CodeSha256": "string",
"CodeSize": number,
"DeadLetterConfig": {
"TargetArn": "string"
},
"Description": "string",
"Environment": {
"Error": {
"ErrorCode": "string",
"Message": "string"
},
"Variables": {
"string" : "string"
}
},
"FunctionArn": "string",
"FunctionName": "string",
"Handler": "string",
"KMSKeyArn": "string",
"LastModified": "string",
"MasterArn": "string",
"MemorySize": number,
"Role": "string",
"Runtime": "string",
"Timeout": number,
"TracingConfig": {
"Mode": "string"
},
"Version": "string",
"VpcConfig": {
"SecurityGroupIds": [ "string" ],
"SubnetIds": [ "string" ],
"VpcId": "string"
}
},
"Tags": {
"string" : "string"
}
}

Response Elements
If the action is successful, the service sends back an HTTP 200 response.

The following data is returned in JSON format by the service.

Code (p. 390)

The object for the Lambda function location.

Type: FunctionCodeLocation (p. 465) object


Conguration (p. 390)

A complex type that describes function metadata.

Type: FunctionConguration (p. 466) object

391
AWS Lambda Developer Guide
GetFunction

Tags (p. 390)

Returns the list of tags associated with the function.

Type: String to string map

Errors
InvalidParameterValueException

One of the parameters in the request is invalid. For example, if you provided an IAM role for AWS
Lambda to assume in the CreateFunction or the UpdateFunctionConfiguration API, that AWS
Lambda is unable to assume you will get this exception. You will also get this exception if you have
selected a deprecated runtime, such as Node v0.10.42.

HTTP Status Code: 400


ResourceNotFoundException

The resource (for example, a Lambda function or access policy statement) specied in the request
does not exist.

HTTP Status Code: 404


ServiceException

The AWS Lambda service encountered an internal error.

HTTP Status Code: 500


TooManyRequestsException

HTTP Status Code: 429

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS Command Line Interface


AWS SDK for .NET
AWS SDK for C++
AWS SDK for Go
AWS SDK for Java
AWS SDK for JavaScript
AWS SDK for PHP V3
AWS SDK for Python
AWS SDK for Ruby V2

392
AWS Lambda Developer Guide
GetFunctionConguration

GetFunctionConguration
Returns the conguration information of the Lambda function. This the same information you provided
as parameters when uploading the function by using CreateFunction (p. 366).

If you are using the versioning feature, you can retrieve this information for a specic function version
by using the optional Qualifier parameter and specifying the function version or alias that points to it.
If you don't provide it, the API returns information about the $LATEST version of the function. For more
information about versioning, see AWS Lambda Function Versioning and Aliases.

This operation requires permission for the lambda:GetFunctionConfiguration operation.

Request Syntax
GET /2015-03-31/functions/FunctionName/configuration?Qualifier=Qualifier HTTP/1.1

URI Request Parameters


The request requires the following URI parameters.

FunctionName (p. 393)

The name of the Lambda function for which you want to retrieve the conguration information.

You can specify a function name (for example, Thumbnail) or you can specify Amazon
Resource Name (ARN) of the function (for example, arn:aws:lambda:us-west-2:account-
id:function:ThumbNail). AWS Lambda also allows you to specify a partial ARN (for example,
account-id:Thumbnail). Note that the length constraint applies only to the ARN. If you specify only
the function name, it is limited to 64 characters in length.

Length Constraints: Minimum length of 1. Maximum length of 170.

Pattern: (arn:aws:lambda:)?([a-z]{2}-[a-z]+-\d{1}:)?(\d{12}:)?(function:)?([a-zA-Z0-9-_
\.]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Qualier (p. 393)

Using this optional parameter you can specify a function version or an alias name. If you specify
function version, the API uses qualied function ARN and returns information about the specic
function version. If you specify an alias name, the API uses the alias ARN and returns information
about the function version to which the alias points.

If you don't specify this parameter, the API uses unqualied function ARN, and returns information
about the $LATEST function version.

Length Constraints: Minimum length of 1. Maximum length of 128.

Pattern: (|[a-zA-Z0-9$_-]+)

Request Body
The request does not have a request body.

Response Syntax
HTTP/1.1 200
Content-type: application/json

393
AWS Lambda Developer Guide
GetFunctionConguration

{
"CodeSha256": "string",
"CodeSize": number,
"DeadLetterConfig": {
"TargetArn": "string"
},
"Description": "string",
"Environment": {
"Error": {
"ErrorCode": "string",
"Message": "string"
},
"Variables": {
"string" : "string"
}
},
"FunctionArn": "string",
"FunctionName": "string",
"Handler": "string",
"KMSKeyArn": "string",
"LastModified": "string",
"MasterArn": "string",
"MemorySize": number,
"Role": "string",
"Runtime": "string",
"Timeout": number,
"TracingConfig": {
"Mode": "string"
},
"Version": "string",
"VpcConfig": {
"SecurityGroupIds": [ "string" ],
"SubnetIds": [ "string" ],
"VpcId": "string"
}
}

Response Elements
If the action is successful, the service sends back an HTTP 200 response.

The following data is returned in JSON format by the service.

CodeSha256 (p. 393)

It is the SHA256 hash of your function deployment package.

Type: String
CodeSize (p. 393)

The size, in bytes, of the function .zip le you uploaded.

Type: Long
DeadLetterCong (p. 393)

The parent object that contains the target ARN (Amazon Resource Name) of an Amazon SQS queue
or Amazon SNS topic.

Type: DeadLetterCong (p. 458) object


Description (p. 393)

The user-provided description.

394
AWS Lambda Developer Guide
GetFunctionConguration

Type: String

Length Constraints: Minimum length of 0. Maximum length of 256.


Environment (p. 393)

The parent object that contains your environment's conguration settings.

Type: EnvironmentResponse (p. 461) object


FunctionArn (p. 393)

The Amazon Resource Name (ARN) assigned to the function.

Type: String

Pattern: arn:aws:lambda:[a-z]{2}-[a-z]+-\d{1}:\d{12}:function:[a-zA-Z0-9-_\.]+(:(\
$LATEST|[a-zA-Z0-9-_]+))?
FunctionName (p. 393)

The name of the function. Note that the length constraint applies only to the ARN. If you specify
only the function name, it is limited to 64 characters in length.

Type: String

Length Constraints: Minimum length of 1. Maximum length of 170.

Pattern: (arn:aws:lambda:)?([a-z]{2}-[a-z]+-\d{1}:)?(\d{12}:)?(function:)?([a-zA-Z0-9-_
\.]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Handler (p. 393)

The function Lambda calls to begin executing your function.

Type: String

Length Constraints: Maximum length of 128.

Pattern: [^\s]+
KMSKeyArn (p. 393)

The Amazon Resource Name (ARN) of the KMS key used to encrypt your function's environment
variables. If empty, it means you are using the AWS Lambda default service key.

Type: String

Pattern: (arn:aws:[a-z0-9-.]+:.*)|()
LastModied (p. 393)

The time stamp of the last time you updated the function. The time stamp is conveyed
as a string complying with ISO-8601 in this way YYYY-MM-DDThh:mm:ssTZD (e.g.,
1997-07-16T19:20:30+01:00). For more information, see Date and Time Formats.

Type: String
MasterArn (p. 393)

Returns the ARN (Amazon Resource Name) of the master function.

Type: String

Pattern: arn:aws:lambda:[a-z]{2}-[a-z]+-\d{1}:\d{12}:function:[a-zA-Z0-9-_]+(:(\$LATEST|
[a-zA-Z0-9-_]+))?

395
AWS Lambda Developer Guide
GetFunctionConguration

MemorySize (p. 393)

The memory size, in MB, you congured for the function. Must be a multiple of 64 MB.

Type: Integer

Valid Range: Minimum value of 128. Maximum value of 1536.


Role (p. 393)

The Amazon Resource Name (ARN) of the IAM role that Lambda assumes when it executes your
function to access any other Amazon Web Services (AWS) resources.

Type: String

Pattern: arn:aws:iam::\d{12}:role/?[a-zA-Z_0-9+=,.@\-_/]+
Runtime (p. 393)

The runtime environment for the Lambda function.

Type: String

Valid Values: nodejs | nodejs4.3 | nodejs6.10 | java8 | python2.7 | python3.6 |


dotnetcore1.0 | nodejs4.3-edge
Timeout (p. 393)

The function execution time at which Lambda should terminate the function. Because the execution
time has cost implications, we recommend you set this value based on your expected execution time.
The default is 3 seconds.

Type: Integer

Valid Range: Minimum value of 1.


TracingCong (p. 393)

The parent object that contains your function's tracing settings.

Type: TracingCongResponse (p. 471) object


Version (p. 393)

The version of the Lambda function.

Type: String

Length Constraints: Minimum length of 1. Maximum length of 1024.

Pattern: (\$LATEST|[0-9]+)
VpcCong (p. 393)

VPC conguration associated with your Lambda function.

Type: VpcCongResponse (p. 473) object

Errors
InvalidParameterValueException

One of the parameters in the request is invalid. For example, if you provided an IAM role for AWS
Lambda to assume in the CreateFunction or the UpdateFunctionConfiguration API, that AWS

396
AWS Lambda Developer Guide
GetFunctionConguration

Lambda is unable to assume you will get this exception. You will also get this exception if you have
selected a deprecated runtime, such as Node v0.10.42.

HTTP Status Code: 400


ResourceNotFoundException

The resource (for example, a Lambda function or access policy statement) specied in the request
does not exist.

HTTP Status Code: 404


ServiceException

The AWS Lambda service encountered an internal error.

HTTP Status Code: 500


TooManyRequestsException

HTTP Status Code: 429

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS Command Line Interface


AWS SDK for .NET
AWS SDK for C++
AWS SDK for Go
AWS SDK for Java
AWS SDK for JavaScript
AWS SDK for PHP V3
AWS SDK for Python
AWS SDK for Ruby V2

397
AWS Lambda Developer Guide
GetPolicy

GetPolicy
Returns the resource policy associated with the specied Lambda function.

If you are using the versioning feature, you can get the resource policy associated with the specic
Lambda function version or alias by specifying the version or alias name using the Qualifier parameter.
For more information about versioning, see AWS Lambda Function Versioning and Aliases.

You need permission for the lambda:GetPolicy action.

Request Syntax
GET /2015-03-31/functions/FunctionName/policy?Qualifier=Qualifier HTTP/1.1

URI Request Parameters


The request requires the following URI parameters.

FunctionName (p. 398)

Function name whose resource policy you want to retrieve.

You can specify the function name (for example, Thumbnail) or you can specify Amazon
Resource Name (ARN) of the function (for example, arn:aws:lambda:us-west-2:account-
id:function:ThumbNail). If you are using versioning, you can also provide a qualied function ARN
(ARN that is qualied with function version or alias name as sux). AWS Lambda also allows you to
specify only the function name with the account ID qualier (for example, account-id:Thumbnail).
Note that the length constraint applies only to the ARN. If you specify only the function name, it is
limited to 64 characters in length.

Length Constraints: Minimum length of 1. Maximum length of 170.

Pattern: (arn:aws:lambda:)?([a-z]{2}-[a-z]+-\d{1}:)?(\d{12}:)?(function:)?([a-zA-Z0-9-_
\.]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Qualier (p. 398)

You can specify this optional query parameter to specify a function version or an alias name in
which case this API will return all permissions associated with the specic qualied ARN. If you don't
provide this parameter, the API will return permissions that apply to the unqualied function ARN.

Length Constraints: Minimum length of 1. Maximum length of 128.

Pattern: (|[a-zA-Z0-9$_-]+)

Request Body
The request does not have a request body.

Response Syntax
HTTP/1.1 200
Content-type: application/json

{
"Policy": "string"

398
AWS Lambda Developer Guide
GetPolicy

Response Elements
If the action is successful, the service sends back an HTTP 200 response.

The following data is returned in JSON format by the service.

Policy (p. 398)

The resource policy associated with the specied function. The response returns the same as a string
using a backslash ("\") as an escape character in the JSON.

Type: String

Errors
InvalidParameterValueException

One of the parameters in the request is invalid. For example, if you provided an IAM role for AWS
Lambda to assume in the CreateFunction or the UpdateFunctionConfiguration API, that AWS
Lambda is unable to assume you will get this exception. You will also get this exception if you have
selected a deprecated runtime, such as Node v0.10.42.

HTTP Status Code: 400


ResourceNotFoundException

The resource (for example, a Lambda function or access policy statement) specied in the request
does not exist.

HTTP Status Code: 404


ServiceException

The AWS Lambda service encountered an internal error.

HTTP Status Code: 500


TooManyRequestsException

HTTP Status Code: 429

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS Command Line Interface


AWS SDK for .NET
AWS SDK for C++
AWS SDK for Go
AWS SDK for Java
AWS SDK for JavaScript
AWS SDK for PHP V3
AWS SDK for Python
AWS SDK for Ruby V2

399
AWS Lambda Developer Guide
GetPolicy

400
AWS Lambda Developer Guide
Invoke

Invoke
Invokes a specic Lambda function. For an example, see Create the Lambda Function and Test It
Manually.

If you are using the versioning feature, you can invoke the specic function version by providing function
version or alias name that is pointing to the function version using the Qualifier parameter in the
request. If you don't provide the Qualifier parameter, the $LATEST version of the Lambda function is
invoked. Invocations occur at least once in response to an event and functions must be idempotent to
handle this. For information about the versioning feature, see AWS Lambda Function Versioning and
Aliases.

This operation requires permission for the lambda:InvokeFunction action.

Request Syntax
POST /2015-03-31/functions/FunctionName/invocations?Qualifier=Qualifier HTTP/1.1
X-Amz-Invocation-Type: InvocationType
X-Amz-Log-Type: LogType
X-Amz-Client-Context: ClientContext

Payload

URI Request Parameters


The request requires the following URI parameters.

ClientContext (p. 401)

Using the ClientContext you can pass client-specic information to the Lambda function you
are invoking. You can then process the client information in your Lambda function as you choose
through the context variable. For an example of a ClientContext JSON, see PutEvents in the
Amazon Mobile Analytics API Reference and User Guide.

The ClientContext JSON must be base64-encoded.


FunctionName (p. 401)

The Lambda function name.

You can specify a function name (for example, Thumbnail) or you can specify Amazon
Resource Name (ARN) of the function (for example, arn:aws:lambda:us-west-2:account-
id:function:ThumbNail). AWS Lambda also allows you to specify a partial ARN (for example,
account-id:Thumbnail). Note that the length constraint applies only to the ARN. If you specify only
the function name, it is limited to 64 characters in length.

Length Constraints: Minimum length of 1. Maximum length of 170.

Pattern: (arn:aws:lambda:)?([a-z]{2}-[a-z]+-\d{1}:)?(\d{12}:)?(function:)?([a-zA-Z0-9-_
\.]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
InvocationType (p. 401)

By default, the Invoke API assumes RequestResponse invocation type. You can optionally request
asynchronous execution by specifying Event as the InvocationType. You can also use this parameter
to request AWS Lambda to not execute the function but do some verication, such as if the caller is
authorized to invoke the function and if the inputs are valid. You request this by specifying DryRun
as the InvocationType. This is useful in a cross-account scenario when you want to verify access to a
function without running it.

401
AWS Lambda Developer Guide
Invoke

Valid Values: Event | RequestResponse | DryRun


LogType (p. 401)

You can set this optional parameter to Tail in the request only if you specify the InvocationType
parameter with value RequestResponse. In this case, AWS Lambda returns the base64-encoded last 4
KB of log data produced by your Lambda function in the x-amz-log-result header.

Valid Values: None | Tail


Qualier (p. 401)

You can use this optional parameter to specify a Lambda function version or alias name. If you
specify a function version, the API uses the qualied function ARN to invoke a specic Lambda
function. If you specify an alias name, the API uses the alias ARN to invoke the Lambda function
version to which the alias points.

If you don't provide this parameter, then the API uses unqualied function ARN which results in
invocation of the $LATEST version.

Length Constraints: Minimum length of 1. Maximum length of 128.

Pattern: (|[a-zA-Z0-9$_-]+)

Request Body
The request accepts the following binary data.
<varlistentry> Payload (p. 401)

JSON that you want to provide to your Lambda function as input.


</varlistentry>

Response Syntax
HTTP/1.1 StatusCode
X-Amz-Function-Error: FunctionError
X-Amz-Log-Result: LogResult

Payload

Response Elements
If the action is successful, the service sends back the following HTTP response.

StatusCode (p. 402)

The HTTP status code will be in the 200 range for successful request. For the RequestResponse
invocation type this status code will be 200. For the Event invocation type this status code will be
202. For the DryRun invocation type the status code will be 204.

The response returns the following HTTP headers.

FunctionError (p. 402)

Indicates whether an error occurred while executing the Lambda function. If an error occurred this
eld will have one of two values; Handled or Unhandled. Handled errors are errors that are reported
by the function while the Unhandled errors are those detected and reported by AWS Lambda.

402
AWS Lambda Developer Guide
Invoke

Unhandled errors include out of memory errors and function timeouts. For information about how
to report an Handled error, see Programming Model.
LogResult (p. 402)

It is the base64-encoded logs for the Lambda function invocation. This is present only if the
invocation type is RequestResponse and the logs were requested.

The response returns the following as the HTTP body.


<varlistentry> Payload (p. 402)

It is the JSON representation of the object returned by the Lambda function. This is present only if the
invocation type is RequestResponse.

In the event of a function error this eld contains a message describing the error. For the Handled errors
the Lambda function will report this message. For Unhandled errors AWS Lambda reports the message.
</varlistentry>

Errors
EC2AccessDeniedException

HTTP Status Code: 502


EC2ThrottledException

AWS Lambda was throttled by Amazon EC2 during Lambda function initialization using the
execution role provided for the Lambda function.

HTTP Status Code: 502


EC2UnexpectedException

AWS Lambda received an unexpected EC2 client exception while setting up for the Lambda function.

HTTP Status Code: 502


ENILimitReachedException

AWS Lambda was not able to create an Elastic Network Interface (ENI) in the VPC, specied as part
of Lambda function conguration, because the limit for network interfaces has been reached.

HTTP Status Code: 502


InvalidParameterValueException

One of the parameters in the request is invalid. For example, if you provided an IAM role for AWS
Lambda to assume in the CreateFunction or the UpdateFunctionConfiguration API, that AWS
Lambda is unable to assume you will get this exception. You will also get this exception if you have
selected a deprecated runtime, such as Node v0.10.42.

HTTP Status Code: 400


InvalidRequestContentException

The request body could not be parsed as JSON.

HTTP Status Code: 400


InvalidRuntimeException

The runtime or runtime version specied is not supported.

403
AWS Lambda Developer Guide
Invoke

HTTP Status Code: 502


InvalidSecurityGroupIDException

The Security Group ID provided in the Lambda function VPC conguration is invalid.

HTTP Status Code: 502


InvalidSubnetIDException

The Subnet ID provided in the Lambda function VPC conguration is invalid.

HTTP Status Code: 502


InvalidZipFileException

AWS Lambda could not unzip the function zip le.

HTTP Status Code: 502


KMSAccessDeniedException

Lambda was unable to decrypt the environment variables because KMS access was denied. Check the
Lambda function's KMS permissions.

HTTP Status Code: 502


KMSDisabledException

Lambda was unable to decrypt the environment variables because the KMS key used is disabled.
Check the Lambda function's KMS key settings.

HTTP Status Code: 502


KMSInvalidStateException

Lambda was unable to decrypt the environment variables because the KMS key used is in an invalid
state for Decrypt. Check the function's KMS key settings.

HTTP Status Code: 502


KMSNotFoundException

Lambda was unable to decrypt the environment variables because the KMS key was not found.
Check the function's KMS key settings.

HTTP Status Code: 502


RequestTooLargeException

The request payload exceeded the Invoke request body JSON input limit. For more information, see
Limits.

HTTP Status Code: 413


ResourceNotFoundException

The resource (for example, a Lambda function or access policy statement) specied in the request
does not exist.

HTTP Status Code: 404


ServiceException

The AWS Lambda service encountered an internal error.

HTTP Status Code: 500

404
AWS Lambda Developer Guide
Invoke

SubnetIPAddressLimitReachedException

AWS Lambda was not able to set up VPC access for the Lambda function because one or more
congured subnets has no available IP addresses.

HTTP Status Code: 502


TooManyRequestsException

HTTP Status Code: 429


UnsupportedMediaTypeException

The content type of the Invoke request body is not JSON.

HTTP Status Code: 415

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS Command Line Interface


AWS SDK for .NET
AWS SDK for C++
AWS SDK for Go
AWS SDK for Java
AWS SDK for JavaScript
AWS SDK for PHP V3
AWS SDK for Python
AWS SDK for Ruby V2

405
AWS Lambda Developer Guide
InvokeAsync

InvokeAsync
Important
This API is deprecated. We recommend you use Invoke API (see Invoke (p. 401)).

Submits an invocation request to AWS Lambda. Upon receiving the request, Lambda executes the
specied function asynchronously. To see the logs generated by the Lambda function execution, see the
CloudWatch Logs console.

This operation requires permission for the lambda:InvokeFunction action.

Request Syntax
POST /2014-11-13/functions/FunctionName/invoke-async/ HTTP/1.1

InvokeArgs

URI Request Parameters


The request requires the following URI parameters.

FunctionName (p. 406)

The Lambda function name. Note that the length constraint applies only to the ARN. If you specify
only the function name, it is limited to 64 characters in length.

Length Constraints: Minimum length of 1. Maximum length of 170.

Pattern: (arn:aws:lambda:)?([a-z]{2}-[a-z]+-\d{1}:)?(\d{12}:)?(function:)?([a-zA-Z0-9-_
\.]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?

Request Body
The request accepts the following binary data.
<varlistentry> InvokeArgs (p. 406)

JSON that you want to provide to your Lambda function as input.


</varlistentry>

Response Syntax
HTTP/1.1 Status

Response Elements
If the action is successful, the service sends back the following HTTP response.

Status (p. 406)

It will be 202 upon success.

Errors
InvalidRequestContentException

The request body could not be parsed as JSON.

406
AWS Lambda Developer Guide
InvokeAsync

HTTP Status Code: 400


InvalidRuntimeException

The runtime or runtime version specied is not supported.

HTTP Status Code: 502


ResourceNotFoundException

The resource (for example, a Lambda function or access policy statement) specied in the request
does not exist.

HTTP Status Code: 404


ServiceException

The AWS Lambda service encountered an internal error.

HTTP Status Code: 500

Example
Invoke a Lambda function
The following example uses a POST request to invoke a Lambda function.

Sample Request

POST /2014-11-13/functions/helloworld/invoke-async/ HTTP/1.1


[input json]

Sample Response

HTTP/1.1 202 Accepted

x-amzn-requestid: f037bc5c-5a08-11e4-b02e-af446c3f9d0d
content-length: 0
connection: keep-alive
date: Wed, 22 Oct 2014 16:31:55 GMT
content-type: application/json

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS Command Line Interface


AWS SDK for .NET
AWS SDK for C++
AWS SDK for Go
AWS SDK for Java
AWS SDK for JavaScript
AWS SDK for PHP V3
AWS SDK for Python
AWS SDK for Ruby V2

407
AWS Lambda Developer Guide
ListAliases

ListAliases
Returns list of aliases created for a Lambda function. For each alias, the response includes information
such as the alias ARN, description, alias name, and the function version to which it points. For more
information, see Introduction to AWS Lambda Aliases.

This requires permission for the lambda:ListAliases action.

Request Syntax
GET /2015-03-31/functions/FunctionName/aliases?
FunctionVersion=FunctionVersion&Marker=Marker&MaxItems=MaxItems HTTP/1.1

URI Request Parameters


The request requires the following URI parameters.

FunctionName (p. 408)

Lambda function name for which the alias is created. Note that the length constraint applies only to
the ARN. If you specify only the function name, it is limited to 64 characters in length.

Length Constraints: Minimum length of 1. Maximum length of 140.

Pattern: (arn:aws:lambda:)?([a-z]{2}-[a-z]+-\d{1}:)?(\d{12}:)?(function:)?([a-zA-Z0-9-
_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
FunctionVersion (p. 408)

If you specify this optional parameter, the API returns only the aliases that are pointing to the
specic Lambda function version, otherwise the API returns all of the aliases created for the Lambda
function.

Length Constraints: Minimum length of 1. Maximum length of 1024.

Pattern: (\$LATEST|[0-9]+)
Marker (p. 408)

Optional string. An opaque pagination token returned from a previous ListAliases operation. If
present, indicates where to continue the listing.
MaxItems (p. 408)

Optional integer. Species the maximum number of aliases to return in response. This parameter
value must be greater than 0.

Valid Range: Minimum value of 1. Maximum value of 10000.

Request Body
The request does not have a request body.

Response Syntax
HTTP/1.1 200
Content-type: application/json

408
AWS Lambda Developer Guide
ListAliases

{
"Aliases": [
{
"AliasArn": "string",
"Description": "string",
"FunctionVersion": "string",
"Name": "string"
}
],
"NextMarker": "string"
}

Response Elements
If the action is successful, the service sends back an HTTP 200 response.

The following data is returned in JSON format by the service.

Aliases (p. 408)

A list of aliases.

Type: Array of AliasConguration (p. 456) objects


NextMarker (p. 408)

A string, present if there are more aliases.

Type: String

Errors
InvalidParameterValueException

One of the parameters in the request is invalid. For example, if you provided an IAM role for AWS
Lambda to assume in the CreateFunction or the UpdateFunctionConfiguration API, that AWS
Lambda is unable to assume you will get this exception. You will also get this exception if you have
selected a deprecated runtime, such as Node v0.10.42.

HTTP Status Code: 400


ResourceNotFoundException

The resource (for example, a Lambda function or access policy statement) specied in the request
does not exist.

HTTP Status Code: 404


ServiceException

The AWS Lambda service encountered an internal error.

HTTP Status Code: 500


TooManyRequestsException

HTTP Status Code: 429

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

409
AWS Lambda Developer Guide
ListAliases

AWS Command Line Interface


AWS SDK for .NET
AWS SDK for C++
AWS SDK for Go
AWS SDK for Java
AWS SDK for JavaScript
AWS SDK for PHP V3
AWS SDK for Python
AWS SDK for Ruby V2

410
AWS Lambda Developer Guide
ListEventSourceMappings

ListEventSourceMappings
Returns a list of event source mappings you created using the CreateEventSourceMapping (see
CreateEventSourceMapping (p. 361)).

For each mapping, the API returns conguration information. You can optionally specify lters to retrieve
specic event source mappings.

If you are using the versioning feature, you can get list of event source mappings for a specic Lambda
function version or an alias as described in the FunctionName parameter. For information about the
versioning feature, see AWS Lambda Function Versioning and Aliases.

This operation requires permission for the lambda:ListEventSourceMappings action.

Request Syntax
GET /2015-03-31/event-source-mappings/?
EventSourceArn=EventSourceArn&FunctionName=FunctionName&Marker=Marker&MaxItems=MaxItems
HTTP/1.1

URI Request Parameters


The request requires the following URI parameters.

EventSourceArn (p. 411)

The Amazon Resource Name (ARN) of the Amazon Kinesis stream. (This parameter is optional.)

Pattern: arn:aws:([a-zA-Z0-9\-])+:([a-z]{2}-[a-z]+-\d{1})?:(\d{12})?:(.*)
FunctionName (p. 411)

The name of the Lambda function.

You can specify the function name (for example, Thumbnail) or you can specify Amazon
Resource Name (ARN) of the function (for example, arn:aws:lambda:us-west-2:account-
id:function:ThumbNail). If you are using versioning, you can also provide a qualied function ARN
(ARN that is qualied with function version or alias name as sux). AWS Lambda also allows you to
specify only the function name with the account ID qualier (for example, account-id:Thumbnail).
Note that the length constraint applies only to the ARN. If you specify only the function name, it is
limited to 64 characters in length.

Length Constraints: Minimum length of 1. Maximum length of 140.

Pattern: (arn:aws:lambda:)?([a-z]{2}-[a-z]+-\d{1}:)?(\d{12}:)?(function:)?([a-zA-Z0-9-
_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Marker (p. 411)

Optional string. An opaque pagination token returned from a previous ListEventSourceMappings


operation. If present, species to continue the list from where the returning call left o.
MaxItems (p. 411)

Optional integer. Species the maximum number of event sources to return in response. This value
must be greater than 0.

Valid Range: Minimum value of 1. Maximum value of 10000.

411
AWS Lambda Developer Guide
ListEventSourceMappings

Request Body
The request does not have a request body.

Response Syntax
HTTP/1.1 200
Content-type: application/json

{
"EventSourceMappings": [
{
"BatchSize": number,
"EventSourceArn": "string",
"FunctionArn": "string",
"LastModified": number,
"LastProcessingResult": "string",
"State": "string",
"StateTransitionReason": "string",
"UUID": "string"
}
],
"NextMarker": "string"
}

Response Elements
If the action is successful, the service sends back an HTTP 200 response.

The following data is returned in JSON format by the service.

EventSourceMappings (p. 412)

An array of EventSourceMappingConfiguration objects.

Type: Array of EventSourceMappingConguration (p. 462) objects


NextMarker (p. 412)

A string, present if there are more event source mappings.

Type: String

Errors
InvalidParameterValueException

One of the parameters in the request is invalid. For example, if you provided an IAM role for AWS
Lambda to assume in the CreateFunction or the UpdateFunctionConfiguration API, that AWS
Lambda is unable to assume you will get this exception. You will also get this exception if you have
selected a deprecated runtime, such as Node v0.10.42.

HTTP Status Code: 400


ResourceNotFoundException

The resource (for example, a Lambda function or access policy statement) specied in the request
does not exist.

HTTP Status Code: 404

412
AWS Lambda Developer Guide
ListEventSourceMappings

ServiceException

The AWS Lambda service encountered an internal error.

HTTP Status Code: 500


TooManyRequestsException

HTTP Status Code: 429

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS Command Line Interface


AWS SDK for .NET
AWS SDK for C++
AWS SDK for Go
AWS SDK for Java
AWS SDK for JavaScript
AWS SDK for PHP V3
AWS SDK for Python
AWS SDK for Ruby V2

413
AWS Lambda Developer Guide
ListFunctions

ListFunctions
Returns a list of your Lambda functions. For each function, the response includes the function
conguration information. You must use GetFunction (p. 390) to retrieve the code for your function.

This operation requires permission for the lambda:ListFunctions action.

If you are using the versioning feature, you can list all of your functions or only $LATEST versions. For
information about the versioning feature, see AWS Lambda Function Versioning and Aliases.

Request Syntax
GET /2015-03-31/functions/?
FunctionVersion=FunctionVersion&Marker=Marker&MasterRegion=MasterRegion&MaxItems=MaxItems
HTTP/1.1

URI Request Parameters


The request requires the following URI parameters.

FunctionVersion (p. 414)

Optional string. If not specied, only the unqualied functions ARNs (Amazon Resource Names) will
be returned.

Valid value:

ALL: Will return all versions, including $LATEST which will have fully qualied ARNs (Amazon
Resource Names).

Valid Values: ALL


Marker (p. 414)

Optional string. An opaque pagination token returned from a previous ListFunctions operation. If
present, indicates where to continue the listing.
MasterRegion (p. 414)

Optional string. If not specied, will return only regular function versions (i.e., non-replicated
versions).

Valid values are:

The region from which the functions are replicated. For example, if you specify us-east-1, only
functions replicated from that region will be returned.

ALL: Will return all functions from any region. If specied, you also must specify a valid
FunctionVersion parameter.

Pattern: ALL|[a-z]{2}(-gov)?-[a-z]+-\d{1}
MaxItems (p. 414)

Optional integer. Species the maximum number of AWS Lambda functions to return in response.
This parameter value must be greater than 0.

Valid Range: Minimum value of 1. Maximum value of 10000.

414
AWS Lambda Developer Guide
ListFunctions

Request Body
The request does not have a request body.

Response Syntax
HTTP/1.1 200
Content-type: application/json

{
"Functions": [
{
"CodeSha256": "string",
"CodeSize": number,
"DeadLetterConfig": {
"TargetArn": "string"
},
"Description": "string",
"Environment": {
"Error": {
"ErrorCode": "string",
"Message": "string"
},
"Variables": {
"string" : "string"
}
},
"FunctionArn": "string",
"FunctionName": "string",
"Handler": "string",
"KMSKeyArn": "string",
"LastModified": "string",
"MasterArn": "string",
"MemorySize": number,
"Role": "string",
"Runtime": "string",
"Timeout": number,
"TracingConfig": {
"Mode": "string"
},
"Version": "string",
"VpcConfig": {
"SecurityGroupIds": [ "string" ],
"SubnetIds": [ "string" ],
"VpcId": "string"
}
}
],
"NextMarker": "string"
}

Response Elements
If the action is successful, the service sends back an HTTP 200 response.

The following data is returned in JSON format by the service.

Functions (p. 415)

A list of Lambda functions.

Type: Array of FunctionConguration (p. 466) objects

415
AWS Lambda Developer Guide
ListFunctions

NextMarker (p. 415)

A string, present if there are more functions.

Type: String

Errors
InvalidParameterValueException

One of the parameters in the request is invalid. For example, if you provided an IAM role for AWS
Lambda to assume in the CreateFunction or the UpdateFunctionConfiguration API, that AWS
Lambda is unable to assume you will get this exception. You will also get this exception if you have
selected a deprecated runtime, such as Node v0.10.42.

HTTP Status Code: 400


ServiceException

The AWS Lambda service encountered an internal error.

HTTP Status Code: 500


TooManyRequestsException

HTTP Status Code: 429

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS Command Line Interface


AWS SDK for .NET
AWS SDK for C++
AWS SDK for Go
AWS SDK for Java
AWS SDK for JavaScript
AWS SDK for PHP V3
AWS SDK for Python
AWS SDK for Ruby V2

416
AWS Lambda Developer Guide
ListTags

ListTags
Returns a list of tags assigned to a function when supplied the function ARN (Amazon Resource Name).

Request Syntax
GET /2017-03-31/tags/ARN HTTP/1.1

URI Request Parameters


The request requires the following URI parameters.

Resource (p. 417)

The ARN (Amazon Resource Name) of the function.

Pattern: arn:aws:lambda:[a-z]{2}-[a-z]+-\d{1}:\d{12}:function:[a-zA-Z0-9-_]+(:(\$LATEST|
[a-zA-Z0-9-_]+))?

Request Body
The request does not have a request body.

Response Syntax
HTTP/1.1 200
Content-type: application/json

{
"Tags": {
"string" : "string"
}
}

Response Elements
If the action is successful, the service sends back an HTTP 200 response.

The following data is returned in JSON format by the service.

Tags (p. 417)

The list of tags assigned to the function.

Type: String to string map

Errors
InvalidParameterValueException

One of the parameters in the request is invalid. For example, if you provided an IAM role for AWS
Lambda to assume in the CreateFunction or the UpdateFunctionConfiguration API, that AWS
Lambda is unable to assume you will get this exception. You will also get this exception if you have
selected a deprecated runtime, such as Node v0.10.42.

417
AWS Lambda Developer Guide
ListTags

HTTP Status Code: 400


ResourceNotFoundException

The resource (for example, a Lambda function or access policy statement) specied in the request
does not exist.

HTTP Status Code: 404


ServiceException

The AWS Lambda service encountered an internal error.

HTTP Status Code: 500


TooManyRequestsException

HTTP Status Code: 429

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS Command Line Interface


AWS SDK for .NET
AWS SDK for C++
AWS SDK for Go
AWS SDK for Java
AWS SDK for JavaScript
AWS SDK for PHP V3
AWS SDK for Python
AWS SDK for Ruby V2

418
AWS Lambda Developer Guide
ListVersionsByFunction

ListVersionsByFunction
List all versions of a function. For information about the versioning feature, see AWS Lambda Function
Versioning and Aliases.

Request Syntax
GET /2015-03-31/functions/FunctionName/versions?Marker=Marker&MaxItems=MaxItems HTTP/1.1

URI Request Parameters


The request requires the following URI parameters.

FunctionName (p. 419)

Function name whose versions to list. You can specify a function name (for example, Thumbnail) or
you can specify Amazon Resource Name (ARN) of the function (for example, arn:aws:lambda:us-
west-2:account-id:function:ThumbNail). AWS Lambda also allows you to specify a partial ARN (for
example, account-id:Thumbnail). Note that the length constraint applies only to the ARN. If you
specify only the function name, it is limited to 64 characters in length.

Length Constraints: Minimum length of 1. Maximum length of 170.

Pattern: (arn:aws:lambda:)?([a-z]{2}-[a-z]+-\d{1}:)?(\d{12}:)?(function:)?([a-zA-Z0-9-_
\.]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Marker (p. 419)

Optional string. An opaque pagination token returned from a previous ListVersionsByFunction


operation. If present, indicates where to continue the listing.
MaxItems (p. 419)

Optional integer. Species the maximum number of AWS Lambda function versions to return in
response. This parameter value must be greater than 0.

Valid Range: Minimum value of 1. Maximum value of 10000.

Request Body
The request does not have a request body.

Response Syntax
HTTP/1.1 200
Content-type: application/json

{
"NextMarker": "string",
"Versions": [
{
"CodeSha256": "string",
"CodeSize": number,
"DeadLetterConfig": {
"TargetArn": "string"
},

419
AWS Lambda Developer Guide
ListVersionsByFunction

"Description": "string",
"Environment": {
"Error": {
"ErrorCode": "string",
"Message": "string"
},
"Variables": {
"string" : "string"
}
},
"FunctionArn": "string",
"FunctionName": "string",
"Handler": "string",
"KMSKeyArn": "string",
"LastModified": "string",
"MasterArn": "string",
"MemorySize": number,
"Role": "string",
"Runtime": "string",
"Timeout": number,
"TracingConfig": {
"Mode": "string"
},
"Version": "string",
"VpcConfig": {
"SecurityGroupIds": [ "string" ],
"SubnetIds": [ "string" ],
"VpcId": "string"
}
}
]
}

Response Elements
If the action is successful, the service sends back an HTTP 200 response.

The following data is returned in JSON format by the service.

NextMarker (p. 419)

A string, present if there are more function versions.

Type: String
Versions (p. 419)

A list of Lambda function versions.

Type: Array of FunctionConguration (p. 466) objects

Errors
InvalidParameterValueException

One of the parameters in the request is invalid. For example, if you provided an IAM role for AWS
Lambda to assume in the CreateFunction or the UpdateFunctionConfiguration API, that AWS
Lambda is unable to assume you will get this exception. You will also get this exception if you have
selected a deprecated runtime, such as Node v0.10.42.

HTTP Status Code: 400

420
AWS Lambda Developer Guide
ListVersionsByFunction

ResourceNotFoundException

The resource (for example, a Lambda function or access policy statement) specied in the request
does not exist.

HTTP Status Code: 404


ServiceException

The AWS Lambda service encountered an internal error.

HTTP Status Code: 500


TooManyRequestsException

HTTP Status Code: 429

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS Command Line Interface


AWS SDK for .NET
AWS SDK for C++
AWS SDK for Go
AWS SDK for Java
AWS SDK for JavaScript
AWS SDK for PHP V3
AWS SDK for Python
AWS SDK for Ruby V2

421
AWS Lambda Developer Guide
PublishVersion

PublishVersion
Publishes a version of your function from the current snapshot of $LATEST. That is, AWS Lambda takes a
snapshot of the function code and conguration information from $LATEST and publishes a new version.
The code and conguration cannot be modied after publication. For information about the versioning
feature, see AWS Lambda Function Versioning and Aliases.

Request Syntax
POST /2015-03-31/functions/FunctionName/versions HTTP/1.1
Content-type: application/json

{
"CodeSha256": "string",
"Description": "string"
}

URI Request Parameters


The request requires the following URI parameters.

FunctionName (p. 422)

The Lambda function name. You can specify a function name (for example, Thumbnail) or you
can specify Amazon Resource Name (ARN) of the function (for example, arn:aws:lambda:us-
west-2:account-id:function:ThumbNail). AWS Lambda also allows you to specify a partial ARN (for
example, account-id:Thumbnail). Note that the length constraint applies only to the ARN. If you
specify only the function name, it is limited to 64 characters in length.

Length Constraints: Minimum length of 1. Maximum length of 140.

Pattern: (arn:aws:lambda:)?([a-z]{2}-[a-z]+-\d{1}:)?(\d{12}:)?(function:)?([a-zA-Z0-9-
_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?

Request Body
The request accepts the following data in JSON format.

CodeSha256 (p. 422)

The SHA256 hash of the deployment package you want to publish. This provides validation on
the code you are publishing. If you provide this parameter, the value must match the SHA256
of the $LATEST version for the publication to succeed. You can use the DryRun parameter of
UpdateFunctionCode (p. 440) to verify the hash value that will be returned before publishing your
new version.

Type: String

Required: No
Description (p. 422)

The description for the version you are publishing. If not provided, AWS Lambda copies the
description from the $LATEST version.

Type: String

Length Constraints: Minimum length of 0. Maximum length of 256.

422
AWS Lambda Developer Guide
PublishVersion

Required: No

Response Syntax
HTTP/1.1 201
Content-type: application/json

{
"CodeSha256": "string",
"CodeSize": number,
"DeadLetterConfig": {
"TargetArn": "string"
},
"Description": "string",
"Environment": {
"Error": {
"ErrorCode": "string",
"Message": "string"
},
"Variables": {
"string" : "string"
}
},
"FunctionArn": "string",
"FunctionName": "string",
"Handler": "string",
"KMSKeyArn": "string",
"LastModified": "string",
"MasterArn": "string",
"MemorySize": number,
"Role": "string",
"Runtime": "string",
"Timeout": number,
"TracingConfig": {
"Mode": "string"
},
"Version": "string",
"VpcConfig": {
"SecurityGroupIds": [ "string" ],
"SubnetIds": [ "string" ],
"VpcId": "string"
}
}

Response Elements
If the action is successful, the service sends back an HTTP 201 response.

The following data is returned in JSON format by the service.

CodeSha256 (p. 423)

It is the SHA256 hash of your function deployment package.

Type: String
CodeSize (p. 423)

The size, in bytes, of the function .zip le you uploaded.

Type: Long

423
AWS Lambda Developer Guide
PublishVersion

DeadLetterCong (p. 423)

The parent object that contains the target ARN (Amazon Resource Name) of an Amazon SQS queue
or Amazon SNS topic.

Type: DeadLetterCong (p. 458) object


Description (p. 423)

The user-provided description.

Type: String

Length Constraints: Minimum length of 0. Maximum length of 256.


Environment (p. 423)

The parent object that contains your environment's conguration settings.

Type: EnvironmentResponse (p. 461) object


FunctionArn (p. 423)

The Amazon Resource Name (ARN) assigned to the function.

Type: String

Pattern: arn:aws:lambda:[a-z]{2}-[a-z]+-\d{1}:\d{12}:function:[a-zA-Z0-9-_\.]+(:(\
$LATEST|[a-zA-Z0-9-_]+))?
FunctionName (p. 423)

The name of the function. Note that the length constraint applies only to the ARN. If you specify
only the function name, it is limited to 64 characters in length.

Type: String

Length Constraints: Minimum length of 1. Maximum length of 170.

Pattern: (arn:aws:lambda:)?([a-z]{2}-[a-z]+-\d{1}:)?(\d{12}:)?(function:)?([a-zA-Z0-9-_
\.]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Handler (p. 423)

The function Lambda calls to begin executing your function.

Type: String

Length Constraints: Maximum length of 128.

Pattern: [^\s]+
KMSKeyArn (p. 423)

The Amazon Resource Name (ARN) of the KMS key used to encrypt your function's environment
variables. If empty, it means you are using the AWS Lambda default service key.

Type: String

Pattern: (arn:aws:[a-z0-9-.]+:.*)|()
LastModied (p. 423)

The time stamp of the last time you updated the function. The time stamp is conveyed
as a string complying with ISO-8601 in this way YYYY-MM-DDThh:mm:ssTZD (e.g.,
1997-07-16T19:20:30+01:00). For more information, see Date and Time Formats.

424
AWS Lambda Developer Guide
PublishVersion

Type: String
MasterArn (p. 423)

Returns the ARN (Amazon Resource Name) of the master function.

Type: String

Pattern: arn:aws:lambda:[a-z]{2}-[a-z]+-\d{1}:\d{12}:function:[a-zA-Z0-9-_]+(:(\$LATEST|
[a-zA-Z0-9-_]+))?
MemorySize (p. 423)

The memory size, in MB, you congured for the function. Must be a multiple of 64 MB.

Type: Integer

Valid Range: Minimum value of 128. Maximum value of 1536.


Role (p. 423)

The Amazon Resource Name (ARN) of the IAM role that Lambda assumes when it executes your
function to access any other Amazon Web Services (AWS) resources.

Type: String

Pattern: arn:aws:iam::\d{12}:role/?[a-zA-Z_0-9+=,.@\-_/]+
Runtime (p. 423)

The runtime environment for the Lambda function.

Type: String

Valid Values: nodejs | nodejs4.3 | nodejs6.10 | java8 | python2.7 | python3.6 |


dotnetcore1.0 | nodejs4.3-edge
Timeout (p. 423)

The function execution time at which Lambda should terminate the function. Because the execution
time has cost implications, we recommend you set this value based on your expected execution time.
The default is 3 seconds.

Type: Integer

Valid Range: Minimum value of 1.


TracingCong (p. 423)

The parent object that contains your function's tracing settings.

Type: TracingCongResponse (p. 471) object


Version (p. 423)

The version of the Lambda function.

Type: String

Length Constraints: Minimum length of 1. Maximum length of 1024.

Pattern: (\$LATEST|[0-9]+)
VpcCong (p. 423)

VPC conguration associated with your Lambda function.

Type: VpcCongResponse (p. 473) object

425
AWS Lambda Developer Guide
PublishVersion

Errors
CodeStorageExceededException

You have exceeded your maximum total code size per account. Limits

HTTP Status Code: 400


InvalidParameterValueException

One of the parameters in the request is invalid. For example, if you provided an IAM role for AWS
Lambda to assume in the CreateFunction or the UpdateFunctionConfiguration API, that AWS
Lambda is unable to assume you will get this exception. You will also get this exception if you have
selected a deprecated runtime, such as Node v0.10.42.

HTTP Status Code: 400


ResourceNotFoundException

The resource (for example, a Lambda function or access policy statement) specied in the request
does not exist.

HTTP Status Code: 404


ServiceException

The AWS Lambda service encountered an internal error.

HTTP Status Code: 500


TooManyRequestsException

HTTP Status Code: 429

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS Command Line Interface


AWS SDK for .NET
AWS SDK for C++
AWS SDK for Go
AWS SDK for Java
AWS SDK for JavaScript
AWS SDK for PHP V3
AWS SDK for Python
AWS SDK for Ruby V2

426
AWS Lambda Developer Guide
RemovePermission

RemovePermission
You can remove individual permissions from an resource policy associated with a Lambda function by
providing a statement ID that you provided when you added the permission.

If you are using versioning, the permissions you remove are specic to the Lambda function version or
alias you specify in the AddPermission request via the Qualifier parameter. For more information about
versioning, see AWS Lambda Function Versioning and Aliases.

Note that removal of a permission will cause an active event source to lose permission to the function.

You need permission for the lambda:RemovePermission action.

Request Syntax
DELETE /2015-03-31/functions/FunctionName/policy/StatementId?Qualifier=Qualifier HTTP/1.1

URI Request Parameters


The request requires the following URI parameters.

FunctionName (p. 427)

Lambda function whose resource policy you want to remove a permission from.

You can specify a function name (for example, Thumbnail) or you can specify Amazon
Resource Name (ARN) of the function (for example, arn:aws:lambda:us-west-2:account-
id:function:ThumbNail). AWS Lambda also allows you to specify a partial ARN (for example,
account-id:Thumbnail). Note that the length constraint applies only to the ARN. If you specify only
the function name, it is limited to 64 characters in length.

Length Constraints: Minimum length of 1. Maximum length of 140.

Pattern: (arn:aws:lambda:)?([a-z]{2}-[a-z]+-\d{1}:)?(\d{12}:)?(function:)?([a-zA-Z0-9-
_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Qualier (p. 427)

You can specify this optional parameter to remove permission associated with a specic function
version or function alias. If you don't specify this parameter, the API removes permission associated
with the unqualied function ARN.

Length Constraints: Minimum length of 1. Maximum length of 128.

Pattern: (|[a-zA-Z0-9$_-]+)
StatementId (p. 427)

Statement ID of the permission to remove.

Length Constraints: Minimum length of 1. Maximum length of 100.

Pattern: ([a-zA-Z0-9-_.]+)

Request Body
The request does not have a request body.

427
AWS Lambda Developer Guide
RemovePermission

Response Syntax
HTTP/1.1 204

Response Elements
If the action is successful, the service sends back an HTTP 204 response with an empty HTTP body.

Errors
InvalidParameterValueException

One of the parameters in the request is invalid. For example, if you provided an IAM role for AWS
Lambda to assume in the CreateFunction or the UpdateFunctionConfiguration API, that AWS
Lambda is unable to assume you will get this exception. You will also get this exception if you have
selected a deprecated runtime, such as Node v0.10.42.

HTTP Status Code: 400


ResourceNotFoundException

The resource (for example, a Lambda function or access policy statement) specied in the request
does not exist.

HTTP Status Code: 404


ServiceException

The AWS Lambda service encountered an internal error.

HTTP Status Code: 500


TooManyRequestsException

HTTP Status Code: 429

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS Command Line Interface


AWS SDK for .NET
AWS SDK for C++
AWS SDK for Go
AWS SDK for Java
AWS SDK for JavaScript
AWS SDK for PHP V3
AWS SDK for Python
AWS SDK for Ruby V2

428
AWS Lambda Developer Guide
TagResource

TagResource
Creates a list of tags (key-value pairs) on the Lambda function. Requires the Lambda function ARN
(Amazon Resource Name). If a key is specied without a value, Lambda creates a tag with the specied
key and a value of null.

Request Syntax
POST /2017-03-31/tags/ARN HTTP/1.1
Content-type: application/json

{
"Tags": {
"string" : "string"
}
}

URI Request Parameters


The request requires the following URI parameters.

Resource (p. 429)

The ARN (Amazon Resource Name) of the Lambda function.

Pattern: arn:aws:lambda:[a-z]{2}-[a-z]+-\d{1}:\d{12}:function:[a-zA-Z0-9-_]+(:(\$LATEST|
[a-zA-Z0-9-_]+))?

Request Body
The request accepts the following data in JSON format.

Tags (p. 429)

The list of tags (key-value pairs) you are assigning to the Lambda function.

Type: String to string map

Required: Yes

Response Syntax
HTTP/1.1 204

Response Elements
If the action is successful, the service sends back an HTTP 204 response with an empty HTTP body.

Errors
InvalidParameterValueException

One of the parameters in the request is invalid. For example, if you provided an IAM role for AWS
Lambda to assume in the CreateFunction or the UpdateFunctionConfiguration API, that AWS

429
AWS Lambda Developer Guide
TagResource

Lambda is unable to assume you will get this exception. You will also get this exception if you have
selected a deprecated runtime, such as Node v0.10.42.

HTTP Status Code: 400


ResourceNotFoundException

The resource (for example, a Lambda function or access policy statement) specied in the request
does not exist.

HTTP Status Code: 404


ServiceException

The AWS Lambda service encountered an internal error.

HTTP Status Code: 500


TooManyRequestsException

HTTP Status Code: 429

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS Command Line Interface


AWS SDK for .NET
AWS SDK for C++
AWS SDK for Go
AWS SDK for Java
AWS SDK for JavaScript
AWS SDK for PHP V3
AWS SDK for Python
AWS SDK for Ruby V2

430
AWS Lambda Developer Guide
UntagResource

UntagResource
Removes tags from a Lambda function. Requires the function ARN (Amazon Resource Name).

Request Syntax
DELETE /2017-03-31/tags/ARN?tagKeys=TagKeys HTTP/1.1

URI Request Parameters


The request requires the following URI parameters.

Resource (p. 431)

The ARN (Amazon Resource Name) of the function.

Pattern: arn:aws:lambda:[a-z]{2}-[a-z]+-\d{1}:\d{12}:function:[a-zA-Z0-9-_]+(:(\$LATEST|
[a-zA-Z0-9-_]+))?
TagKeys (p. 431)

The list of tag keys to be deleted from the function.

Request Body
The request does not have a request body.

Response Syntax
HTTP/1.1 204

Response Elements
If the action is successful, the service sends back an HTTP 204 response with an empty HTTP body.

Errors
InvalidParameterValueException

One of the parameters in the request is invalid. For example, if you provided an IAM role for AWS
Lambda to assume in the CreateFunction or the UpdateFunctionConfiguration API, that AWS
Lambda is unable to assume you will get this exception. You will also get this exception if you have
selected a deprecated runtime, such as Node v0.10.42.

HTTP Status Code: 400


ResourceNotFoundException

The resource (for example, a Lambda function or access policy statement) specied in the request
does not exist.

HTTP Status Code: 404


ServiceException

The AWS Lambda service encountered an internal error.

431
AWS Lambda Developer Guide
UntagResource

HTTP Status Code: 500


TooManyRequestsException

HTTP Status Code: 429

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS Command Line Interface


AWS SDK for .NET
AWS SDK for C++
AWS SDK for Go
AWS SDK for Java
AWS SDK for JavaScript
AWS SDK for PHP V3
AWS SDK for Python
AWS SDK for Ruby V2

432
AWS Lambda Developer Guide
UpdateAlias

UpdateAlias
Using this API you can update the function version to which the alias points and the alias description. For
more information, see Introduction to AWS Lambda Aliases.

This requires permission for the lambda:UpdateAlias action.

Request Syntax
PUT /2015-03-31/functions/FunctionName/aliases/Name HTTP/1.1
Content-type: application/json

{
"Description": "string",
"FunctionVersion": "string"
}

URI Request Parameters


The request requires the following URI parameters.

FunctionName (p. 433)

The function name for which the alias is created. Note that the length constraint applies only to the
ARN. If you specify only the function name, it is limited to 64 characters in length.

Length Constraints: Minimum length of 1. Maximum length of 140.

Pattern: (arn:aws:lambda:)?([a-z]{2}-[a-z]+-\d{1}:)?(\d{12}:)?(function:)?([a-zA-Z0-9-
_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Name (p. 433)

The alias name.

Length Constraints: Minimum length of 1. Maximum length of 128.

Pattern: (?!^[0-9]+$)([a-zA-Z0-9-_]+)

Request Body
The request accepts the following data in JSON format.

Description (p. 433)

You can change the description of the alias using this parameter.

Type: String

Length Constraints: Minimum length of 0. Maximum length of 256.

Required: No
FunctionVersion (p. 433)

Using this parameter you can change the Lambda function version to which the alias points.

Type: String

433
AWS Lambda Developer Guide
UpdateAlias

Length Constraints: Minimum length of 1. Maximum length of 1024.

Pattern: (\$LATEST|[0-9]+)

Required: No

Response Syntax
HTTP/1.1 200
Content-type: application/json

{
"AliasArn": "string",
"Description": "string",
"FunctionVersion": "string",
"Name": "string"
}

Response Elements
If the action is successful, the service sends back an HTTP 200 response.

The following data is returned in JSON format by the service.

AliasArn (p. 434)

Lambda function ARN that is qualied using the alias name as the sux. For example, if you create
an alias called BETA that points to a helloworld function version, the ARN is arn:aws:lambda:aws-
regions:acct-id:function:helloworld:BETA.

Type: String

Pattern: arn:aws:lambda:[a-z]{2}-[a-z]+-\d{1}:\d{12}:function:[a-zA-Z0-9-_]+(:(\$LATEST|
[a-zA-Z0-9-_]+))?
Description (p. 434)

Alias description.

Type: String

Length Constraints: Minimum length of 0. Maximum length of 256.


FunctionVersion (p. 434)

Function version to which the alias points.

Type: String

Length Constraints: Minimum length of 1. Maximum length of 1024.

Pattern: (\$LATEST|[0-9]+)
Name (p. 434)

Alias name.

Type: String

Length Constraints: Minimum length of 1. Maximum length of 128.

Pattern: (?!^[0-9]+$)([a-zA-Z0-9-_]+)

434
AWS Lambda Developer Guide
UpdateAlias

Errors
InvalidParameterValueException

One of the parameters in the request is invalid. For example, if you provided an IAM role for AWS
Lambda to assume in the CreateFunction or the UpdateFunctionConfiguration API, that AWS
Lambda is unable to assume you will get this exception. You will also get this exception if you have
selected a deprecated runtime, such as Node v0.10.42.

HTTP Status Code: 400


ResourceNotFoundException

The resource (for example, a Lambda function or access policy statement) specied in the request
does not exist.

HTTP Status Code: 404


ServiceException

The AWS Lambda service encountered an internal error.

HTTP Status Code: 500


TooManyRequestsException

HTTP Status Code: 429

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS Command Line Interface


AWS SDK for .NET
AWS SDK for C++
AWS SDK for Go
AWS SDK for Java
AWS SDK for JavaScript
AWS SDK for PHP V3
AWS SDK for Python
AWS SDK for Ruby V2

435
AWS Lambda Developer Guide
UpdateEventSourceMapping

UpdateEventSourceMapping
You can update an event source mapping. This is useful if you want to change the parameters of the
existing mapping without losing your position in the stream. You can change which function will receive
the stream records, but to change the stream itself, you must create a new mapping.

If you are using the versioning feature, you can update the event source mapping to map to a specic
Lambda function version or alias as described in the FunctionName parameter. For information about the
versioning feature, see AWS Lambda Function Versioning and Aliases.

If you disable the event source mapping, AWS Lambda stops polling. If you enable again, it will resume
polling from the time it had stopped polling, so you don't lose processing of any records. However, if you
delete event source mapping and create it again, it will reset.

This operation requires permission for the lambda:UpdateEventSourceMapping action.

Request Syntax
PUT /2015-03-31/event-source-mappings/UUID HTTP/1.1
Content-type: application/json

{
"BatchSize": number,
"Enabled": boolean,
"FunctionName": "string"
}

URI Request Parameters


The request requires the following URI parameters.

UUID (p. 436)

The event source mapping identier.

Request Body
The request accepts the following data in JSON format.

BatchSize (p. 436)

The maximum number of stream records that can be sent to your Lambda function for a single
invocation.

Type: Integer

Valid Range: Minimum value of 1. Maximum value of 10000.

Required: No
Enabled (p. 436)

Species whether AWS Lambda should actively poll the stream or not. If disabled, AWS Lambda will
not poll the stream.

Type: Boolean

Required: No

436
AWS Lambda Developer Guide
UpdateEventSourceMapping

FunctionName (p. 436)

The Lambda function to which you want the stream records sent.

You can specify a function name (for example, Thumbnail) or you can specify Amazon
Resource Name (ARN) of the function (for example, arn:aws:lambda:us-west-2:account-
id:function:ThumbNail). AWS Lambda also allows you to specify a partial ARN (for example,
account-id:Thumbnail). Note that the length constraint applies only to the ARN. If you specify only
the function name, it is limited to 64 characters in length.

If you are using versioning, you can also provide a qualied function ARN (ARN that is qualied with
function version or alias name as sux). For more information about versioning, see AWS Lambda
Function Versioning and Aliases

Note that the length constraint applies only to the ARN. If you specify only the function name, it is
limited to 64 character in length.

Type: String

Length Constraints: Minimum length of 1. Maximum length of 140.

Pattern: (arn:aws:lambda:)?([a-z]{2}-[a-z]+-\d{1}:)?(\d{12}:)?(function:)?([a-zA-Z0-9-
_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?

Required: No

Response Syntax
HTTP/1.1 202
Content-type: application/json

{
"BatchSize": number,
"EventSourceArn": "string",
"FunctionArn": "string",
"LastModified": number,
"LastProcessingResult": "string",
"State": "string",
"StateTransitionReason": "string",
"UUID": "string"
}

Response Elements
If the action is successful, the service sends back an HTTP 202 response.

The following data is returned in JSON format by the service.

BatchSize (p. 437)

The largest number of records that AWS Lambda will retrieve from your event source at the time of
invoking your function. Your function receives an event with all the retrieved records.

Type: Integer

Valid Range: Minimum value of 1. Maximum value of 10000.


EventSourceArn (p. 437)

The Amazon Resource Name (ARN) of the Amazon Kinesis stream that is the source of events.

437
AWS Lambda Developer Guide
UpdateEventSourceMapping

Type: String

Pattern: arn:aws:([a-zA-Z0-9\-])+:([a-z]{2}-[a-z]+-\d{1})?:(\d{12})?:(.*)
FunctionArn (p. 437)

The Lambda function to invoke when AWS Lambda detects an event on the stream.

Type: String

Pattern: arn:aws:lambda:[a-z]{2}-[a-z]+-\d{1}:\d{12}:function:[a-zA-Z0-9-_]+(:(\$LATEST|
[a-zA-Z0-9-_]+))?
LastModied (p. 437)

The UTC time string indicating the last time the event mapping was updated.

Type: Timestamp
LastProcessingResult (p. 437)

The result of the last AWS Lambda invocation of your Lambda function.

Type: String
State (p. 437)

The state of the event source mapping. It can be Creating, Enabled, Disabled, Enabling, Disabling,
Updating, or Deleting.

Type: String
StateTransitionReason (p. 437)

The reason the event source mapping is in its current state. It is either user-requested or an AWS
Lambda-initiated state transition.

Type: String
UUID (p. 437)

The AWS Lambda assigned opaque identier for the mapping.

Type: String

Errors
InvalidParameterValueException

One of the parameters in the request is invalid. For example, if you provided an IAM role for AWS
Lambda to assume in the CreateFunction or the UpdateFunctionConfiguration API, that AWS
Lambda is unable to assume you will get this exception. You will also get this exception if you have
selected a deprecated runtime, such as Node v0.10.42.

HTTP Status Code: 400


ResourceConictException

The resource already exists.

HTTP Status Code: 409


ResourceNotFoundException

The resource (for example, a Lambda function or access policy statement) specied in the request
does not exist.

438
AWS Lambda Developer Guide
UpdateEventSourceMapping

HTTP Status Code: 404


ServiceException

The AWS Lambda service encountered an internal error.

HTTP Status Code: 500


TooManyRequestsException

HTTP Status Code: 429

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS Command Line Interface


AWS SDK for .NET
AWS SDK for C++
AWS SDK for Go
AWS SDK for Java
AWS SDK for JavaScript
AWS SDK for PHP V3
AWS SDK for Python
AWS SDK for Ruby V2

439
AWS Lambda Developer Guide
UpdateFunctionCode

UpdateFunctionCode
Updates the code for the specied Lambda function. This operation must only be used on an existing
Lambda function and cannot be used to update the function conguration.

If you are using the versioning feature, note this API will always update the $LATEST version of your
Lambda function. For information about the versioning feature, see AWS Lambda Function Versioning
and Aliases.

This operation requires permission for the lambda:UpdateFunctionCode action.

Request Syntax
PUT /2015-03-31/functions/FunctionName/code HTTP/1.1
Content-type: application/json

{
"DryRun": boolean,
"Publish": boolean,
"S3Bucket": "string",
"S3Key": "string",
"S3ObjectVersion": "string",
"ZipFile": blob
}

URI Request Parameters


The request requires the following URI parameters.

FunctionName (p. 440)

The existing Lambda function name whose code you want to replace.

You can specify a function name (for example, Thumbnail) or you can specify Amazon
Resource Name (ARN) of the function (for example, arn:aws:lambda:us-west-2:account-
id:function:ThumbNail). AWS Lambda also allows you to specify a partial ARN (for example,
account-id:Thumbnail). Note that the length constraint applies only to the ARN. If you specify only
the function name, it is limited to 64 characters in length.

Length Constraints: Minimum length of 1. Maximum length of 140.

Pattern: (arn:aws:lambda:)?([a-z]{2}-[a-z]+-\d{1}:)?(\d{12}:)?(function:)?([a-zA-Z0-9-
_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?

Request Body
The request accepts the following data in JSON format.

DryRun (p. 440)

This boolean parameter can be used to test your request to AWS Lambda to update the Lambda
function and publish a version as an atomic operation. It will do all necessary computation and
validation of your code but will not upload it or a publish a version. Each time this operation is
invoked, the CodeSha256 hash value of the provided code will also be computed and returned in the
response.

Type: Boolean

440
AWS Lambda Developer Guide
UpdateFunctionCode

Required: No
Publish (p. 440)

This boolean parameter can be used to request AWS Lambda to update the Lambda function and
publish a version as an atomic operation.

Type: Boolean

Required: No
S3Bucket (p. 440)

Amazon S3 bucket name where the .zip le containing your deployment package is stored. This
bucket must reside in the same AWS Region where you are creating the Lambda function.

Type: String

Length Constraints: Minimum length of 3. Maximum length of 63.

Pattern: ^[0-9A-Za-z\.\-_]*(?<!\.)$

Required: No
S3Key (p. 440)

The Amazon S3 object (the deployment package) key name you want to upload.

Type: String

Length Constraints: Minimum length of 1. Maximum length of 1024.

Required: No
S3ObjectVersion (p. 440)

The Amazon S3 object (the deployment package) version you want to upload.

Type: String

Length Constraints: Minimum length of 1. Maximum length of 1024.

Required: No
ZipFile (p. 440)

The contents of your zip le containing your deployment package. If you are using the web API
directly, the contents of the zip le must be base64-encoded. If you are using the AWS SDKs or the
AWS CLI, the SDKs or CLI will do the encoding for you. For more information about creating a .zip
le, see Execution Permissions in the AWS Lambda Developer Guide.

Type: Base64-encoded binary data object

Required: No

Response Syntax
HTTP/1.1 200
Content-type: application/json

{
"CodeSha256": "string",
"CodeSize": number,
"DeadLetterConfig": {

441
AWS Lambda Developer Guide
UpdateFunctionCode

"TargetArn": "string"
},
"Description": "string",
"Environment": {
"Error": {
"ErrorCode": "string",
"Message": "string"
},
"Variables": {
"string" : "string"
}
},
"FunctionArn": "string",
"FunctionName": "string",
"Handler": "string",
"KMSKeyArn": "string",
"LastModified": "string",
"MasterArn": "string",
"MemorySize": number,
"Role": "string",
"Runtime": "string",
"Timeout": number,
"TracingConfig": {
"Mode": "string"
},
"Version": "string",
"VpcConfig": {
"SecurityGroupIds": [ "string" ],
"SubnetIds": [ "string" ],
"VpcId": "string"
}
}

Response Elements
If the action is successful, the service sends back an HTTP 200 response.

The following data is returned in JSON format by the service.

CodeSha256 (p. 441)

It is the SHA256 hash of your function deployment package.

Type: String
CodeSize (p. 441)

The size, in bytes, of the function .zip le you uploaded.

Type: Long
DeadLetterCong (p. 441)

The parent object that contains the target ARN (Amazon Resource Name) of an Amazon SQS queue
or Amazon SNS topic.

Type: DeadLetterCong (p. 458) object


Description (p. 441)

The user-provided description.

Type: String

Length Constraints: Minimum length of 0. Maximum length of 256.

442
AWS Lambda Developer Guide
UpdateFunctionCode

Environment (p. 441)

The parent object that contains your environment's conguration settings.

Type: EnvironmentResponse (p. 461) object


FunctionArn (p. 441)

The Amazon Resource Name (ARN) assigned to the function.

Type: String

Pattern: arn:aws:lambda:[a-z]{2}-[a-z]+-\d{1}:\d{12}:function:[a-zA-Z0-9-_\.]+(:(\
$LATEST|[a-zA-Z0-9-_]+))?
FunctionName (p. 441)

The name of the function. Note that the length constraint applies only to the ARN. If you specify
only the function name, it is limited to 64 characters in length.

Type: String

Length Constraints: Minimum length of 1. Maximum length of 170.

Pattern: (arn:aws:lambda:)?([a-z]{2}-[a-z]+-\d{1}:)?(\d{12}:)?(function:)?([a-zA-Z0-9-_
\.]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Handler (p. 441)

The function Lambda calls to begin executing your function.

Type: String

Length Constraints: Maximum length of 128.

Pattern: [^\s]+
KMSKeyArn (p. 441)

The Amazon Resource Name (ARN) of the KMS key used to encrypt your function's environment
variables. If empty, it means you are using the AWS Lambda default service key.

Type: String

Pattern: (arn:aws:[a-z0-9-.]+:.*)|()
LastModied (p. 441)

The time stamp of the last time you updated the function. The time stamp is conveyed
as a string complying with ISO-8601 in this way YYYY-MM-DDThh:mm:ssTZD (e.g.,
1997-07-16T19:20:30+01:00). For more information, see Date and Time Formats.

Type: String
MasterArn (p. 441)

Returns the ARN (Amazon Resource Name) of the master function.

Type: String

Pattern: arn:aws:lambda:[a-z]{2}-[a-z]+-\d{1}:\d{12}:function:[a-zA-Z0-9-_]+(:(\$LATEST|
[a-zA-Z0-9-_]+))?
MemorySize (p. 441)

The memory size, in MB, you congured for the function. Must be a multiple of 64 MB.

443
AWS Lambda Developer Guide
UpdateFunctionCode

Type: Integer

Valid Range: Minimum value of 128. Maximum value of 1536.


Role (p. 441)

The Amazon Resource Name (ARN) of the IAM role that Lambda assumes when it executes your
function to access any other Amazon Web Services (AWS) resources.

Type: String

Pattern: arn:aws:iam::\d{12}:role/?[a-zA-Z_0-9+=,.@\-_/]+
Runtime (p. 441)

The runtime environment for the Lambda function.

Type: String

Valid Values: nodejs | nodejs4.3 | nodejs6.10 | java8 | python2.7 | python3.6 |


dotnetcore1.0 | nodejs4.3-edge
Timeout (p. 441)

The function execution time at which Lambda should terminate the function. Because the execution
time has cost implications, we recommend you set this value based on your expected execution time.
The default is 3 seconds.

Type: Integer

Valid Range: Minimum value of 1.


TracingCong (p. 441)

The parent object that contains your function's tracing settings.

Type: TracingCongResponse (p. 471) object


Version (p. 441)

The version of the Lambda function.

Type: String

Length Constraints: Minimum length of 1. Maximum length of 1024.

Pattern: (\$LATEST|[0-9]+)
VpcCong (p. 441)

VPC conguration associated with your Lambda function.

Type: VpcCongResponse (p. 473) object

Errors
CodeStorageExceededException

You have exceeded your maximum total code size per account. Limits

HTTP Status Code: 400


InvalidParameterValueException

One of the parameters in the request is invalid. For example, if you provided an IAM role for AWS
Lambda to assume in the CreateFunction or the UpdateFunctionConfiguration API, that AWS

444
AWS Lambda Developer Guide
UpdateFunctionCode

Lambda is unable to assume you will get this exception. You will also get this exception if you have
selected a deprecated runtime, such as Node v0.10.42.

HTTP Status Code: 400


ResourceNotFoundException

The resource (for example, a Lambda function or access policy statement) specied in the request
does not exist.

HTTP Status Code: 404


ServiceException

The AWS Lambda service encountered an internal error.

HTTP Status Code: 500


TooManyRequestsException

HTTP Status Code: 429

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS Command Line Interface


AWS SDK for .NET
AWS SDK for C++
AWS SDK for Go
AWS SDK for Java
AWS SDK for JavaScript
AWS SDK for PHP V3
AWS SDK for Python
AWS SDK for Ruby V2

445
AWS Lambda Developer Guide
UpdateFunctionConguration

UpdateFunctionConguration
Updates the conguration parameters for the specied Lambda function by using the values provided in
the request. You provide only the parameters you want to change. This operation must only be used on
an existing Lambda function and cannot be used to update the function's code.

If you are using the versioning feature, note this API will always update the $LATEST version of your
Lambda function. For information about the versioning feature, see AWS Lambda Function Versioning
and Aliases.

This operation requires permission for the lambda:UpdateFunctionConfiguration action.

Request Syntax
PUT /2015-03-31/functions/FunctionName/configuration HTTP/1.1
Content-type: application/json

{
"DeadLetterConfig": {
"TargetArn": "string"
},
"Description": "string",
"Environment": {
"Variables": {
"string" : "string"
}
},
"Handler": "string",
"KMSKeyArn": "string",
"MemorySize": number,
"Role": "string",
"Runtime": "string",
"Timeout": number,
"TracingConfig": {
"Mode": "string"
},
"VpcConfig": {
"SecurityGroupIds": [ "string" ],
"SubnetIds": [ "string" ]
}
}

URI Request Parameters


The request requires the following URI parameters.

FunctionName (p. 446)

The name of the Lambda function.

You can specify a function name (for example, Thumbnail) or you can specify Amazon
Resource Name (ARN) of the function (for example, arn:aws:lambda:us-west-2:account-
id:function:ThumbNail). AWS Lambda also allows you to specify a partial ARN (for example,
account-id:Thumbnail). Note that the length constraint applies only to the ARN. If you specify only
the function name, it is limited to 64 character in length.

Length Constraints: Minimum length of 1. Maximum length of 140.

Pattern: (arn:aws:lambda:)?([a-z]{2}-[a-z]+-\d{1}:)?(\d{12}:)?(function:)?([a-zA-Z0-9-
_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?

446
AWS Lambda Developer Guide
UpdateFunctionConguration

Request Body
The request accepts the following data in JSON format.

DeadLetterCong (p. 446)

The parent object that contains the target ARN (Amazon Resource Name) of an Amazon SQS queue
or Amazon SNS topic.

Type: DeadLetterCong (p. 458) object

Required: No
Description (p. 446)

A short user-dened function description. AWS Lambda does not use this value. Assign a meaningful
description as you see t.

Type: String

Length Constraints: Minimum length of 0. Maximum length of 256.

Required: No
Environment (p. 446)

The parent object that contains your environment's conguration settings.

Type: Environment (p. 459) object

Required: No
Handler (p. 446)

The function that Lambda calls to begin executing your function. For Node.js, it is the module-
name.export value in your function.

Type: String

Length Constraints: Maximum length of 128.

Pattern: [^\s]+

Required: No
KMSKeyArn (p. 446)

The Amazon Resource Name (ARN) of the KMS key used to encrypt your function's environment
variables. If you elect to use the AWS Lambda default service key, pass in an empty string ("") for this
parameter.

Type: String

Pattern: (arn:aws:[a-z0-9-.]+:.*)|()

Required: No
MemorySize (p. 446)

The amount of memory, in MB, your Lambda function is given. AWS Lambda uses this memory size
to infer the amount of CPU allocated to your function. Your function use-case determines your CPU
and memory requirements. For example, a database operation might need less memory compared

447
AWS Lambda Developer Guide
UpdateFunctionConguration

to an image processing function. The default value is 128 MB. The value must be a multiple of 64
MB.

Type: Integer

Valid Range: Minimum value of 128. Maximum value of 1536.

Required: No
Role (p. 446)

The Amazon Resource Name (ARN) of the IAM role that Lambda will assume when it executes your
function.

Type: String

Pattern: arn:aws:iam::\d{12}:role/?[a-zA-Z_0-9+=,.@\-_/]+

Required: No
Runtime (p. 446)

The runtime environment for the Lambda function.

To use the Python runtime v3.6, set the value to "python3.6". To use the Python runtime v2.7, set
the value to "python2.7". To use the Node.js runtime v6.10, set the value to "nodejs6.10". To use the
Node.js runtime v4.3, set the value to "nodejs4.3". To use the Python runtime v3.6, set the value to
"python3.6".
Note
Node v0.10.42 is currently marked as deprecated. You must migrate existing functions to
the newer Node.js runtime versions available on AWS Lambda (nodejs4.3 or nodejs6.10) as
soon as possible. You can request a one-time extension until June 30, 2017 by going to the
Lambda console and following the instructions provided. Failure to do so will result in an
invalid parameter error being returned. Note that you will have to follow this procedure for
each region that contains functions written in the Node v0.10.42 runtime.

Type: String

Valid Values: nodejs | nodejs4.3 | nodejs6.10 | java8 | python2.7 | python3.6 |


dotnetcore1.0 | nodejs4.3-edge

Required: No
Timeout (p. 446)

The function execution time at which AWS Lambda should terminate the function. Because the
execution time has cost implications, we recommend you set this value based on your expected
execution time. The default is 3 seconds.

Type: Integer

Valid Range: Minimum value of 1.

Required: No
TracingCong (p. 446)

The parent object that contains your function's tracing settings.

Type: TracingCong (p. 470) object

Required: No

448
AWS Lambda Developer Guide
UpdateFunctionConguration

VpcCong (p. 446)

If your Lambda function accesses resources in a VPC, you provide this parameter identifying the list
of security group IDs and subnet IDs. These must belong to the same VPC. You must provide at least
one security group and one subnet ID.

Type: VpcCong (p. 472) object

Required: No

Response Syntax
HTTP/1.1 200
Content-type: application/json

{
"CodeSha256": "string",
"CodeSize": number,
"DeadLetterConfig": {
"TargetArn": "string"
},
"Description": "string",
"Environment": {
"Error": {
"ErrorCode": "string",
"Message": "string"
},
"Variables": {
"string" : "string"
}
},
"FunctionArn": "string",
"FunctionName": "string",
"Handler": "string",
"KMSKeyArn": "string",
"LastModified": "string",
"MasterArn": "string",
"MemorySize": number,
"Role": "string",
"Runtime": "string",
"Timeout": number,
"TracingConfig": {
"Mode": "string"
},
"Version": "string",
"VpcConfig": {
"SecurityGroupIds": [ "string" ],
"SubnetIds": [ "string" ],
"VpcId": "string"
}
}

Response Elements
If the action is successful, the service sends back an HTTP 200 response.

The following data is returned in JSON format by the service.

CodeSha256 (p. 449)

It is the SHA256 hash of your function deployment package.

449
AWS Lambda Developer Guide
UpdateFunctionConguration

Type: String
CodeSize (p. 449)

The size, in bytes, of the function .zip le you uploaded.

Type: Long
DeadLetterCong (p. 449)

The parent object that contains the target ARN (Amazon Resource Name) of an Amazon SQS queue
or Amazon SNS topic.

Type: DeadLetterCong (p. 458) object


Description (p. 449)

The user-provided description.

Type: String

Length Constraints: Minimum length of 0. Maximum length of 256.


Environment (p. 449)

The parent object that contains your environment's conguration settings.

Type: EnvironmentResponse (p. 461) object


FunctionArn (p. 449)

The Amazon Resource Name (ARN) assigned to the function.

Type: String

Pattern: arn:aws:lambda:[a-z]{2}-[a-z]+-\d{1}:\d{12}:function:[a-zA-Z0-9-_\.]+(:(\
$LATEST|[a-zA-Z0-9-_]+))?
FunctionName (p. 449)

The name of the function. Note that the length constraint applies only to the ARN. If you specify
only the function name, it is limited to 64 characters in length.

Type: String

Length Constraints: Minimum length of 1. Maximum length of 170.

Pattern: (arn:aws:lambda:)?([a-z]{2}-[a-z]+-\d{1}:)?(\d{12}:)?(function:)?([a-zA-Z0-9-_
\.]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Handler (p. 449)

The function Lambda calls to begin executing your function.

Type: String

Length Constraints: Maximum length of 128.

Pattern: [^\s]+
KMSKeyArn (p. 449)

The Amazon Resource Name (ARN) of the KMS key used to encrypt your function's environment
variables. If empty, it means you are using the AWS Lambda default service key.

Type: String

450
AWS Lambda Developer Guide
UpdateFunctionConguration

Pattern: (arn:aws:[a-z0-9-.]+:.*)|()
LastModied (p. 449)

The time stamp of the last time you updated the function. The time stamp is conveyed
as a string complying with ISO-8601 in this way YYYY-MM-DDThh:mm:ssTZD (e.g.,
1997-07-16T19:20:30+01:00). For more information, see Date and Time Formats.

Type: String
MasterArn (p. 449)

Returns the ARN (Amazon Resource Name) of the master function.

Type: String

Pattern: arn:aws:lambda:[a-z]{2}-[a-z]+-\d{1}:\d{12}:function:[a-zA-Z0-9-_]+(:(\$LATEST|
[a-zA-Z0-9-_]+))?
MemorySize (p. 449)

The memory size, in MB, you congured for the function. Must be a multiple of 64 MB.

Type: Integer

Valid Range: Minimum value of 128. Maximum value of 1536.


Role (p. 449)

The Amazon Resource Name (ARN) of the IAM role that Lambda assumes when it executes your
function to access any other Amazon Web Services (AWS) resources.

Type: String

Pattern: arn:aws:iam::\d{12}:role/?[a-zA-Z_0-9+=,.@\-_/]+
Runtime (p. 449)

The runtime environment for the Lambda function.

Type: String

Valid Values: nodejs | nodejs4.3 | nodejs6.10 | java8 | python2.7 | python3.6 |


dotnetcore1.0 | nodejs4.3-edge
Timeout (p. 449)

The function execution time at which Lambda should terminate the function. Because the execution
time has cost implications, we recommend you set this value based on your expected execution time.
The default is 3 seconds.

Type: Integer

Valid Range: Minimum value of 1.


TracingCong (p. 449)

The parent object that contains your function's tracing settings.

Type: TracingCongResponse (p. 471) object


Version (p. 449)

The version of the Lambda function.

Type: String

451
AWS Lambda Developer Guide
UpdateFunctionConguration

Length Constraints: Minimum length of 1. Maximum length of 1024.

Pattern: (\$LATEST|[0-9]+)
VpcCong (p. 449)

VPC conguration associated with your Lambda function.

Type: VpcCongResponse (p. 473) object

Errors
InvalidParameterValueException

One of the parameters in the request is invalid. For example, if you provided an IAM role for AWS
Lambda to assume in the CreateFunction or the UpdateFunctionConfiguration API, that AWS
Lambda is unable to assume you will get this exception. You will also get this exception if you have
selected a deprecated runtime, such as Node v0.10.42.

HTTP Status Code: 400


ResourceConictException

The resource already exists.

HTTP Status Code: 409


ResourceNotFoundException

The resource (for example, a Lambda function or access policy statement) specied in the request
does not exist.

HTTP Status Code: 404


ServiceException

The AWS Lambda service encountered an internal error.

HTTP Status Code: 500


TooManyRequestsException

HTTP Status Code: 429

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS Command Line Interface


AWS SDK for .NET
AWS SDK for C++
AWS SDK for Go
AWS SDK for Java
AWS SDK for JavaScript
AWS SDK for PHP V3
AWS SDK for Python
AWS SDK for Ruby V2

452
AWS Lambda Developer Guide
Data Types

Data Types
The following data types are supported:

AccountLimit (p. 454)


AccountUsage (p. 455)
AliasConguration (p. 456)
DeadLetterCong (p. 458)
Environment (p. 459)
EnvironmentError (p. 460)
EnvironmentResponse (p. 461)
EventSourceMappingConguration (p. 462)
FunctionCode (p. 464)
FunctionCodeLocation (p. 465)
FunctionConguration (p. 466)
TracingCong (p. 470)
TracingCongResponse (p. 471)
VpcCong (p. 472)
VpcCongResponse (p. 473)

453
AWS Lambda Developer Guide
AccountLimit

AccountLimit
Provides limits of code size and concurrency associated with the current account and region.

Contents
CodeSizeUnzipped

Size, in bytes, of code/dependencies that you can zip into a deployment package (uncompressed
zip/jar size) for uploading. The default limit is 250 MB.

Type: Long

Required: No
CodeSizeZipped

Size, in bytes, of a single zipped code/dependencies package you can upload for your Lambda
function(.zip/.jar le). Try using Amazon S3 for uploading larger les. Default limit is 50 MB.

Type: Long

Required: No
ConcurrentExecutions

Number of simultaneous executions of your function per region. For more information or to request
a limit increase for concurrent executions, see Lambda Function Concurrent Executions. The default
limit is 1000.

Type: Integer

Required: No
TotalCodeSize

Maximum size, in bytes, of a code package you can upload per region. The default size is 75 GB.

Type: Long

Required: No

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS SDK for C++


AWS SDK for Go
AWS SDK for Java
AWS SDK for Ruby V2

454
AWS Lambda Developer Guide
AccountUsage

AccountUsage
Provides code size usage and function count associated with the current account and region.

Contents
FunctionCount

The number of your account's existing functions per region.

Type: Long

Required: No
TotalCodeSize

Total size, in bytes, of the account's deployment packages per region.

Type: Long

Required: No

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS SDK for C++


AWS SDK for Go
AWS SDK for Java
AWS SDK for Ruby V2

455
AWS Lambda Developer Guide
AliasConguration

AliasConguration
Provides conguration information about a Lambda function version alias.

Contents
AliasArn

Lambda function ARN that is qualied using the alias name as the sux. For example, if you create
an alias called BETA that points to a helloworld function version, the ARN is arn:aws:lambda:aws-
regions:acct-id:function:helloworld:BETA.

Type: String

Pattern: arn:aws:lambda:[a-z]{2}-[a-z]+-\d{1}:\d{12}:function:[a-zA-Z0-9-_]+(:(\$LATEST|
[a-zA-Z0-9-_]+))?

Required: No
Description

Alias description.

Type: String

Length Constraints: Minimum length of 0. Maximum length of 256.

Required: No
FunctionVersion

Function version to which the alias points.

Type: String

Length Constraints: Minimum length of 1. Maximum length of 1024.

Pattern: (\$LATEST|[0-9]+)

Required: No
Name

Alias name.

Type: String

Length Constraints: Minimum length of 1. Maximum length of 128.

Pattern: (?!^[0-9]+$)([a-zA-Z0-9-_]+)

Required: No

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS SDK for C++


AWS SDK for Go
AWS SDK for Java

456
AWS Lambda Developer Guide
AliasConguration

AWS SDK for Ruby V2

457
AWS Lambda Developer Guide
DeadLetterCong

DeadLetterCong
The parent object that contains the target ARN (Amazon Resource Name) of an Amazon SQS queue or
Amazon SNS topic.

Contents
TargetArn

The Amazon Resource Name (ARN) of an Amazon SQS queue or Amazon SNS topic you specify as
your Dead Letter Queue (DLQ).

Type: String

Pattern: (arn:aws:[a-z0-9-.]+:.*)|()

Required: No

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS SDK for C++


AWS SDK for Go
AWS SDK for Java
AWS SDK for Ruby V2

458
AWS Lambda Developer Guide
Environment

Environment
The parent object that contains your environment's conguration settings.

Contents
Variables

The key-value pairs that represent your environment's conguration settings.

Type: String to string map

Required: No

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS SDK for C++


AWS SDK for Go
AWS SDK for Java
AWS SDK for Ruby V2

459
AWS Lambda Developer Guide
EnvironmentError

EnvironmentError
The parent object that contains error information associated with your conguration settings.

Contents
ErrorCode

The error code returned by the environment error object.

Type: String

Required: No
Message

The message returned by the environment error object.

Type: String

Required: No

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS SDK for C++


AWS SDK for Go
AWS SDK for Java
AWS SDK for Ruby V2

460
AWS Lambda Developer Guide
EnvironmentResponse

EnvironmentResponse
The parent object returned that contains your environment's conguration settings or any error
information associated with your conguration settings.

Contents
Error

The parent object that contains error information associated with your conguration settings.

Type: EnvironmentError (p. 460) object

Required: No
Variables

The key-value pairs returned that represent your environment's conguration settings or error
information.

Type: String to string map

Required: No

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS SDK for C++


AWS SDK for Go
AWS SDK for Java
AWS SDK for Ruby V2

461
AWS Lambda Developer Guide
EventSourceMappingConguration

EventSourceMappingConguration
Describes mapping between an Amazon Kinesis stream and a Lambda function.

Contents
BatchSize

The largest number of records that AWS Lambda will retrieve from your event source at the time of
invoking your function. Your function receives an event with all the retrieved records.

Type: Integer

Valid Range: Minimum value of 1. Maximum value of 10000.

Required: No
EventSourceArn

The Amazon Resource Name (ARN) of the Amazon Kinesis stream that is the source of events.

Type: String

Pattern: arn:aws:([a-zA-Z0-9\-])+:([a-z]{2}-[a-z]+-\d{1})?:(\d{12})?:(.*)

Required: No
FunctionArn

The Lambda function to invoke when AWS Lambda detects an event on the stream.

Type: String

Pattern: arn:aws:lambda:[a-z]{2}-[a-z]+-\d{1}:\d{12}:function:[a-zA-Z0-9-_]+(:(\$LATEST|
[a-zA-Z0-9-_]+))?

Required: No
LastModied

The UTC time string indicating the last time the event mapping was updated.

Type: Timestamp

Required: No
LastProcessingResult

The result of the last AWS Lambda invocation of your Lambda function.

Type: String

Required: No
State

The state of the event source mapping. It can be Creating, Enabled, Disabled, Enabling, Disabling,
Updating, or Deleting.

Type: String

Required: No

462
AWS Lambda Developer Guide
EventSourceMappingConguration

StateTransitionReason

The reason the event source mapping is in its current state. It is either user-requested or an AWS
Lambda-initiated state transition.

Type: String

Required: No
UUID

The AWS Lambda assigned opaque identier for the mapping.

Type: String

Required: No

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS SDK for C++


AWS SDK for Go
AWS SDK for Java
AWS SDK for Ruby V2

463
AWS Lambda Developer Guide
FunctionCode

FunctionCode
The code for the Lambda function.

Contents
S3Bucket

Amazon S3 bucket name where the .zip le containing your deployment package is stored. This
bucket must reside in the same AWS region where you are creating the Lambda function.

Type: String

Length Constraints: Minimum length of 3. Maximum length of 63.

Pattern: ^[0-9A-Za-z\.\-_]*(?<!\.)$

Required: No
S3Key

The Amazon S3 object (the deployment package) key name you want to upload.

Type: String

Length Constraints: Minimum length of 1. Maximum length of 1024.

Required: No
S3ObjectVersion

The Amazon S3 object (the deployment package) version you want to upload.

Type: String

Length Constraints: Minimum length of 1. Maximum length of 1024.

Required: No
ZipFile

The contents of your zip le containing your deployment package. If you are using the web API
directly, the contents of the zip le must be base64-encoded. If you are using the AWS SDKs or the
AWS CLI, the SDKs or CLI will do the encoding for you. For more information about creating a .zip
le, see Execution Permissions in the AWS Lambda Developer Guide.

Type: Base64-encoded binary data object

Required: No

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS SDK for C++


AWS SDK for Go
AWS SDK for Java
AWS SDK for Ruby V2

464
AWS Lambda Developer Guide
FunctionCodeLocation

FunctionCodeLocation
The object for the Lambda function location.

Contents
Location

The presigned URL you can use to download the function's .zip le that you previously uploaded.
The URL is valid for up to 10 minutes.

Type: String

Required: No
RepositoryType

The repository from which you can download the function.

Type: String

Required: No

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS SDK for C++


AWS SDK for Go
AWS SDK for Java
AWS SDK for Ruby V2

465
AWS Lambda Developer Guide
FunctionConguration

FunctionConguration
A complex type that describes function metadata.

Contents
CodeSha256

It is the SHA256 hash of your function deployment package.

Type: String

Required: No
CodeSize

The size, in bytes, of the function .zip le you uploaded.

Type: Long

Required: No
DeadLetterCong

The parent object that contains the target ARN (Amazon Resource Name) of an Amazon SQS queue
or Amazon SNS topic.

Type: DeadLetterCong (p. 458) object

Required: No
Description

The user-provided description.

Type: String

Length Constraints: Minimum length of 0. Maximum length of 256.

Required: No
Environment

The parent object that contains your environment's conguration settings.

Type: EnvironmentResponse (p. 461) object

Required: No
FunctionArn

The Amazon Resource Name (ARN) assigned to the function.

Type: String

Pattern: arn:aws:lambda:[a-z]{2}-[a-z]+-\d{1}:\d{12}:function:[a-zA-Z0-9-_\.]+(:(\
$LATEST|[a-zA-Z0-9-_]+))?

Required: No
FunctionName

The name of the function. Note that the length constraint applies only to the ARN. If you specify
only the function name, it is limited to 64 characters in length.

466
AWS Lambda Developer Guide
FunctionConguration

Type: String

Length Constraints: Minimum length of 1. Maximum length of 170.

Pattern: (arn:aws:lambda:)?([a-z]{2}-[a-z]+-\d{1}:)?(\d{12}:)?(function:)?([a-zA-Z0-9-_
\.]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?

Required: No
Handler

The function Lambda calls to begin executing your function.

Type: String

Length Constraints: Maximum length of 128.

Pattern: [^\s]+

Required: No
KMSKeyArn

The Amazon Resource Name (ARN) of the KMS key used to encrypt your function's environment
variables. If empty, it means you are using the AWS Lambda default service key.

Type: String

Pattern: (arn:aws:[a-z0-9-.]+:.*)|()

Required: No
LastModied

The time stamp of the last time you updated the function. The time stamp is conveyed
as a string complying with ISO-8601 in this way YYYY-MM-DDThh:mm:ssTZD (e.g.,
1997-07-16T19:20:30+01:00). For more information, see Date and Time Formats.

Type: String

Required: No
MasterArn

Returns the ARN (Amazon Resource Name) of the master function.

Type: String

Pattern: arn:aws:lambda:[a-z]{2}-[a-z]+-\d{1}:\d{12}:function:[a-zA-Z0-9-_]+(:(\$LATEST|
[a-zA-Z0-9-_]+))?

Required: No
MemorySize

The memory size, in MB, you congured for the function. Must be a multiple of 64 MB.

Type: Integer

Valid Range: Minimum value of 128. Maximum value of 1536.

Required: No
Role

The Amazon Resource Name (ARN) of the IAM role that Lambda assumes when it executes your
function to access any other Amazon Web Services (AWS) resources.

467
AWS Lambda Developer Guide
FunctionConguration

Type: String

Pattern: arn:aws:iam::\d{12}:role/?[a-zA-Z_0-9+=,.@\-_/]+

Required: No
Runtime

The runtime environment for the Lambda function.

Type: String

Valid Values: nodejs | nodejs4.3 | nodejs6.10 | java8 | python2.7 | python3.6 |


dotnetcore1.0 | nodejs4.3-edge

Required: No
Timeout

The function execution time at which Lambda should terminate the function. Because the execution
time has cost implications, we recommend you set this value based on your expected execution time.
The default is 3 seconds.

Type: Integer

Valid Range: Minimum value of 1.

Required: No
TracingCong

The parent object that contains your function's tracing settings.

Type: TracingCongResponse (p. 471) object

Required: No
Version

The version of the Lambda function.

Type: String

Length Constraints: Minimum length of 1. Maximum length of 1024.

Pattern: (\$LATEST|[0-9]+)

Required: No
VpcCong

VPC conguration associated with your Lambda function.

Type: VpcCongResponse (p. 473) object

Required: No

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS SDK for C++


AWS SDK for Go

468
AWS Lambda Developer Guide
FunctionConguration

AWS SDK for Java


AWS SDK for Ruby V2

469
AWS Lambda Developer Guide
TracingCong

TracingCong
The parent object that contains your function's tracing settings.

Contents
Mode

Can be either PassThrough or Active. If PassThrough, Lambda will only trace the request from an
upstream service if it contains a tracing header with "sampled=1". If Active, Lambda will respect any
tracing header it receives from an upstream service. If no tracing header is received, Lambda will call
X-Ray for a tracing decision.

Type: String

Valid Values: Active | PassThrough

Required: No

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS SDK for C++


AWS SDK for Go
AWS SDK for Java
AWS SDK for Ruby V2

470
AWS Lambda Developer Guide
TracingCongResponse

TracingCongResponse
Parent object of the tracing information associated with your Lambda function.

Contents
Mode

The tracing mode associated with your Lambda function.

Type: String

Valid Values: Active | PassThrough

Required: No

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS SDK for C++


AWS SDK for Go
AWS SDK for Java
AWS SDK for Ruby V2

471
AWS Lambda Developer Guide
VpcCong

VpcCong
If your Lambda function accesses resources in a VPC, you provide this parameter identifying the list of
security group IDs and subnet IDs. These must belong to the same VPC. You must provide at least one
security group and one subnet ID.

Contents
SecurityGroupIds

A list of one or more security groups IDs in your VPC.

Type: Array of strings

Array Members: Maximum number of 5 items.

Required: No
SubnetIds

A list of one or more subnet IDs in your VPC.

Type: Array of strings

Array Members: Maximum number of 16 items.

Required: No

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS SDK for C++


AWS SDK for Go
AWS SDK for Java
AWS SDK for Ruby V2

472
AWS Lambda Developer Guide
VpcCongResponse

VpcCongResponse
VPC conguration associated with your Lambda function.

Contents
SecurityGroupIds

A list of security group IDs associated with the Lambda function.

Type: Array of strings

Array Members: Maximum number of 5 items.

Required: No
SubnetIds

A list of subnet IDs associated with the Lambda function.

Type: Array of strings

Array Members: Maximum number of 16 items.

Required: No
VpcId

The VPC ID associated with you Lambda function.

Type: String

Required: No

See Also
For more information about using this API in one of the language-specic AWS SDKs, see the following:

AWS SDK for C++


AWS SDK for Go
AWS SDK for Java
AWS SDK for Ruby V2

473
AWS Lambda Developer Guide

Document History

The following table describes the important changes to the AWS Lambda Developer Guide.

Relevant Dates to this History:

Current product version: 2015-03-31


Last documentation update: August 11, 2017

Change Description Date

Introducing SAM Local AWS Lambda introduces SAM Local, an AWS CLI tool that August 11,
provides an environment for you to develop, test, and analyze 2017
your serverless applications locally before uploading them
to the Lambda runtime. For more information, see Test Your
Serverless Applications Locally Using SAM Local (Public
Beta) (p. 157).

Canada (Central) Region AWS Lambda is now available in the Canada (Central) Region. June 22,
For more information about Lambda regions and endpoints, 2017
see Regions and Endpoints in the AWS General Reference.

South America (So AWS Lambda is now available in the South America (So June 6,
Paulo) Region Paulo) Region. For more information about Lambda regions 2017
and endpoints, see Regions and Endpoints in the AWS General
Reference.

AWS Lambda support Lambda introduces support for X-Ray, which allows you April 19,
for AWS X-Ray. to detect, analyze, and optimize performance issues with 2017
your Lambda applications. For more information, see
Troubleshooting Lambda-Based Applications (p. 164).

Asia Pacic (Mumbai) AWS Lambda is now available in the Asia Pacic (Mumbai) March 28,
Region Region. For more information about Lambda regions and 2017
endpoints, see Regions and Endpoints in the AWS General
Reference.

AWS Lambda now AWS Lambda added support for Node.js runtime v6.10. For March 22,
supports Node.js more information, see Programming Model (Node.js) (p. 9). 2017
runtime v6.10

474
AWS Lambda Developer Guide

Change Description Date

EU (London) Region AWS Lambda is now available in the EU (London) Region. For February 1,
more information about Lambda regions and endpoints, see 2017
Regions and Endpoints in the AWS General Reference.

AWS Lambda support AWS Lambda introduces the following features: December
for the .NET runtime, 3, 2016
Lambda@Edge AWS Lambda added support for C#. For more information,
(Preview), Dead Letter see Programming Model for Authoring Lambda Functions in
Queues and automated C# (p. 50).
deployment of Lambda@Edge (Preview) allows you to run Lambda
serverless applications. functions at the AWS Edge locations in response to
CloudFront events. For more information, see AWS
Lambda@Edge (p. 299).
Added a tutorial for automating deployment of serverless
applications using AWS CodePipeline, AWS CodeBuild
and AWS CloudFormation. For more information,
see Automating Deployment of Lambda-based
Applications (p. 152).
Updated Troubleshooting and Monitoring AWS Lambda
Functions with Amazon CloudWatch (p. 114) to include
a section on Dead Letter Queues (p. 121), which you can
congure to retrieve information on failed asynchronous
invocations of Lambda functions.

AWS Lambda adds Using Lambda and Amazon Lex, you can quickly build chat November
Amazon Lex as a bots for various services like Slack and Facebook. For more 30, 2016
supported event source. information, see Amazon Lex (p. 136).

US West (N. California) AWS Lambda is now available in the US West (N. California) November
Region Region. For more information about Lambda regions and 21, 2016
endpoints, see Regions and Endpoints in the AWS General
Reference.

Introduced the AWS AWS Lambda introduces the following features in this release. November
Serverless Application 18, 2016
Model for creating and AWS Serverless Application Model: You can now use the
deploying Lambda- AWS SAM to dene the syntax for expressing resources
based applications and within a serverless application. In order to deploy your
using environment application, simply specify the resources you need as part
variables for Lambda of your application, along with their associated permissions
function conguration policies in a AWS CloudFormation template le (written in
settings. either JSON or YAML), package your deployment artifacts,
and deploy the template. For more information, see
Deploying Lambda-based Applications (p. 144).
Environment variables: You can use environment variables
to specify conguration settings for your Lambda function
outside of your function code. For more information, see
Environment Variables (p. 92).

Added a tutorial under The tutorial instructs how to seamlessly integrate a Lambda August 29,
Getting Started (p. 185) function with an API via new features introduced in Congure 2016
for creating an Amazon Proxy Integration for a Proxy Resource. For more information,
API Gateway endpoint see Step 3: Create a Simple Microservice using Lambda and
using the Lambda API Gateway (p. 197).
console

475
AWS Lambda Developer Guide

Change Description Date

Asia Pacic (Seoul) AWS Lambda is now available in the Asia Pacic (Seoul) August 29,
Region Region. For more information about Lambda regions and 2016
endpoints, see Regions and Endpoints in the AWS General
Reference.

Asia Pacic (Sydney) Lambda is now available in the Asia Pacic (Sydney) Region. June 23,
Region For more information about Lambda regions and endpoints, 2016
see Regions and Endpoints in the AWS General Reference.

Updates to the Lambda The Lambda console has been updated to simplify the role- June 23,
console creation process. For more information, see Step 2.1: Create a 2016
Hello World Lambda Function (p. 189).

AWS Lambda now AWS Lambda added support for Node.js runtime v4.3. For April 07,
supports Node.js more information, see Programming Model (Node.js) (p. 9). 2016
runtime v4.3

EU (Frankfurt) region Lambda is now available in the EU (Frankfurt) region. For more March 14,
information about Lambda regions and endpoints, see Regions 2016
and Endpoints in the AWS General Reference.

VPC support You can now congure a Lambda function to access resources February
in your VPC. For more information, see Conguring a Lambda 11, 2016
Function to Access Resources in an Amazon VPC (p. 103). For
example walkthroughs, see Tutorials: Conguring a Lambda
Function to Access Resources in an Amazon VPC (p. 105).

Content reorganization The reorganized content now provides the following: December
9, 2015
Getting Started (p. 185) Contains a console-based exercise
in which you create a Hello World Lambda function. You
explore the AWS Lambda console features, including
blueprints that enable you to create Lambda functions with
just a few clicks.
Use Cases (p. 200) Provides examples of how to use
AWS Lambda with other AWS services or your custom
applications as event sources, invoke over HTTPS, and set up
AWS Lambda to invoke your Lambda function at scheduled
interval.
Programming Model (p. 8) Explains programming model
core concepts and describes language-specic details.
Regardless of the language you choose, there is a common
pattern to writing code for a Lambda function.
Creating a Deployment Package (p. 60) Explains how to
create deployment packages for Lambda function code
that is authored in languages supported by AWS Lambda
(Python, Java, and Node.js).

476
AWS Lambda Developer Guide

Change Description Date

AWS Lambda runtime AWS Lambda runtime has been updated with the following November
has been updated. SDK and Linux kernel versions in this release: 4, 2015

AWS SDK for JavaScript: 2.2.12


Boto SDK: 1.2.1
Linux kernel version: 3.14.48-33.39.amzn1.x86_6.

For more information, see Lambda Execution Environment and


Available Libraries (p. 182).

Versioning support, AWS Lambda introduces the following features in this release. October
Python for developing 08, 2015
code for Lambda Python: You can now develop your Lambda function code
functions, scheduled using Python. For more information, see Programming
events, and increase in Model (p. 8).
execution time Versioning: You can maintain one or more versions of
your Lambda function. Versioning allows you to control
which Lambda function version is executed in dierent
environments (for example, development, testing, or
production). For more information, see AWS Lambda
Function Versioning and Aliases (p. 75).
Scheduled events: You can also set up AWS Lambda to
invoke your code on a regular, scheduled basis using
the AWS Lambda console. You can specify a xed rate
(number of hours, days, or weeks) or you can specify a cron
expression. For an example, see Using AWS Lambda with
Scheduled Events (p. 284).
Increase in execution time: You can now set up your Lambda
functions to run for up to ve minutes allowing longer
running functions such as large volume data ingestion and
processing jobs.

Two new walkthroughs The following new walkthroughs are added. They both use August 27,
Java Lambda function. 2015

Tutorial: Using AWS Lambda with Amazon DynamoDB (p. 228)

Using AWS Lambda as Mobile Application Backend (Custom


Event Source: Android) (p. 272)

Support for DynamoDB DynamoDB Streams is now generally available and you can July 14,
Streams use it in all the regions where DynamoDB is available. You can 2015
enable DynamoDB Streams for your table and use a Lambda
function as a trigger for the table. Triggers are custom actions
you take in response to updates made to the DynamoDB table.
For an example walkthrough, see Tutorial: Using AWS Lambda
with Amazon DynamoDB (p. 228) .

477
AWS Lambda Developer Guide

Change Description Date

AWS Lambda now Until now, to invoke your Lambda function from your web, July 09,
supports invoking mobile, or IoT application you needed the AWS SDKs (for 2015
Lambda functions example, AWS SDK for Java, AWS SDK for Android, or AWS
with REST-compatible SDK for iOS). Now, AWS Lambda supports invoking a Lambda
clients. function with REST-compatible clients through a customized
API that you can create using Amazon API Gateway. You
can send requests to your Lambda function endpoint URL.
You can congure security on the endpoint to allow open
access, leverage AWS Identity and Access Management (IAM)
to authorize access, or use API keys to meter access to your
Lambda functions by others.

For an example Getting Started exercise, see Using AWS


Lambda with Amazon API Gateway (On-Demand Over
HTTPS) (p. 258).

For more information about the Amazon API Gateway, see


https://aws.amazon.com/api-gateway/.

The AWS Lambda AWS Lambda console provides a set of blueprints. Each In this
console now provides blueprint provides a sample event source conguration and release
blueprints to easily sample code for your Lambda function that you can use to
create Lambda easily create Lambda-based applications. All of the AWS
functions and test them. Lambda Getting Started exercises now use the blueprints. For
more information, see Getting Started (p. 185).

AWS Lambda now You can now author Lambda code in Java. For more June 15,
supports Java to author information, see Programming Model (p. 8). 2015
your Lambda functions.

AWS Lambda now You can upload a Lambda function deployment package (.zip May 28,
supports specifying an le) to an Amazon S3 bucket in the same region where you 2015
Amazon S3 object as want to create a Lambda function. Then, you can specify the
the function .zip when bucket name and object key name when you create or update
creating or updating a a Lambda function.
Lambda function.

AWS Lambda now AWS Lambda is now generally available for production April 9,
generally available use. The release also introduces new features that make it 2015
with added support for easier to build mobile, tablet, and Internet of Things (IoT)
mobile backends backends using AWS Lambda that scale automatically without
provisioning or managing infrastructure. AWS Lambda now
supports both real-time (synchronous) and asynchronous
events. Additional features include easier event source
conguration and management. The permission model
and the programming model have been simplied by the
introduction of resource policies for your Lambda functions.

The documentation has been updated accordingly. For


information, see the following topics:

How It Works (p. 175)

Getting Started (p. 185)

AWS Lambda

478
AWS Lambda Developer Guide

Change Description Date

Preview release Preview release of the AWS Lambda Developer Guide. November
13, 2014

479
AWS Lambda Developer Guide

AWS Glossary

For the latest AWS terminology, see the AWS Glossary in the AWS General Reference.

480

You might also like