Menjalankan dan Memanggil Fungsi Lambda

Bab ini akan menjelaskan secara detail tentang proses menjalankan dan menjalankan fungsi Lambda dan langkah-langkah yang terlibat di dalamnya.

Model Eksekusi AWS Lambda

Eksekusi AWS bergantung pada detail konfigurasi yang ditambahkan untuk Fungsi AWS Lambda. Saat fungsi dibuat, adamemory dan time allotted, yang digunakan untuk menjalankan fungsi AWS Lambda.

Dengan bantuan detail konfigurasi, AWS Lambda membuat konteks eksekusi. Konteks eksekusi adalah lingkungan runtime sementara yang disiapkan dengan dependensi eksternal seperti koneksi database, titik akhir http, pustaka pihak ketiga, dll., Jika ada.

Saat fungsi AWS Lambda dipanggil untuk pertama kalinya atau jika fungsi lambda diperbarui, ada sedikit latensi yang ditambahkan karena pengaturan konteks eksekusi. Namun, panggilan berikutnya lebih cepat dibandingkan dengan yang pertama. AWS Lambda mencoba menggunakan kembali konteks eksekusi lagi jika fungsi Lambda dipanggil dalam waktu yang lebih singkat.

Penggunaan kembali konteks eksekusi memiliki implikasi berikut -

  • Jika ada koneksi database yang dilakukan untuk eksekusi Lambda, koneksi dipertahankan untuk digunakan kembali. Jadi kode Lambda harus sedemikian rupa sehingga sambungan harus diperiksa terlebih dahulu - jika ada dan digunakan kembali; kalau tidak, kita harus membuat koneksi baru yang segar.

  • Konteks eksekusi mempertahankan ruang disk sebesar 500MB /tmpdirektori. Data yang diperlukan disimpan dalam cache di direktori ini. Anda dapat memiliki pemeriksaan tambahan dalam kode untuk melihat apakah datanya ada.

  • Jika callback atau beberapa proses latar belakang tidak selesai saat fungsi Lambda dipanggil, eksekusi akan dimulai saat fungsi lambda dipanggil lagi. Jika Anda tidak perlu hal seperti itu terjadi, pastikan proses Anda semua diakhiri dengan benar, ketika eksekusi fungsi selesai.

Anda harus menggunakan konteks eksekusi dan data yang disimpan dalam direktori tmp. Anda harus menambahkan pemeriksaan yang diperlukan dalam kode untuk melihat apakah data yang diperlukan ada sebelum membuat yang baru. Ini akan menghemat waktu selama eksekusi dan membuatnya lebih cepat.

Memanggil fungsi AWS Lambda

Kami dapat meminta AWS secara manual menggunakan aws cli. Kami telah melihat cara membuat dan menerapkan AWS Lambda menggunakancli. Di sini, pertama-tama kita akan membuat fungsi menggunakanaws cli dan meminta hal yang sama.

Membuat Fungsi AWS Lambda menggunakan AWS CLI

Anda dapat menggunakan perintah berikut untuk membuat fungsi AWS Lambda menggunakan aws cli -

Commands

create-function 
--function-name <value>
--runtime <value>
--role <value>
--handler <value>
[--code <value>] 
[--description <value>] 
[--timeout <value>] 
[--memory-size <value>] 
[--environment <value>] 
[--kms-key-arn <value>] 
[--tags <value>] 
[--zip-file <value>] 
[--cli-input-json <value>]

Command with values

aws lambda create-function 
--function-name "lambdainvoke" 
--runtime "nodejs8.10" 
--role "arn:aws:iam::625297745038:role/lambdaapipolicy" 
--handler "index.handler" 
--timeout 5 
--memory-size 256 
--zip-file "fileb://C:\nodeproject\index.zip"

Outputnya seperti yang ditunjukkan di bawah ini -

Fungsi yang dibuat di konsol AWS seperti yang ditunjukkan di bawah ini -

Sekarang, Anda dapat menjalankan fungsi tersebut menggunakan perintah:invoke

--function-name <value>
[--invocation-type <value>]
[--log-type <value>]
[--client-context <value>]
[--payload <value>]
[--qualifier <value>]
outfile <value>

Options

--function-name − Tentukan nama fungsi yang ingin Anda panggil.

--invocation-type(string) − secara default jenis pemanggilan adalah requestresponse. Nilai yang tersedia untuk digunakan dengan jenis pemanggilan adalahRequestResponse, Event dan DryRun.

  • Jenis permintaan acara akan digunakan untuk respons asinkron.

  • DryRun digunakan saat Anda ingin memverifikasi fungsi Lambda tanpa perlu menjalankannya.

