View a markdown version of this page

Runtime yang didukung untuk fungsi yang tahan lama - AWS Lambda

Terjemahan disediakan oleh mesin penerjemah. Jika konten terjemahan yang diberikan bertentangan dengan versi bahasa Inggris aslinya, utamakan versi bahasa Inggris.

Runtime yang didukung untuk fungsi yang tahan lama

Fungsi tahan lama tersedia untuk runtime terkelola yang dipilih dan gambar kontainer OCI untuk fleksibilitas versi runtime tambahan. Anda dapat membuat fungsi tahan lama untuk Node.js, Python, dan Java menggunakan runtime terkelola langsung di konsol atau melalui program. infrastructure-as-code

Runtime terkelola Lambda

Runtime terkelola berikut mendukung fungsi tahan lama saat Anda membuat fungsi di konsol Lambda atau menggunakan parameter AWS CLI with--durable-config '{"ExecutionTimeout": 3600, "RetentionPeriodInDays": 7}'. Untuk informasi selengkapnya tentang runtime Lambda, lihat runtime Lambda.

Bahasa Waktu Aktif
Node.js nodejs22.x
Node.js nodejs24.x
Python python3.13
Python python3.14
Java java17
Java java21
Java java25
catatan

Lambda Node.js dan runtime Python menyertakan SDK eksekusi yang tahan lama untuk pengujian dan pengembangan. Namun, sebaiknya sertakan SDK dalam paket penerapan Anda untuk produksi. Ini memastikan konsistensi versi dan menghindari kemungkinan pembaruan runtime yang mungkin memengaruhi perilaku fungsi Anda. Karena Java adalah bahasa yang dikompilasi, runtime Lambda Java tidak menyertakan SDK eksekusi yang tahan lama, sehingga harus disertakan dalam paket penerapan Anda.

Node.js

Instal SDK di proyek Node.js Anda:

npm install @aws/durable-execution-sdk-js

SDK mendukung JavaScript dan TypeScript. Untuk TypeScript proyek, SDK menyertakan definisi tipe.

Python

Instal SDK di proyek Python Anda:

pip install aws-durable-execution-sdk-python

Python SDK menggunakan metode sinkron dan tidak memerlukan. async/await

Java

Tambahkan ketergantungan kepom.xml:

<dependency> <groupId>software.amazon.lambda.durable</groupId> <artifactId>aws-durable-execution-sdk-java</artifactId> <version>VERSION</version> </dependency>

Instal SDK di proyek Java Anda:

mvn install

Java SDK menyediakan versi sinkron dan asinkron dari setiap metode.

Image kontainer

Anda dapat menggunakan fungsi tahan lama dengan gambar kontainer untuk mendukung versi runtime tambahan atau konfigurasi runtime khusus. Gambar kontainer memungkinkan Anda menggunakan versi runtime yang tidak tersedia sebagai runtime terkelola atau menyesuaikan lingkungan runtime Anda.

Untuk membuat fungsi tahan lama menggunakan gambar kontainer:

  1. Buat Dockerfile berdasarkan gambar dasar Lambda

  2. Instal SDK eksekusi tahan lama di container Anda

  3. Buat dan dorong gambar kontainer ke Amazon Elastic Container Registry

  4. Buat fungsi Lambda dari image container dengan eksekusi tahan lama diaktifkan

Contoh kontainer

Buat Dockerfile:

Python

Buat Dockerfile untuk Python 3.11:

FROM public.ecr.aws/lambda/python:3.11 # Copy requirements file COPY requirements.txt ${LAMBDA_TASK_ROOT}/ # Install dependencies including durable SDK RUN pip install -r requirements.txt # Copy function code COPY lambda_function.py ${LAMBDA_TASK_ROOT}/ # Set the handler CMD [ "lambda_function.handler" ]

Buat requirements.txt file:

aws-durable-execution-sdk-python
Java

Buat Dockerfile untuk Java 25:

FROM --platform=linux/amd64 public.ecr.aws/lambda/java:25 # Install Maven RUN dnf install -y maven WORKDIR /var/task # Copy Maven configuration and source code COPY pom.xml . COPY src ./src # Build RUN mvn clean package -DskipTests # Move JAR to lib directory RUN mv target/*.jar lib/ # Set the handler CMD ["src.path.to.lambdaFunction::handler"]

Bangun dan dorong gambar:

# Build the image docker build -t my-durable-function . # Tag for ECR docker tag my-durable-function:latest 123456789012.dkr.ecr.us-east-1.amazonaws.com/my-durable-function:latest # Push to ECR docker push 123456789012.dkr.ecr.us-east-1.amazonaws.com/my-durable-function:latest

Buat fungsi dengan eksekusi tahan lama diaktifkan:

aws lambda create-function \ --function-name myDurableFunction \ --package-type Image \ --code ImageUri=123456789012.dkr.ecr.us-east-1.amazonaws.com/my-durable-function:latest \ --role arn:aws:iam::123456789012:role/lambda-execution-role \ --durable-config '{"ExecutionTimeout": 3600, "RetentionPeriodInDays": 7}'

Untuk informasi selengkapnya tentang penggunaan gambar kontainer dengan Lambda, lihat Membuat gambar kontainer Lambda di Panduan Pengembang Lambda.

Pertimbangan runtime

Manajemen versi SDK: Sertakan SDK eksekusi tahan lama dalam paket penerapan atau image kontainer Anda. Ini memastikan fungsi Anda menggunakan versi SDK tertentu dan tidak terpengaruh oleh pembaruan runtime. Sematkan versi SDK di package.json atau requirements.txt untuk mengontrol saat Anda memutakhirkan.

Pembaruan runtime: AWS memperbarui runtime terkelola untuk menyertakan patch keamanan dan perbaikan bug. Pembaruan ini mungkin termasuk versi SDK baru. Untuk menghindari perilaku yang tidak terduga, sertakan SDK dalam paket penerapan Anda dan uji secara menyeluruh sebelum menerapkan ke produksi.

Ukuran gambar kontainer: Gambar kontainer memiliki ukuran maksimum yang tidak terkompresi 10 GB. SDK eksekusi yang tahan lama menambahkan ukuran minimal pada gambar Anda. Optimalkan penampung Anda dengan menggunakan build multi-tahap dan menghapus dependensi yang tidak perlu.

Kinerja awal dingin: Gambar kontainer mungkin memiliki waktu mulai dingin yang lebih lama daripada runtime yang dikelola. SDK eksekusi yang tahan lama memiliki dampak minimal pada kinerja start dingin. Gunakan konkurensi yang disediakan jika latensi start dingin sangat penting untuk aplikasi Anda.