How to Use Custom Python Modules: AWS Lambda

How to Use Custom Python Modules: AWS Lambda

In this blog, we will see how to use custom Python modules in our AWS Lambda function.


AWS Lambda is a serverless compute service that lets you run code without provisioning or managing servers, creating workload-aware cluster scaling logic, maintaining event integrations, or managing runtimes. You can write Lambda functions in your favorite language (Node.js, Python, Go, Java, and more) and use both serverless and container tools to build, test, and deploy your functions.

By default, Lambda provides few additional modules (like json, boto3, botocore, pip, python-dateutil, and so on) in addition to Standard Python Library. But, this is not always sufficient and we might need few other packages like the Pandas module, mysql, snowflake, and so on.

To cater to this, the user needs to apply layers in the Lambda function.

Assuming we want to use the Pandas module in our Lambda function, let's go ahead and apply layers to our Lambda function to use Pandas in our code.

Steps:

1.????Create an Amazon Linux instance and check the Python version on this Ec2 instance. [ Optional — Upgrade or degrade to specific Python version based on your need ]

2.??Download necessary packages (pandas for our use-case) and create a zip

3.???Upload the zip to the S3 bucket

4.??Create Lambda function (Choose the same Python version used on Amazon Linux instance)

5.???Apply the layer to the Lambda function

6.??Import the Pandas library in the code and do a test run.

?

Step-By-Step

Step 1: Create an Amazon Linux instance and log in to the EC2 instance to run the below commands.

?

mkdir Demo

cd Demo

Install the necessary packages in the Python folder using the below command.

pip3 install pandas -t .

rm -rf *.dist-info

Step 2: Move to the parent directory and zip the Python directory. (Note: Zip should have a Python directory).

zip -r pandas_layer.zip .

Step 3: Create an S3 bucket (if not already available) and upload the zip file created in Step 2.?(Note: For our use-case, we have created an S3 bucket named python-demo-pandas where we would be uploading this zip file)

aws s3 cp pandas_layer.zip s3:// python-demo-pandas/

No alt text provided for this image

Step 4: Create lambda function from AWS Console and select the correct Python version which was also used in the Amazon Linux instance. This is because sometimes modules are not compatible and you might face issues while using these modules in Lambda function.

?Step 5: Create layers for Lambda from AWS Console

No alt text provided for this image


Go to the Lambda function to which the layer has to be applied. Click on layers (highlighted in the black box in the below screen-shot) which will redirect to the section where you could add layers.

No alt text provided for this image


Click on the ‘Add layer’ button to add layers

No alt text provided for this image


Select ‘Custom layers’ and from the drop-down, select your layer (‘python-pandas-demo’)

No alt text provided for this image

Step 6?: Import the pandas library in code and do test run to see if it is working fine

No alt text provided for this image

Test Execution is successful, which indicates the layer has been applied correctly.

No alt text provided for this image

要查看或添加评论,请登录

sumit potdar的更多文章

社区洞察

其他会员也浏览了