--log-type − Boleh jadi Tailjika jenis permintaan adalah RequestResponse. Ini memberikan data log bersandiaksara 4KB base64 terakhir. Nilai yang mungkin adalahTail dan None.

--client-context −Anda dapat meneruskan detail spesifik klien ke fungsi Lambda. Konteks klien harus dalam format json dan dikodekan base64. Ukuran file maksimum adalah 3583 byte.

--payload − json format masukan untuk Anda fungsi lambda.

--qualifier −Anda dapat menentukan versi fungsi Lambda atau nama alias. Jika Anda meneruskan versi fungsi maka api akan menggunakan fungsi yang memenuhi syarat arn untuk memanggil fungsi Lambda. Jika Anda menentukan nama alias, api menggunakan alias ARN untuk menjalankan fungsi Lambda.

outfile − Ini adalah nama file tempat konten akan disimpan.

Command with values

aws lambda invoke --function-name "lambdainvoke" --log-type 
Tail C:\nodeproject\outputfile.txt

Anda dapat menggunakan opsi payload untuk mengirim acara dummy ke fungsi lambda dalam format json seperti yang ditunjukkan di bawah ini.

Kode AWS Lambda terkait adalah sebagai berikut -

exports.handler = async (event, callback) => {
   console.log("Hello => "+ event.name);
   console.log("Address =>"+ event.addr);
   callback(null, 'Hello '+event.name +" and address is "+ event.addr);
};

Perhatikan bahwa di dalam kode, kami memiliki konsol event.name dan event.addr. Sekarang, mari kita gunakan opsi payload di aws cli untuk mengirim acara dengan nama dan alamat sebagai berikut -

aws lambda invoke --function-name "lambdainvoke" --log-type 
Tail --payload file://C:\clioutput\input.txt C:\clioutput\outputfile.txt

Thenpayload mengambil input sebagai jalur file yang memiliki input json seperti yang ditunjukkan -

{"name":"Roy Singh", "addr":"Mumbai"}

Output yang sesuai seperti yang ditunjukkan di bawah ini -

Outputnya disimpan dalam file C:\clioutput\outputfile.txt sebagai berikut -

"Hello Roy Singh and address is Mumbai"

Contoh Peristiwa

Anda dapat menguji fungsi AWS Lambda dengan meneruskan kejadian sampel. Bagian ini memberikan beberapa contoh kejadian untuk Layanan AWS. Anda dapat menggunakaninvokeperintah untuk menguji keluaran saat dipicu dengan salah satu layanan. Perhatikan kode yang diberikan untuk contoh kejadian terkait di bawah ini -

Amazon S3 Put Sample Event

{
  "Records": [{
      "eventVersion": "2.0",
      "eventTime": "1970-01-01T00:00:00.000Z",
      "requestParameters": {
         "SourceIPAddress": "127.0.0.1"
      },
      "s3": {
         "configurationId": "testConfigRule",
         "object": {
            "eTag": "0123456789abcdef0123456789abcdef",
            "sequencer": "0A1B2C3D4E5F678901",
            "key": "HappyFace.jpg",
            "size": 1024
         },
         "bucket": { 
            "arn": bucketarn,
            "name": "Sourcebucket",
            "ownerIdentity": {
               "principalId": "EXAMPLE"
            }
         },
         "s3SchemaVersion": "1.0"
      },
      "responseElements": {
         "x-amz-id-2": "EXAMPLE123/5678abcdefghijklambdaisawesome/mnopqrstuvwxyzABCDEFGH",
         "x-amz-request-id": "EXAMPLE123456789"
      },
      "awsRegion": "us-east-1",
      "eventName": "ObjectCreated:Put",
      "userIdentity": {
         "principalId": "EXAMPLE"
      },
      "eventSource": "aws:s3"
   }]
}

Untuk mendapatkan details of the file from the s3 put event, Anda dapat menggunakan perintah berikut -

event.Records[0].s3.object.key   //will display the name of the file

Untuk get the bucket name, Anda dapat menggunakan perintah berikut -

event.Records[0].s3.bucket.name  //will give the name of the bucket.

Untuk see the EventName, Anda dapat menggunakan perintah berikut -

event.Records[0].eventName    // will display the eventname

Amazon S3 Hapus Contoh Peristiwa

