Terjemahan disediakan oleh mesin penerjemah. Jika konten terjemahan yang diberikan bertentangan dengan versi bahasa Inggris aslinya, utamakan versi bahasa Inggris.
Menggunakan Lambda dengan Amazon SQS
Anda dapat menggunakan fungsi Lambda untuk memproses pesan dalam antrean Amazon Simple Queue Service (AmazonSQS). Lambda mendukung antrian standar dan antrianfirst-in, first-out (FIFO) untuk pemetaan sumber acara. Fungsi Lambda dan SQS antrian Amazon harus sama Wilayah AWS, meskipun bisa berbeda. Akun AWS
Topik
- Memahami perilaku polling dan batching untuk pemetaan sumber SQS acara Amazon
- Contoh acara pesan antrian standar
- Contoh FIFO acara pesan antrian
- Membuat dan mengonfigurasi pemetaan sumber SQS peristiwa Amazon
- Mengonfigurasi perilaku penskalaan untuk pemetaan SQS sumber peristiwa
- Menangani kesalahan untuk sumber SQS peristiwa di Lambda
- Parameter Lambda untuk pemetaan sumber SQS acara Amazon
- Menggunakan pemfilteran acara dengan sumber SQS acara Amazon
- Tutorial: Menggunakan Lambda dengan Amazon SQS
- Tutorial: Menggunakan SQS antrian Amazon lintas akun sebagai sumber acara
Memahami perilaku polling dan batching untuk pemetaan sumber SQS acara Amazon
Dengan pemetaan sumber SQS kejadian Amazon, Lambda melakukan polling pada antrean dan memanggil fungsi Anda secara sinkron dengan kejadian. Setiap acara dapat berisi sekumpulan beberapa pesan dari antrian. Lambda menerima kejadian ini satu batch pada satu waktu, dan memanggil fungsi Anda satu kali untuk setiap batch. Ketika fungsi Anda berhasil memproses suatu batch, Lambda menghapus pesannya dari antrean.
Ketika Lambda menerima batch, pesan tetap berada dalam antrean, tetapi tersembunyi selama batas waktu visibilitas antrean. Jika fungsi Anda berhasil memproses semua pesan dalam batch, Lambda menghapus pesan dari antrean. Secara default, jika fungsi Anda mengalami kesalahan saat memproses batch, semua pesan dalam kumpulan tersebut akan terlihat lagi dalam antrian setelah batas waktu visibilitas berakhir. Untuk alasan ini, kode fungsi Anda harus dapat memproses pesan yang sama beberapa kali tanpa efek samping yang tidak diinginkan.
Awas
Pemetaan sumber peristiwa Lambda memproses setiap peristiwa setidaknya sekali, dan pemrosesan duplikat catatan dapat terjadi. Untuk menghindari potensi masalah yang terkait dengan duplikat peristiwa, kami sangat menyarankan agar Anda membuat kode fungsi Anda idempoten. Untuk mempelajari lebih lanjut, lihat Bagaimana cara membuat fungsi Lambda saya idempoten
Untuk mencegah Lambda memproses pesan beberapa kali, Anda dapat mengonfigurasi pemetaan sumber peristiwa untuk menyertakan kegagalan item batch dalam respons fungsi Anda, atau Anda dapat menggunakan DeleteMessageAPIuntuk menghapus pesan dari antrian karena fungsi Lambda berhasil memprosesnya.
Untuk informasi selengkapnya tentang parameter konfigurasi yang didukung Lambda untuk pemetaan sumber SQS peristiwa, lihat. Membuat pemetaan sumber SQS acara
Contoh acara pesan antrian standar
contoh Kejadian SQS pesan Amazon (antrean standar)
{ "Records": [ { "messageId": "059f36b4-87a3-44ab-83d2-661975830a7d", "receiptHandle": "AQEBwJnKyrHigUMZj6rYigCgxlaS3SLy0a...", "body": "Test message.", "attributes": { "ApproximateReceiveCount": "1", "SentTimestamp": "1545082649183", "SenderId": "AIDAIENQZJOLO23YVJ4VO", "ApproximateFirstReceiveTimestamp": "1545082649185" }, "messageAttributes": { "myAttribute": { "stringValue": "myValue", "stringListValues": [], "binaryListValues": [], "dataType": 'String' } }, "md5OfBody": "e4e68fb7bd0e697a0ae8f1bb342846b3", "eventSource": "aws:sqs", "eventSourceARN": "arn:aws:sqs:us-east-2:123456789012:my-queue", "awsRegion": "us-east-2" }, { "messageId": "2e1424d4-f796-459a-8184-9c92662be6da", "receiptHandle": "AQEBzWwaftRI0KuVm4tP+/7q1rGgNqicHq...", "body": "Test message.", "attributes": { "ApproximateReceiveCount": "1", "SentTimestamp": "1545082650636", "SenderId": "AIDAIENQZJOLO23YVJ4VO", "ApproximateFirstReceiveTimestamp": "1545082650649" }, "messageAttributes": {}, "md5OfBody": "e4e68fb7bd0e697a0ae8f1bb342846b3", "eventSource": "aws:sqs", "eventSourceARN": "arn:aws:sqs:us-east-2:123456789012:my-queue", "awsRegion": "us-east-2" } ] }
Secara default, Lambda melakukan polling hingga 10 pesan dalam antrean Anda sekaligus dan mengirim batch tersebut ke fungsi Anda. Untuk menghindari invokasi fungsi dengan sejumlah kecil rekaman, Anda dapat mengonfigurasikan sumber kejadian untuk melakukan buffer rekaman selama hingga 5 menit dengan mengonfigurasikan jendela batch. Sebelum memanggil fungsi, Lambda terus melakukan polling pesan dari antrean standar hingga jendela batch kedaluwarsa, kuota ukuran payload invokasi tercapai, atau ukuran batch maksimum yang dikonfigurasi tercapai.
Jika Anda menggunakan jendela batch dan SQS antrian Anda berisi lalu lintas yang sangat rendah, Lambda mungkin menunggu hingga 20 detik sebelum menjalankan fungsi Anda. Ini benar bahkan jika Anda mengatur jendela batch lebih rendah dari 20 detik.
catatan
Di Java, Anda mungkin mengalami kesalahan pointer null saat deserialisasi. JSON Ini bisa jadi karena bagaimana kasus “Records” dan "eventSourceARN" dikonversi oleh JSON object mapper.
Contoh FIFO acara pesan antrian
Untuk FIFO antrean, rekaman berisi atribut tambahan yang terkait dengan deduplikasi dan pengurutan.
contoh Acara SQS pesan Amazon (FIFOantrian)
{ "Records": [ { "messageId": "11d6ee51-4cc7-4302-9e22-7cd8afdaadf5", "receiptHandle": "AQEBBX8nesZEXmkhsmZeyIE8iQAMig7qw...", "body": "Test message.", "attributes": { "ApproximateReceiveCount": "1", "SentTimestamp": "1573251510774",
"SequenceNumber": "18849496460467696128", "MessageGroupId": "1",
"SenderId": "AIDAIO23YVJENQZJOL4VO","MessageDeduplicationId": "1",
"ApproximateFirstReceiveTimestamp": "1573251510774" }, "messageAttributes": {}, "md5OfBody": "e4e68fb7bd0e697a0ae8f1bb342846b3", "eventSource": "aws:sqs", "eventSourceARN": "arn:aws:sqs:us-east-2:123456789012:fifo.fifo", "awsRegion": "us-east-2" } ] }