

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

# Membangun fungsi Lambda dengan Python
<a name="lambda-python"></a>

Anda bisa menjalankan kode Python di AWS Lambda. Lambda menyediakan [runtime](lambda-runtimes.md) untuk Python yang menjalankan kode Anda untuk memproses peristiwa. Kode Anda berjalan di lingkungan yang menyertakan SDK for Python (Boto3), dengan AWS Identity and Access Management kredensi dari peran (IAM) yang Anda kelola. Untuk mempelajari lebih lanjut tentang versi SDK yang disertakan dengan runtime Python, lihat. [Versi SDK yang disertakan Runtime](#python-sdk-included)

Lambda mendukung runtime Python berikut.


| Nama | Pengidentifikasi | Sistem operasi | Tanggal pengusangan | Buat fungsi blok | Pembaruan fungsi blok | 
| --- | --- | --- | --- | --- | --- | 
|  Python 3.14  |  `python3.14`  |  Amazon Linux 2023  |   30 Jun 2029   |   31 Jul 2029   |   Agustus 31, 2029   | 
|  Python 3.13  |  `python3.13`  |  Amazon Linux 2023  |   30 Jun 2029   |   31 Jul 2029   |   Agustus 31, 2029   | 
|  Python 3.12  |  `python3.12`  |  Amazon Linux 2023  |   Okt 31, 2028   |   Nov 30, 2028   |   10 Jan 2029   | 
|  Python 3.11  |  `python3.11`  |  Amazon Linux 2  |   30 Jun 2027   |   31 Jul 2027   |   Agustus 31, 2027   | 
|  Python 3.10  |  `python3.10`  |  Amazon Linux 2  |   Okt 31, 2026   |   Nov 30, 2026   |   15 Jan 2027   | 

**Untuk membuat fungsi Python**

1. Buka [Konsol Lambda](https://console.aws.amazon.com/lambda).

1. Pilih **Buat fungsi**.

1. Konfigurasikan pengaturan berikut:
   + **Nama fungsi**: Masukkan nama untuk fungsi tersebut.
   + **Runtime**: Pilih **Python 3.14**.

1. Pilih **Buat fungsi**.

Konsol membuat fungsi Lambda dengan satu file sumber bernama `lambda_function`. Anda dapat mengedit file ini dan menambahkan lebih banyak file di editor kode bawaan. Di bagian **DEPLOY**, pilih **Deploy** untuk memperbarui kode fungsi Anda. Kemudian, untuk menjalankan kode Anda, pilih **Create test event** di bagian **TEST EVENTS**.

Fungsi Lambda Anda dilengkapi dengan grup CloudWatch log Log. Runtime fungsi mengirimkan detail tentang setiap invokasi ke CloudWatch Logs. Detail tersebut menyampaikan [log yang dihasilkan fungsi Anda](python-logging.md) selama invokasi. Jika fungsi mengembalikan kesalahan, Lambda memformat kesalahan dan mengembalikannya ke pemanggil.

**Topics**
+ [Versi SDK yang disertakan Runtime](#python-sdk-included)
+ [Fitur Python dinonaktifkan](#python-disabled-features)
+ [Format respons](#python-response-format)
+ [Shutdown anggun untuk ekstensi](#python-graceful-shutdown)
+ [Tentukan penangan fungsi Lambda dengan Python](python-handler.md)
+ [Bekerja dengan arsip file.zip untuk fungsi Python Lambda](python-package.md)
+ [Deploy fungsi Lambda Python dengan gambar kontainer](python-image.md)
+ [Bekerja dengan lapisan untuk fungsi Lambda Python](python-layers.md)
+ [Menggunakan objek konteks Lambda untuk mengambil informasi fungsi Python](python-context.md)
+ [Log dan pantau fungsi Python Lambda](python-logging.md)
+ [AWS Lambda pengujian fungsi dengan Python](python-testing.md)
+ [Menginstrumentasi kode Python di AWS Lambda](python-tracing.md)

## Versi SDK yang disertakan Runtime
<a name="python-sdk-included"></a>

Versi AWS SDK yang disertakan dalam runtime Python bergantung pada versi runtime dan versi Anda. Wilayah AWS Untuk menemukan versi SDK yang disertakan dalam runtime yang Anda gunakan, buat fungsi Lambda dengan kode berikut.

```
import boto3
import botocore

def lambda_handler(event, context):
   print(f'boto3 version: {boto3.__version__}')
   print(f'botocore version: {botocore.__version__}')
```

## Fitur Python dinonaktifkan
<a name="python-disabled-features"></a>

Tabel berikut mencantumkan fitur Python yang dinonaktifkan di runtime terkelola Lambda dan gambar dasar kontainer untuk Python. Fitur-fitur ini harus diaktifkan ketika runtime Python executable dikompilasi dan tidak dapat diaktifkan dengan menggunakan flag eksekusi waktu. [[Untuk menggunakan fitur-fitur ini di Lambda, Anda dapat menerapkan build runtime Python Anda sendiri dengan fitur ini diaktifkan, menggunakan gambar kontainer atau runtime khusus.](runtimes-custom.md)](python-image.md#python-image-clients)


| Fitur Python | Versi Python yang terpengaruh | Status | 
| --- | --- | --- | 
| Just-in-Time (JIT) kompiler | Python 3.13 dan yang lebih baru | Kompiler JIT bersifat eksperimental dan tidak direkomendasikan untuk beban kerja produksi. Oleh karena itu dinonaktifkan di runtime Lambda Python. | 
| Threading gratis | Python 3.13 dan yang lebih baru | Threading gratis (opsi untuk menonaktifkan kunci interpreter global) dinonaktifkan di build Lambda Python karena dampak kinerja pada kode single-threaded. | 

## Format respons
<a name="python-response-format"></a>

Dalam Python 3.12 dan runtime Python yang lebih baru, fungsi mengembalikan karakter Unicode sebagai bagian dari respons JSON mereka. Runtime Python sebelumnya mengembalikan urutan yang lolos untuk karakter Unicode dalam tanggapan. Misalnya, dalam Python 3.11, jika Anda mengembalikan string Unicode seperti "こんにちは“, itu lolos dari karakter Unicode dan mengembalikan “\$1 u3053\$1 u3093\$1 u306b\$1 u3061\$1 u306f”. Runtime Python 3.12 mengembalikan yang asli "”. こんにちは

Menggunakan respons Unicode mengurangi ukuran respons Lambda, membuatnya lebih mudah untuk memasukkan respons yang lebih besar ke dalam ukuran muatan maksimum 6 MB untuk fungsi sinkron. Pada contoh sebelumnya, versi escaped adalah 32 byte — dibandingkan dengan 17 byte dengan string Unicode.

Saat Anda meningkatkan ke Python 3.12 atau yang lebih baru runtime Python, Anda mungkin perlu menyesuaikan kode Anda untuk memperhitungkan format respons baru. Jika pemanggil mengharapkan Unicode lolos, Anda harus menambahkan kode ke fungsi kembali untuk melarikan diri dari Unicode secara manual, atau menyesuaikan pemanggil untuk menangani pengembalian Unicode.

## Shutdown anggun untuk ekstensi
<a name="python-graceful-shutdown"></a>

[Python 3.12 dan runtime Python yang lebih baru menawarkan kemampuan shutdown anggun yang ditingkatkan untuk fungsi dengan ekstensi eksternal.](lambda-extensions.md) Ketika Lambda mematikan lingkungan eksekusi, ia mengirimkan `SIGTERM` sinyal ke runtime dan kemudian `SHUTDOWN` peristiwa ke setiap ekstensi eksternal terdaftar. Anda dapat menangkap `SIGTERM` sinyal dalam fungsi Lambda Anda dan membersihkan sumber daya seperti koneksi database yang dibuat oleh fungsi tersebut.

Untuk mempelajari lebih lanjut tentang siklus hidup lingkungan eksekusi, lihat. [Memahami siklus hidup lingkungan pelaksanaan Lambda](lambda-runtime-environment.md) Untuk contoh cara menggunakan shutdown anggun dengan ekstensi, lihat Repositori [AWS Sampel GitHub ](https://github.com/aws-samples/graceful-shutdown-with-aws-lambda).