{
   "Records": [{
      "eventVersion": "2.0",
      "eventTime": "1970-01-01T00:00:00.000Z",
      "requestParameters": {
         "SourceIPAddress": "127.0.0.1"
      },
      "s3": {
         "configurationId": "testConfigRule",
         "object": {
            "sequencer": "0A1B2C3D4E5F678901",
            "key": "HappyFace.jpg"
         },
         "bucket": {
            "arn": bucketarn,
            "name": "Sourcebucket",
            "ownerIdentity": {
               "principalId": "EXAMPLE"
            }
         },
        "s3SchemaVersion": "1.0"
      },
      "responseElements": {
         "x-amz-id-2": "EXAMPLE123/5678abcdefghijklambdaisawesome/mnopqrstuvwxyzABCDEFGH",
         "x-amz-request-id": "EXAMPLE123456789"
      },
      "awsRegion": "us-east-1",
      "eventName": "ObjectRemoved:Delete",
      "userIdentity": {
         "principalId": "EXAMPLE"
      },
      "eventSource": "aws:s3"
   }]
}

Amazon DynamoDB

Amazon DynamoDB dapat menjadi peristiwa di AWS Lambda saat perubahan dilakukan pada tabel DynamoDB. Kita dapat melakukan operasi seperti menambah entri, memperbarui dan menghapus catatan dari tabel DynamodDB.

Contoh kejadian untuk menambahkan, menyisipkan dan menghapus acara DynamoDB ditampilkan di sini -

{
  "Records": [{
      "eventID": "1",
      "eventVersion": "1.0",
      "dynamodb": {
         "Keys": {
            "Id": {
               "N": "101"
            }
         },
         "NewImage": {
            "Message": {
               "S": "New item!"
            },
            "Id": {
               "N": "101"
            }
         },
         "StreamViewType": "NEW_AND_OLD_IMAGES",
         "SequenceNumber": "111",
         "SizeBytes": 26
      },
      "awsRegion": "us-west-2",
      "eventName": "INSERT",
      "eventSourceARN": eventSourcearn,
      "eventSource": "aws:dynamodb"
   },
   {
      "eventID": "2",
      "eventVersion": "1.0",
      "dynamodb": {
         "OldImage": {
            "Message": {
               "S": "New item!"
            },
            "Id": {
               "N": "101"
            }
         },
        "SequenceNumber": "222",
        "Keys": {
            "Id": {
               "N": "101"
            }
         },
        "SizeBytes": 59,
        "NewImage": {
            "Message": {
               "S": "This item has changed"
            },
            "Id": {
				   "N": "101"
            }
         },
         "StreamViewType": "NEW_AND_OLD_IMAGES"
      },
      "awsRegion": "us-west-2",
      "eventName": "MODIFY",
      "eventSourceARN": Sourcearn,
      "eventSource": "aws:dynamodb"
   },
   {      
   "eventID": "3",
      "eventVersion": "1.0",
      "dynamodb": {
         "Keys": {
            "Id": {
               "N": "101"
            }
         },
         "SizeBytes": 38,
         "SequenceNumber": "333",
         "OldImage": {
            "Message": {
               "S": "This item has changed"
            },
            "Id": {
               "N": "101"
            }
         },
         "StreamViewType": "NEW_AND_OLD_IMAGES"
      },      "awsRegion": "us-west-2",
      "eventName": "REMOVE",
      "eventSourceARN": Sourcearn,
      "eventSource": "aws:dynamodb"    
   }]
}

Amazon Simple Notification Service

AWS Lambda dapat membantu memproses pemberitahuan yang dibuat di Simple Notification Service (SNS). Setiap kali ada pesan yang diterbitkan di SNS, fungsi Lambda dapat dipicu dengan acara SNS, yang memiliki detail pesan. Pesan ini dapat diproses di dalam fungsi Lambda dan dapat dikirim lebih lanjut ke layanan lain sesuai kebutuhan.

Setelah pesan dimasukkan, SNS akan memicu fungsi Lambda. Jika ada kesalahan yang mencoba memanggil fungsi Lambda, SNS akan mencoba memanggil fungsi lambda hingga tiga kali.

Peristiwa Sampel Amazon SNS

Contoh kejadian yang memiliki semua detail yang tersedia di fungsi AWS Lambda untuk menjalankan proses lebih lanjut ditunjukkan di bawah ini -

