Skip to content

Latest commit

 

History

History
133 lines (101 loc) · 4.96 KB

aws_lambda.md

File metadata and controls

133 lines (101 loc) · 4.96 KB

Lithops on AWS Lambda

Lithops with AWS Lambda as serverless compute backend.

Installation

  1. Install Amazon Web Services backend dependencies:
$ python3 -m pip install lithops[aws]
  1. Login to Amazon Web Services Console (or signup if you don't have an account)

  2. Navigate to IAM > Policies. Click on Create policy.

  3. Select JSON tab and paste the following JSON policy:

{
    "Version": "2012-10-17",
    "Statement": [
        {
            "Sid": "VisualEditor0",
            "Effect": "Allow",
            "Action": [
                "s3:*",
                "lambda:*",
                "ec2:*",
                "ecr:*",
                "sts:GetCallerIdentity"
            ],
            "Resource": "*"
        }
    ]
}
  1. Click Next: Tags and Next: Review. Fill the policy name field (you can name it lithops-policy or simmilar) and create the policy.

  2. Go back to IAM and navigate to Roles tab. Click Create role.

  3. Choose Lambda on the use case list and click Next: Permissions. Select the policy created before (lithops-policy). Click Next: Tags and Next: Review. Type a role name, for example lithops-execution-role. Click on Create Role.

Configuration

  1. Edit your lithops config and add the following keys:
    lithops:
        backend: aws_lambda

    aws:
        access_key_id: <ACCESS_KEY_ID>
        secret_access_key: <SECRET_ACCESS_KEY>
        #account_id: <ACCOUNT_ID>  # Optional

    aws_lambda:
        execution_role: <EXECUTION_ROLE_ARN>
        region_name: <REGION_NAME>

Summary of configuration keys for AWS:

AWS:

Group Key Default Mandatory Additional info
aws access_key_id yes Account access key to AWS services. To find them, navigate to My Security Credentials and click Create Access Key if you don't already have one.
aws secret_access_key yes Account secret access key to AWS services. To find them, navigate to My Security Credentials and click Create Access Key if you don't already have one.
aws account_id no *This field will be used if present to retrieve the account ID instead of using AWS STS. The account ID is used to format full image names for container runtimes.

AWS Lambda:

Group Key Default Mandatory Additional info
aws_lambda region_name yes Region where the S3 bucket is located and where Lambda functions will be invoked (e.g. us-east-1)
aws_lambda execution_role yes ARN of the execution role created at step 3. You can find it in the Role page at the Roles list in the IAM section (e.g. arn:aws:iam::1234567890:role/lithops-role
aws_lambda runtime no Docker image name
aws_lambda runtime_memory 256 no Memory limit in MB. Default 256MB
aws_lambda runtime_timeout 180 no Runtime timeout in seconds. Default 3 minutes
aws_lambda invoke_pool_threads 64 no Number of concurrent threads used for invocation

Additional configuration

VPC

To connect the Lithops lambda to a VPC, add the following configuration to the aws_lambda configuration section:

    aws_lambda:
        execution_role: <EXECUTION_ROLE_ARN>
        region_name: <REGION_NAME>
        vpc:
            subnets:
                - <SUBNET_ID_1>
                - <SUBNET_ID_2>
                ...
            security_groups:
                - <SECURITY_GROUP_1>
                - <SECURITY_GROUP_2>
                ...
  • subnets: A list of VPC subnet IDs.
  • security_groups: A list of VPC security groups IDs.

Note: To be able to create netwrok interfaces for Lambda functions, the role created in step 3 has to have permissions to do so, for example by adding the permission EC2FullAccess.

For more information, check out AWS documentation on VPCs.

EFS

To attach EFS volumes to the Lithops lambda, add the following configuration to the aws_lambda configuration section:

    aws_lambda:
        execution_role: <EXECUTION_ROLE_ARN>
        region_name: <REGION_NAME>
        vpc:
            ...
        efs:
            - access_point: <EFS_ACCESS_POINT_1>
              mount_path: <LAMBDA_VOLUME_MOUNT_PATH_1>
            - access_point: <EFS_ACCESS_POINT_2>
              mount_path: <LAMBDA_VOLUME_MOUNT_PATH_2>
            ...
  • access_point: The Amazon Resource Name (ARN) of the Amazon EFS access point that provides access to the file system.
  • mount_path: The path where the function can access the file system. It must start with /mnt.

Note: to access those volumes, the Lithops lambda has to be connected to the same VPC and subnets as the EFS volumes are mounted to.

For more information, check out AWS documentation on attaching EFS volumes to Lambda.