Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

(aws_lambda_python_alpha): Docker build happens at import time rather than synth/deploy time #27991

Open
anentropic opened this issue Nov 14, 2023 · 5 comments
Labels
@aws-cdk/aws-ecr-assets Related to AWS CDK Docker Image Assets @aws-cdk/aws-lambda Related to AWS Lambda @aws-cdk/aws-lambda-python bug This issue is a bug. p2

Comments

@anentropic
Copy link

anentropic commented Nov 14, 2023

Describe the bug

I have a python cdk codebase

I added a aws_lambda_python_alpha.PythonFunction to my stack... now as soon as I instantiate the stack containing that Lambda, a docker build gets triggered

Expected Behavior

I would expect that docker build for the Lambda function would only occur during deployment, or at worst during synth phase

docker build at import time feels like a bug

Current Behavior

the docker build occurs at the point that the aws_lambda_python_alpha.PythonFunction gets instantiated

so it happens just by importing the code

in particular it happens when I run unit tests for the cdk codebase, which instantiate a version of the stack multiple times

a) makes my tests very slow 😢
b) it's also noisy - it prints a bunch of output to stderr:

#0 building with "desktop-linux" instance using docker driver

#1 [internal] load .dockerignore
#1 transferring context: 2B done
#1 DONE 0.0s

#2 [internal] load build definition from Dockerfile
#2 transferring dockerfile: 1.35kB done
#2 DONE 0.0s

#3 [internal] load metadata for public.ecr.aws/sam/build-python3.11:latest
#3 DONE 0.2s

#4 [1/2] FROM public.ecr.aws/sam/build-python3.11@sha256:1468e6000e3d406ab5b32e82ba3358440faf75398eef30aa997e2c8e4ad85b07
#4 DONE 0.0s

#5 [2/2] RUN     python -m venv /usr/app/venv &&     mkdir /tmp/pip-cache &&     chmod -R 777 /tmp/pip-cache &&     pip install --upgrade pip &&     mkdir /tmp/poetry-cache &&     chmod -R 777 /tmp/poetry-cache &&     pip install pipenv==2022.4.8 poetry==1.5.1 &&     rm -rf /tmp/pip-cache/* /tmp/poetry-cache/*
#5 CACHED

#6 exporting to image
#6 exporting layers done
#6 writing image sha256:e1b922db4e93213d2e2d81648a4527a255153724fb3bee8c5d60b52414d89c12 done
#6 naming to docker.io/library/cdk-db7ab25e39b5606291af96999b213f4ca620fbee93139bb8d158e76572cf1431 done
#6 DONE 0.0s

What's Next?
  View a summary of image vulnerabilities and recommendations → docker scout quickview
Bundling asset Website/Repro Lambda/Code/Stage...
WARNING: The requested image's platform (linux/amd64) does not match the detected host platform (linux/arm64/v8) and no specific platform was requested
sending incremental file list
index.py
requirements.txt

sent 227 bytes  received 54 bytes  562.00 bytes/sec
total size is 45  speedup is 0.16

Reproduction Steps

app.py

from aws_cdk import (
    App,
    Environment,
    Stack,
    aws_lambda,
    aws_lambda_python_alpha as python_lambda,
)
from constructs import Construct


class Website(Stack):
    def __init__(
        self,
        scope: Construct,
        id: str,
        **kwargs,
    ):
        super().__init__(scope, id)

        # if I drop into debugger from tests, docker build occurs here:
        python_lambda.PythonFunction(
            self,
            "Repro Lambda",
            entry="infra/assets/repro/src",
            runtime=aws_lambda.Runtime.PYTHON_3_11,
        )

app = App()

Website(
    app,
    "Website",
    env=Environment(
        account="000000000000",  # or a valid account
        region="eu-west-1",
    ),
)

if __name__ == "__main__":
    app.synth()

infra/assets/repro/src/index.py

def handler(event, context):
    return True

infra/assets/repro/src/requirements.txt (empty file)

Possible Solution

No response

Additional Information/Context

No response

CDK CLI Version

2.106.1 (build a2e5f65)

Framework Version

2.108.0

Node.js Version

v18.18.0

OS

macOS 14.1

Language

Python

Language Version

3.11.5

Other information

No response

@anentropic anentropic added bug This issue is a bug. needs-triage This issue or PR still needs to be triaged. labels Nov 14, 2023
@anentropic
Copy link
Author

TBH I'd love to be able to run the tests without needing docker at all ...I don't see why it should be needed until doing the actual deployment

@indrora
Copy link
Contributor

indrora commented Nov 14, 2023

You're right, this should happen at synth time (or just before).

It doesn't look like there's a good workaround to keep this from happening other than not importing a package, but that's not feasible. However, I don't know how wide the effect of this is; if other customers have serious issues with this happening, we can probably raise it from p2 to p1.

@indrora indrora added p2 @aws-cdk/aws-lambda Related to AWS Lambda @aws-cdk/aws-ecr-assets Related to AWS CDK Docker Image Assets and removed needs-triage This issue or PR still needs to be triaged. labels Nov 14, 2023
@anentropic
Copy link
Author

I was able to reproduce it with the minimal code above, so I guess others should be able to too

and if not maybe we have a clue about if there's something weird on my end (I haven't tried to do anything weird, but who knows)

@tmokmss
Copy link
Contributor

tmokmss commented Nov 15, 2023

One possible solution can be to make BundingOptions.image lazy, i.e. something like getImage: () => DockerImage. and then call the lazy function when a bundling actually happens to get a build image.

export interface BundlingOptions {
/**
* The Docker image where the command will run.
*/
readonly image: DockerImage;

We need to find a way to introduce such change without breaking something. I'm willing to work on this :)

@anentropic
Copy link
Author

The thing that makes this situation even more annoying is that it doesn't appear to use any caching from the Docker engine... every time I run any cdk command on my stack it has to go and build the docker images from scratch

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
@aws-cdk/aws-ecr-assets Related to AWS CDK Docker Image Assets @aws-cdk/aws-lambda Related to AWS Lambda @aws-cdk/aws-lambda-python bug This issue is a bug. p2
Projects
None yet
Development

No branches or pull requests

3 participants