{
  "Records": [{
      "EventVersion": "1.0",
      "EventSubscriptionArn": eventsubscriptionarn,
      "EventSource": "aws:sns",
      "Sns": {
         "SignatureVersion": "1",
         "Timestamp": "1970-01-01T00:00:00.000Z",
         "Signature": "EXAMPLE",
         "SigningCertUrl": "EXAMPLE",
         "MessageId": "95df01b4-ee98-5cb9-9903-4c221d41eb5e",
         "Message": "Hello from SNS!",
         "MessageAttributes": {
            "Test": {
               "Type": "String",
               "Value": "TestString"
            },
            "TestBinary": {
               "Type": "Binary",
               "Value": "TestBinary"
            }
         },
         "Type": "Notification",
         "UnsubscribeUrl": "EXAMPLE",
         "TopicArn": topicarn,
         "Subject": "TestInvoke"
      }
   }]
}

Amazon Simple Mail Service

Amazon Simple Mail Service dapat digunakan untuk mengirim pesan dan juga untuk menerima pesan. Fungsi AWS Lambda dapat dipanggil di Simple Mail Service saat pesan diterima.

Acara Contoh Penerimaan Email Amazon SES

Detail peristiwa SES saat digunakan di dalam AWS Lambda ditunjukkan di bawah -

{
  "Records": [{
      "eventVersion": "1.0",
      "ses": {
         "mail": {
            "commonHeaders": {
               "from": [
                  "Jane Doe <[email protected]>"
               ],
            "to": [
               "[email protected]"
            ],
            "returnPath": "[email protected]",
            "messageId": "<0123456789Source.com>",
            "date": "Wed, 7 Oct 2015 12:34:56 -0700",
            "subject": "Test Subject"
         },
         "example": "[email protected]",
         "timestamp": "1970-01-01T00:00:00.000Z",
         "destination": [
            "[email protected]"
         ],
         "headers": [{
            "name": "Return-Path",
            "value": "<[email protected]>"
         },
         {
            "name": "Received",
            "value": "from mailer.example.com (mailer.example.com [203.0.113.1]) by inbound-smtp.us-west-2.amazonaws.com with SMTP id o3vrnil0e2ic for [email protected]; Wed, 07 Oct 2015 12:34:56 +0000 (UTC)"
         },
         {
            "name": "DKIM-Signature",
            "value": "v=1; a=rsa-sha256; c=relaxed/relaxed; d=example.com; s=example; h=mime-version:from:date:message-id:subject:to:content-type; bh=jX3F0bCAI7sIbkHyy3mLYO28ieDQz2R0P8HwQkklFj4=; b=sQwJ+LMe9RjkesGu+vqU56asvMhrLRRYrWCbV"
         },
         {
            "name": "MIME-Version",
            "value": "1.0"
         },
         {
            "name": "From",
            "value": "Jane Doe <[email protected]>"
         },
         {
            "name": "Date",
            "value": "Wed, 7 Oct 2015 12:34:56 -0700"
         },
         {
            "name": "Message-ID",
            "value": "<0123456789example.com>"
         },
         {
            "name": "Subject",
            "value": "Test Subject"
         },
         {
            "name": "To",
            "value": "[email protected]"
         },
         {
            "name": "Content-Type",
            "value": "text/plain; charset=UTF-8"
         }],
         "headersTruncated": false,
         "messageId": "o3vrnil0e2ic28tr"
      },
      "receipt": {
         "recipients": [
            "[email protected]"
         ],
         "timestamp": "1970-01-01T00:00:00.000Z",
         "spamVerdict": {
            "status": "PASS"
         },
         "dkimVerdict": {
            "status": "PASS"
         },
         "processingTimeMillis": 574,
         "action": {
            "type": "Lambda",
            "invocationType": "Event",
            "functionArn": "arn:aws:lambda:us-west-2:012345678912:function:example"
         },
         "spfVerdict": {
            "status": "PASS"
         },
         "virusVerdict": {
            "status": "PASS"
         }
      }
   },
   "eventexample": "aws:ses"
   }]
}

Amazon Cloudwatch Logs

AWS Lambda dapat dipicu dari Amazon CloudWatch Logs menggunakan CloudWatch Logs Subscriptions. Langganan CloudWatch Logs memiliki data waktu nyata tentang log yang dapat diproses dan dianalisis di dalam AWS Lambda atau dapat digunakan untuk memuat ke sistem lain.

Contoh Peristiwa Amazon CloudWatch Logs

{
   "awslogs": {
      "data": "H4sIAAAAAAAAAHWPwQqCQBCGX0Xm7EFtK+smZBEUgXoLCdMhFtKV3akI8d0bLYmibvPPN3wz00CJxmQnTO41whwW
      QRIctmEcB6sQbFC3CjW3XW8kxpOpP+OC22d1Wml1qZkQGtoMsScxaczKN3plG8zlaHIta5KqWsozoTYw3/djzwhpL
      wivWFGHGpAFe7DL68JlBUk+l7KSN7tCOEJ4M3/qOI49vMHj+zCKdlFqLaU2ZHV2a4Ct/an0/ivdX8oYc1UVX860fQ
      DQiMdxRQEAAA=="
   }
}

