In this step, you will create a Serverless Application that uses AWS Lambda to receive and process events. The infrastructure will be orchestrated by an automatically created CI/CD pipeline. You will then extend the default IAM role created so that you can work with additional services later on.
Each of the following sections provides an implementation overview and detailed, step-by-step instructions. The overview should provide enough context for you to complete the implementation if you're already familiar with the AWS Management Console or you want to explore the services yourself without following a walkthrough.
In the Lambda console, create a new serverless application from scratch. Wait until the creation completes.
✅ Step-by-step directions
-
Go to the AWS Console and log in to your AWS account.
-
Choose the US East (Ohio) region in the navigation bar.
-
Go to the Lambda Console.
-
In the Lambda console, choose Applications in the sidebar on the left.
-
Choose Create application.
-
Choose Author from scratch at the bottom of the page.
-
On the Configure your application page:
- Give the application a name and description
- Choose Node.JS 10.x runtime
- Select CodeCommit as the source control service and name your repository
- Check the Create roles and permissions boundary checkbox.
- Choose Create.
-
Wait for the creation process to finish. This will take approximately 5 minutes and you will see a success message when it's complete.
You now have a running serverless application built on AWS Lambda. Explore the Overview, Code, Deployments, and Monitoring tabs to see more about this base application and the infrastructure that is powering it.
Creation of infrastructure for the application is done by AWS CloudFormation, a service that enables managing infrastructure as code (IaC). CloudFormation uses an Identity and Access Management (IAM) role to create resources in your account. The default role created by the Serverless Application template does not have sufficient permissions to create resources in CloudWatch, SNS and IAM that you will need for this workshop. In this step, you will manually add the necessary permissions.
Open the CloudFormationRole IAM role in IAM console and add SNSFullAccess, IAMFullAccess, and CloudWatchFullAccess policies to it.
✅ Step-by-step directions
-
In the Application page, choose CloudFormationRole under the Infrastructure section. The IAM Console will open in a new tab.
-
Under the Permissions tab choose Attach policies.
-
Search for SNSFullAccess and check the checkbox next to it (but do not attach it yet). Repeat for IAMFullAccess and CloudWatchFullAccess.
-
Choose Attach policy to attach the three selected policies to the role. You should now see 4 policies attached.
🔧 The AWS Lambda "Create Application" flow gives you a full CI/CD setup to support building and deploying your serverless application. In just a few clicks you were able to establish a full code pipeline that automates from commit to deploy of a serverless app.
✅ Proceed to the next module, Code Management, wherein you'll configure an IAM user to interface with the CodeCommit repository created in this step. You'll then clone it locally and test the pipeline's functionality.