Terjemahan disediakan oleh mesin penerjemah. Jika konten terjemahan yang diberikan bertentangan dengan versi bahasa Inggris aslinya, utamakan versi bahasa Inggris.
Menangani keunikan dengan Lambda SnapStart
Saat pemanggilan ditingkatkan pada suatu SnapStart fungsi, Lambda menggunakan satu snapshot yang diinisialisasi untuk melanjutkan beberapa lingkungan eksekusi. Jika kode inisialisasi Anda menghasilkan konten unik yang disertakan dalam snapshot, maka konten tersebut mungkin tidak unik saat digunakan kembali di seluruh lingkungan eksekusi. Untuk mempertahankan keunikan saat menggunakan SnapStart, Anda harus menghasilkan konten unik setelah inisialisasi. Ini termasuk rahasia unikIDs, unik, dan entropi yang digunakan untuk menghasilkan pseudorandomness.
Kami merekomendasikan praktik terbaik berikut untuk membantu Anda mempertahankan keunikan dalam kode Anda. Untuk fungsi Java, Lambda juga menyediakan alat SnapStart pemindaian sumber terbuka untuk membantu memeriksa kode yang mengasumsikan keunikan. Jika Anda menghasilkan data unik selama fase inisialisasi, maka Anda dapat menggunakan kait runtime untuk mengembalikan keunikan. Dengan runtime hooks, Anda dapat menjalankan kode tertentu segera sebelum Lambda mengambil snapshot atau segera setelah Lambda melanjutkan fungsi dari snapshot.
Hindari menyimpan status yang bergantung pada keunikan selama inisialisasi
Selama fase inisialisasi fungsi Anda, hindari caching data yang dimaksudkan untuk menjadi unik, seperti membuat ID unik untuk pencatatan atau pengaturan benih untuk fungsi acak. Sebagai gantinya, kami menyarankan Anda membuat data unik atau menetapkan seed untuk fungsi acak di dalam penangan fungsi Anda—atau menggunakan hook runtime.
Contoh-contoh berikut ini mendemonstrasikan cara menghasilkan fungsi handler. UUID
Gunakan generator nomor pseudorandom yang aman secara kriptografis () CSPRNGs
Jika aplikasi Anda bergantung pada keacakan, kami sarankan Anda menggunakan generator nomor acak yang aman secara kriptografis (). CSPRNGs Selain Open SSL 1.0.2, runtime terkelola Lambda juga menyertakan built-in berikut: CSPRNGs
-
Jawa:
java.security.SecureRandom
-
Python:
SystemRandom
-
.NET:
System.Security.Cryptography.RandomNumberGenerator
Perangkat lunak yang selalu mendapatkan angka acak dari /dev/random
atau /dev/urandom
juga mempertahankan keacakan dengan SnapStart.
AWS pustaka kriptografi secara otomatis mempertahankan keacakan dengan SnapStart memulai dengan versi minimum yang ditentukan dalam tabel berikut. Jika Anda menggunakan pustaka ini dengan fungsi Lambda, pastikan Anda menggunakan versi minimum berikut atau versi yang lebih baru:
Perpustakaan | Versi minimum yang didukung (x86) | Versi minimum yang didukung (ARM) |
---|---|---|
AWS libcrypto (AWS-LC) |
1.16.0 |
1.30.0 |
AWS libcrypto FIPS |
2.0.13 |
2.0.13 |
Jika Anda mengemas pustaka kriptografi sebelumnya dengan fungsi Lambda Anda sebagai dependensi transitif melalui pustaka berikut, pastikan Anda menggunakan versi minimum berikut atau versi yang lebih baru:
Perpustakaan | Versi minimum yang didukung (x86) | Versi minimum yang didukung (ARM) |
---|---|---|
AWS SDK for Java 2.x |
2.23.20 |
2.26.12 |
AWS Runtime Umum untuk Java |
0.29.8 |
0.29.25 |
Amazon Corretto Provider |
2.4.1 |
2.4.1 |
Penyedia Crypto Amazon Corretto FIPS |
2.4.1 |
2.4.1 |
Contoh berikut menunjukkan cara menggunakan CSPRNGs untuk menjamin urutan nomor unik bahkan ketika fungsi dipulihkan dari snapshot.
SnapStart alat pemindaian (hanya Java)
Lambda menyediakan alat pemindaian untuk Java untuk membantu Anda memeriksa kode yang mengasumsikan keunikan. Alat SnapStart pemindaian adalah SpotBugs
Untuk mempelajari lebih lanjut tentang menangani keunikan dengan SnapStart, lihat Memulai lebih cepat dengan AWS Lambda SnapStart