Amazon API Gateway

Fungsi AWS Lambda dapat diaktifkan httpsurl. TI bisa dilakukanGET, POST, PUT. Saat url https dipanggil, fungsi AWS Lambda juga dipicu dan data yang diteruskan ke https menggunakan get / post dapat disediakan di dalam AWS Lambda untuk digunakan untuk dimasukkan ke dalam DynamoDB atau untuk mengirim email, dll.

Peristiwa Permintaan Proxy Gateway API

{
   "path": "/test/hello",
   "headers": {
      "Accept":  "text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8",
      "Accept-Encoding": "gzip, deflate, lzma, sdch, br",
      "Accept-Language": "en-US,en;q=0.8",
      "CloudFront-Forwarded-Proto": "https",
      "CloudFront-Is-Desktop-Viewer": "true",
      "CloudFront-Is-Mobile-Viewer": "false",
      "CloudFront-Is-SmartTV-Viewer": "false",
      "CloudFront-Is-Tablet-Viewer": "false",
      "CloudFront-Viewer-Country": "US",
      "Host": "wt6mne2s9k.execute-api.us-west-2.amazonaws.com",
      "Upgrade-Insecure-Requests": "1",
      "User-Agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/52.0.2743.82 Safari/537.36 OPR/39.0.2256.48",
      "Via": "1.1 fb7cca60f0ecd82ce07790c9c5eef16c.cloudfront.net (CloudFront)",
      "X-Amz-Cf-Id": "nBsWBOrSHMgnaROZJK1wGCZ9PcRcSpq_oSXZNQwQ10OTZL4cimZo3g==",
      "X-Forwarded-For": "192.168.100.1, 192.168.1.1",
      "X-Forwarded-Port": "443",
      "X-Forwarded-Proto": "https"
   },
   "pathParameters": {
      "proxy": "hello"
   },
   "requestContext": {
      "accountId": "123456789012",
      "reexampleId": "us4z18",
      "stage": "test",
      "requestId": "41b45ea3-70b5-11e6-b7bd-69b5aaebc7d9",
	   "identity": {
         "cognitoIdentityPoolId": "",
         "accountId": "",
         "cognitoIdentityId": "",
         "caller": "",
         "apiKey": "",
         "exampleIp": "192.168.100.1",
         "cognitoAuthenticationType": "",
         "cognitoAuthenticationProvider": "",
         "userArn": "",
         "userAgent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/52.0.2743.82 Safari/537.36 OPR/39.0.2256.48",
         "user": ""
      },
      "reexamplePath": "/{proxy+}",
      "httpMethod": "GET",
      "apiId": "wt6mne2s9k"
   },
   "reexample": "/{proxy+}",
   "httpMethod": "GET",
   "queryStringParameters": {
      "name": "me"
   },
   "stageVariables": {
      "stageVarName": "stageVarValue"
   }
}

Peristiwa Respons Proksi Gerbang API

{
   "statusCode": 200,
   "headers": {
      "Accept": "text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8",
      "Accept-Encoding": "gzip, deflate, lzma, sdch, br",
      "Accept-Language": "en-US,en;q=0.8",
      "CloudFront-Forwarded-Proto": "https",
      "CloudFront-Is-Desktop-Viewer": "true",
      "CloudFront-Is-Mobile-Viewer": "false",
      "CloudFront-Is-SmartTV-Viewer": "false",
      "CloudFront-Is-Tablet-Viewer": "false",
      "CloudFront-Viewer-Country": "US",
      "Host": "wt6mne2s9k.execute-api.us-west-2.amazonaws.com",
      "Upgrade-Insecure-Requests": "1",
      "User-Agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/52.0.2743.82 Safari/537.36 OPR/39.0.2256.48",
      "Via": "1.1 fb7cca60f0ecd82ce07790c9c5eef16c.cloudfront.net (CloudFront)",
      "X-Amz-Cf-Id": "nBsWBOrSHMgnaROZJK1wGCZ9PcRcSpq_oSXZNQwQ10OTZL4cimZo3g==",
      "X-Forwarded-For": "192.168.100.1, 192.168.1.1",
      "X-Forwarded-Port": "443",
      "X-Forwarded-Proto": "https"
   },
   "body": "Hello World"
}