Lambda Functions
- Lambda by Amazon Web Services (AWS) is an analogous serverless solution.
- Lambda can be used internall as well as for model deployments (we are focusing on the latter).
- We will repeat setting up the weather app and the recommender model, using the CLI (command line interface tools)
data:image/s3,"s3://crabby-images/74dee/74deee1c0b86dba7356993f13c7ce6167e64ac1f" alt="aws"
Aside: Setting up an IAM user
Hello World in Lambda
- Select the lambda service.
data:image/s3,"s3://crabby-images/b3cd4/b3cd44844ebd5a94aa51be264d858ddd9baa0cd1" alt="lambda_start"
- Pick the python 3.7 runtime.
data:image/s3,"s3://crabby-images/4fbd3/4fbd3feef9490c74f8770e57a58c3036d6968bab" alt="lambda_scratch"
- You will see the green bar indicating a successful creation.
data:image/s3,"s3://crabby-images/4041a/4041a9c0bfc5283fd027fb2bfaef568ebfd87a66" alt="lambda_start_success"
- We will initially not changed the code.
data:image/s3,"s3://crabby-images/bf031/bf0316da2887b06c6ebaa4c8f1a90ee34d24c8f8" alt="lambda_hello_world"
data:image/s3,"s3://crabby-images/f1c3a/f1c3a2a0aba627676cd2b74c4691856ec086e72e" alt="lambda_hello_world_test"
- The result looks like this.
data:image/s3,"s3://crabby-images/4d84e/4d84e4f5bddf7871370b095bf814a930280c9977" alt="lambda_hello_world_test_result"
Setting up an API Gateway
- We will slightly change the function so that it forms a proper HTTP response.
data:image/s3,"s3://crabby-images/001f0/001f008090a63ca2033e9a43eaa9dd8bae897d61" alt="lambda_api0"
- Under the Designer section, we will ‘Add Trigger’ and select ‘API Gateway’.
data:image/s3,"s3://crabby-images/5ebd1/5ebd126f4b4f5d4926f4a9b2f84c1ab27703c27b" alt="lambda_api1"
data:image/s3,"s3://crabby-images/ddc0b/ddc0b07aeec90ad7012a691555f989554dd4644a" alt="lambda_api2"
- We choose HTTP API and security to be open for the time being.
data:image/s3,"s3://crabby-images/93f21/93f21100f607eb1916b165a2f67fffffe0322581" alt="lambda_api3"
- A block will appear on the designer tab in the Lambda function page.
data:image/s3,"s3://crabby-images/c134c/c134cb1be0ca25a6cdf62cd80989f4ead5a18a4a" alt="lambda_api4"
- Once you click on the API Gateway link provided, you will see the response as expected:
data:image/s3,"s3://crabby-images/f8f50/f8f50118b318ea408cffb92a37f6febb4d23e1ed" alt="lambda_api5"
data:image/s3,"s3://crabby-images/291bc/291bc44ff4470e1c133a7407139c7e9bcd54c31d" alt="lambda_api6"
See this documentation for more details.
Set up a Programmatic User to Access S3
What is IAM? IAM (Identity and Access Management) is a very useful tool for an organization to administer and control access to various resources.
- We will create a programmatic user, similar to the service account in GCP.
What is S3? S3 (Simple Storage Service) is a very popular service used by many large and small companies and individuals.
- For example, a typical data science work flow may involve ETL work on databases (such as Amazon Redshift) and then storing outputs on S3.
Start with finding the IAM service.
data:image/s3,"s3://crabby-images/bd77a/bd77abbae148aedcffbcf930ef36387224e8711e" alt="iam"
- Click on create a new user.
data:image/s3,"s3://crabby-images/f8ed6/f8ed6e069792f08da221d65b5fd90fa6a98a4679" alt="iam1"
- We will make this user have programmatic access (for example via Python later on).
data:image/s3,"s3://crabby-images/940c0/940c09f4a8035958b0acf367e8573adda669b992" alt="iam2"
- For now, we let the user have full read and write access to S3.
data:image/s3,"s3://crabby-images/e2127/e2127ebf2b552f3d183d875ee1107ed473d2ae5c" alt="iam3"
- Lets review the user setup.
data:image/s3,"s3://crabby-images/4adc2/4adc22a41e8fe33094561825324f5903be1b2ee2" alt="iam4"
- In this step, copy the access key and secret key that will be needed for the programmatic access. They will not be shown again, so store them safely and securely.
data:image/s3,"s3://crabby-images/2fd42/2fd427f739b1e7676ab146dc4e03142994135804" alt="iam5"
- Here is the description of the user we just created.
data:image/s3,"s3://crabby-images/b59d2/b59d284984e80994b87606adaf17dbe1c9b43754" alt="iam6"
Set up AWS CLI
The AWS Command Line Interface (CLI) is a unified tool to manage your AWS services. With just one tool to download and configure, you can control multiple AWS services from the command line and automate them through scripts.
- Head over to https://aws.amazon.com/cli/ and download a suitable installer for your OS.
Install it and open your terminal. If it is in the PATH, you should be able to verify the following:
which aws
#/usr/local/bin/aws #your location could be different.
aws --version
#aws-cli/2.0.45 Python/3.7.4 Darwin/18.6.0 exe/x86_64
Using the access and secret keys to configure aws using the aws configure
command.
data:image/s3,"s3://crabby-images/12652/126523d17abf31e83cc5648c58cda64ca1288876" alt=""
Test S3 access by issing the following commmand: aws s3 ls
$ aws s3 ls
2020-09-03 12:27:48 chicagodatascience-com
2020-09-03 12:02:25 theja-model-store
Instead of programmatically creating a bucket (with the aws s3 mb s3://bucket-name
) we will do it using the GUI below.