AWS Lambda - Fungsi dengan Python

Dalam bab ini, kami akan membuat fungsi AWS Lambda sederhana dengan Python dan memahami konsep kerjanya setelah detailnya.

Sebelum melanjutkan untuk bekerja membuat fungsi Lambda di AWS, kami memerlukan dukungan toolkit AWS untuk Python. Untuk tujuan ini, ikuti langkah-langkah yang diberikan di bawah ini dan amati tangkapan layar terkait yang terlampir -

Langkah 1

Masuk ke konsol AWS dan buat fungsi Lambda dan pilih bahasa sebagai Python.

Langkah 2

Sekarang, klik Create functiondan masukkan detail untuk membuat AWS Lambda sederhana dengan Python. Kode ini mengembalikan pesan tersebutHello from Lambda using Python dan terlihat seperti yang ditunjukkan di sini -

LANGKAH 3

Sekarang, simpan perubahan dan uji kodenya untuk melihat hasilnya. Anda akan melihat output dan log berikut saat mengujinya di konsol AWS menggunakan tombol uji dari UI.

LANGKAH 4

Sekarang, Anda dapat menulis kode di dalam editor apa pun atau IDE untuk Python. Di sini, kami menggunakan kode studio visual untuk menulis kode. Nanti Anda harus membuat zip file tersebut dan mengunggahnya di konsol AWS.

Di sini, kami telah membuat kode zip dan menggunakannya untuk konsol AWS.

LANGKAH 5

Sekarang, pilih Upload a .ZIP file opsi seperti yang ditunjukkan di bawah ini -

Detail Penangan untuk Python

Perhatikan bahwa penangan haruslah nama file yang diikuti dengan nama fungsinya. Dalam kasus di atas, nama file kami adalahhellopython.py dan nama fungsinya adalah my_handler; jadi pawang akan menjadi hellopython.my_handler.

Setelah unggahan selesai dan perubahan disimpan, ini sebenarnya menunjukkan detail file zip di editor online di konsol AWS Lambda. Sekarang, mari kita uji kode untuk melihat output dan log.

Sekarang, mari kita pahami detail fungsi Lambda menggunakan kode contoh berikut -

def my_handler(event, context):
   return "aws lambda in python using zip file"

Pada kode di atas, nama fungsi my_handler memiliki 2 params, event dan konteks.

Objek Konteks dengan Python

Objek konteks memberikan detail seperti nama fungsi Lambda, waktu tersisa dalam milidetik, id permintaan, nama grup pengawasan cloud, detail waktu tunggu, dll.

Metode dan atribut yang tersedia pada objek konteks ditunjukkan pada tabel yang diberikan di bawah ini -

Sr Tidak Nama Metode & Deskripsi
1

get_remaining_time_in_millis()

Metode ini memberikan waktu yang tersisa dalam milidetik hingga fungsi lambda menghentikan fungsinya

Sr Tidak Atribut & Deskripsi
1

function_name

Ini memberi nama fungsi lambda aws

2

function_version

Ini memberikan versi eksekusi fungsi lambda aws

3

invoked_function_arn

Ini akan memberikan detail ARN.

4

memory_limit_in_mb

Ini menunjukkan batas memori yang ditambahkan saat membuat fungsi lambda

5

aws_request_id

Ini memberikan id permintaan aws.

6

og_group_name

Ini akan memberi nama grup cloudwatch

7

log_stream_name

Ini akan memberi nama aliran log cloudwatch tempat log ditulis.

8

identity

Ini akan memberikan detail tentang penyedia identitas cognito amazon saat digunakan dengan aws mobile sdk. Detail yang diberikan adalah sebagai berikut -

  • identity.cognito_identity_id
  • identity.cognito_identity_pool_id
9

client_context

Ini akan menjelaskan detail aplikasi klien saat digunakan dengan aws mobile sdk. Detail yang diberikan adalah sebagai berikut -

  • client_context.client.installation_id
  • client_context.client.app_title
  • client_context.client.app_version_name
  • client_context.client.app_version_code
  • client_context.client.app_package_name
  • client_context.custom - ini memiliki diktekan nilai khusus dari aplikasi klien seluler
  • client_context.env - memiliki diktekan detail lingkungan dari AWS Mobile SDK

Mari kita lihat contoh kerja Python yang menampilkan detail konteks. Perhatikan kode yang diberikan di bawah ini -

def my_handler(event, context):
   print("Log stream name:", context.log_stream_name)
   print("Log group name:",  context.log_group_name)
   print("Request ID:",context.aws_request_id)
   print("Mem. limits(MB):", context.memory_limit_in_mb)
   print("Time remaining (MS):", context.get_remaining_time_in_millis())
   return "aws lambda in python using zip file"

Output yang sesuai dari kode yang ditunjukkan di atas diberikan di bawah ini -

Logging menggunakan Python

Untuk mencatat info menggunakan Python, kita dapat menggunakan fungsi print atau logger yang tersedia. Mari kita gunakan contoh konteks di atas dan periksa inCloudWatch untuk melihat apakah log dicetak. Perhatikan kode berikut -

def my_handler(event, context):
   print("Log stream name:", context.log_stream_name)
   print("Log group name:",  context.log_group_name)
   print("Request ID:",context.aws_request_id)
   print("Mem. limits(MB):", context.memory_limit_in_mb)
   print("Time remaining (MS):", context.get_remaining_time_in_millis())
   return "aws lambda in python using zip file"

Output dari kode ini di CloudWatch adalah seperti yang ditunjukkan di bawah ini -

Perhatikan contoh berikut untuk memahami tentang menggunakan logger untuk mencetak log ke CloudWatch -

import logging
logger = logging.getLogger()
logger.setLevel(logging.INFO)
def my_handler(event, context):
   logger.info('Using logger to print messages to cloudwatch logs')
   return "aws lambda in python using zip file"

Output untuk ini akan seperti yang ditunjukkan pada gambar di bawah ini -

Penanganan Kesalahan dengan Python untuk fungsi Lambda

Di bagian ini, mari kita lihat contoh kerja yang menunjukkan bagaimana menangani kesalahan dengan Python. Amati potongan kode yang diberikan di sini -

def error_handler(event, context):
   raise Exception('Error Occured!')

Tampilan log seperti yang ditunjukkan pada gambar di sini -