Bekerja dengan lapisan untuk fungsi Lambda Node.js - AWS Lambda

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

Bekerja dengan lapisan untuk fungsi Lambda Node.js

Lapisan Lambda adalah arsip file .zip yang berisi kode atau data tambahan. Lapisan biasanya berisi dependensi pustaka, runtime kustom, atau file konfigurasi. Membuat layer melibatkan tiga langkah umum:

  1. Package konten layer Anda. Ini berarti membuat arsip file .zip yang berisi dependensi yang ingin Anda gunakan dalam fungsi Anda.

  2. Buat layer di Lambda.

  3. Tambahkan lapisan ke fungsi Anda.

Topik ini berisi langkah-langkah dan panduan tentang cara mengemas dan membuat lapisan Lambda Node.js dengan dependensi pustaka eksternal dengan benar.

Prasyarat

Untuk mengikuti langkah-langkah di bagian ini, Anda harus memiliki hal-hal berikut:

Sepanjang topik ini, kami mereferensikan aplikasi sampel layer-nodejs di repositori. aws-lambda-developer-guide GitHub Aplikasi ini berisi skrip yang mengunduh ketergantungan dan mengemasnya ke dalam lapisan. Aplikasi ini juga berisi fungsi terkait yang menggunakan ketergantungan dari lapisan. Setelah membuat layer, Anda dapat menerapkan dan memanggil fungsi yang sesuai untuk memverifikasi bahwa semuanya berfungsi. Contoh aplikasi ini menggunakan runtime Node.js 20. Jika Anda menambahkan dependensi tambahan ke lapisan Anda, mereka harus kompatibel dengan Node.js 20.

Aplikasi layer-nodejs sampel akan mengemas pustaka lodash ke dalam lapisan Lambda. layerDirektori berisi skrip untuk menghasilkan lapisan. functionDirektori berisi fungsi sampel untuk menguji apakah lapisan berfungsi. Dokumen ini berjalan melalui cara membuat, mengemas, menyebarkan, dan menguji lapisan ini.

Kompatibilitas lapisan Node.js dengan lingkungan runtime Lambda

Saat Anda mengemas kode dalam lapisan Node.js, Anda menentukan lingkungan runtime Lambda yang kompatibel dengan kode tersebut. Untuk menilai kompatibilitas kode dengan runtime, pertimbangkan versi Node.js, sistem operasi apa, dan arsitektur set instruksi apa yang dirancang untuk kode tersebut.

Runtime Lambda Node.js menentukan versi Node.js dan sistem operasi mereka. Dalam dokumen ini, Anda akan menggunakan runtime Node.js 20, yang didasarkan pada AL2 023. Untuk informasi selengkapnya tentang versi runtime, lihatWaktu aktif yang didukung. Ketika Anda membuat fungsi Lambda, Anda menentukan arsitektur set instruksi. Dalam dokumen ini, Anda akan menggunakan arm64 arsitektur. Untuk informasi selengkapnya tentang arsitektur di Lambda, lihat. Memilih dan mengonfigurasi arsitektur set instruksi untuk fungsi Lambda Anda

Bila Anda menggunakan kode yang disediakan dalam sebuah paket, setiap pengelola paket secara independen mendefinisikan kompatibilitasnya. Sebagian besar pengembangan Node.js dirancang untuk bekerja secara independen dari sistem operasi dan arsitektur set instruksi. Selain itu, melanggar ketidakcocokan dengan versi Node.js baru tidak begitu umum. Berharap untuk menghabiskan lebih banyak waktu Anda untuk menilai kompatibilitas antar paket daripada menilai kompatibilitas paket dengan versi Node.js, sistem operasi, atau arsitektur set instruksi.

Terkadang paket Node.js menyertakan kode yang dikompilasi, yang mengharuskan Anda mempertimbangkan kompatibilitas arsitektur sistem operasi dan set instruksi. Jika Anda perlu menilai kompatibilitas kode untuk paket Anda, Anda perlu memeriksa paket dan dokumentasinya. Paket di NPM dapat menentukan kompatibilitasnya melaluiengines,os, dan cpu bidang file package.json manifes mereka. Untuk informasi selengkapnya tentang package.json file, lihat package.json di dokumentasi. NPM

Jalur lapisan untuk runtime Node.js

Saat Anda menambahkan layer ke fungsi, Lambda memuat konten layer ke dalam lingkungan eksekusi. Jika layer Anda mengemas dependensi di jalur folder tertentu, lingkungan eksekusi Node.js akan mengenali modul, dan Anda dapat mereferensikan modul dari kode fungsi Anda.

Untuk memastikan bahwa modul Anda diambil, paketkan ke dalam file layer .zip Anda di salah satu jalur folder berikut. File-file ini disimpan di/opt, dan jalur folder dimuat ke dalam variabel PATH lingkungan.

  • nodejs/node_modules

  • nodejs/nodeX/node_modules

Misalnya, file layer zip yang dihasilkan yang Anda buat dalam tutorial ini memiliki struktur direktori berikut:

layer_content.zip └ nodejs └ node20 └ node_modules └ lodash └ <other potential dependencies> └ ...

Anda akan menempatkan lodashperpustakaan di nodejs/node20/node_modules direktori. Ini memastikan bahwa Lambda dapat menemukan pustaka selama pemanggilan fungsi.

Mengemas konten lapisan

Dalam contoh ini, Anda mengemas lodash pustaka dalam file layer .zip. Selesaikan langkah-langkah berikut untuk menginstal dan mengemas konten lapisan.

Untuk menginstal dan mengemas konten lapisan Anda
  1. Kloning aws-lambda-developer-guiderepositori dari GitHub, yang berisi kode sampel yang Anda butuhkan di direktori. sample-apps/layer-nodejs

    git clone https://github.com/awsdocs/aws-lambda-developer-guide.git
  2. Arahkan ke layer direktori aplikasi layer-nodejs sampel. Direktori ini berisi skrip yang Anda gunakan untuk membuat dan mengemas lapisan dengan benar.

    cd aws-lambda-developer-guide/sample-apps/layer-nodejs/layer
  3. Pastikan daftar package.json filelodash. File ini mendefinisikan dependensi yang ingin Anda sertakan dalam layer. Anda dapat memperbarui file ini untuk menyertakan dependensi apa pun yang Anda inginkan di lapisan Anda.

    catatan

    Yang package.json digunakan dalam langkah ini tidak disimpan atau digunakan dengan dependensi Anda setelah diunggah ke lapisan Lambda. Ini hanya digunakan dalam proses pengemasan lapisan, dan tidak menentukan perintah run dan kompatibilitas seperti file dalam aplikasi Node.js atau paket yang diterbitkan.

  4. Pastikan Anda memiliki izin shell untuk menjalankan skrip di layer direktori.

    chmod 744 1-install.sh && chmod 744 2-package.sh
  5. Jalankan skrip 1-install.sh menggunakan perintah berikut:

    ./1-install.sh

    Skrip ini berjalannpm install, yang membaca Anda package.json dan mengunduh dependensi yang ditentukan di dalamnya.

    contoh 1-install.sh
    npm install .
  6. Jalankan skrip 2-package.sh menggunakan perintah berikut:

    ./2-package.sh

    Script ini menyalin isi dari node_modules direktori ke direktori baru bernamanodejs/node20. Kemudian zip isi nodejs direktori ke dalam file bernamalayer_content.zip. Ini adalah file .zip untuk lapisan Anda. Anda dapat membuka zip file dan memverifikasi bahwa itu berisi struktur file yang benar, seperti yang ditunjukkan pada Jalur lapisan untuk runtime Node.js bagian.

    contoh 2-package.sh
    mkdir -p nodejs/node20 cp -r node_modules nodejs/node20/ zip -r layer_content.zip nodejs

Membuat lapisan

Ambil layer_content.zip file yang Anda buat di bagian sebelumnya dan unggah sebagai lapisan Lambda. Anda dapat mengunggah layer menggunakan AWS Management Console atau Lambda API melalui AWS Command Line Interface ()AWS CLI. Saat Anda mengunggah file layer .zip Anda, dalam PublishLayerVersion AWS CLI perintah berikut, tentukan nodejs20.x sebagai runtime yang kompatibel dan arm64 sebagai arsitektur yang kompatibel.

aws lambda publish-layer-version --layer-name nodejs-lodash-layer \ --zip-file fileb://layer_content.zip \ --compatible-runtimes nodejs20.x \ --compatible-architectures "arm64"

Dari tanggapan, perhatikanLayerVersionArn, yang terlihat sepertiarn:aws:lambda:us-east-1:123456789012:layer:nodejs-lodash-layer:1. Anda akan memerlukan Amazon Resource Name (ARN) ini di langkah berikutnya dari tutorial ini, ketika Anda menambahkan layer ke fungsi Anda.

Menambahkan lapisan ke fungsi Anda

Menyebarkan contoh fungsi Lambda yang menggunakan lodash pustaka dalam kode fungsinya, lalu lampirkan layer yang Anda buat. Untuk menerapkan fungsi, Anda memerlukan peran eksekusi. Untuk informasi selengkapnya, lihat Mendefinisikan izin fungsi Lambda dengan peran eksekusi. Jika Anda belum memiliki peran eksekusi, ikuti langkah-langkah di bagian yang dapat dilipat. Jika tidak, lewati ke bagian berikutnya untuk men-deploy fungsi.

Untuk membuat peran eksekusi
  1. Buka halaman peran di IAM konsol.

  2. Pilih Buat peran.

  3. Buat peran dengan properti berikut.

    • Entitas tepercayaLambda.

    • IzinAWSLambdaBasicExecutionRole.

    • Nama peranlambda-role.

    AWSLambdaBasicExecutionRoleKebijakan memiliki izin yang diperlukan oleh fungsi untuk menulis log ke CloudWatch Logs.

Kode fungsi sampel menggunakan _.findLastIndex metode lodash untuk membaca melalui array objek. Ini membandingkan objek dengan kriteria untuk menemukan indeks kecocokan. Kemudian, ia mengembalikan indeks dan nilai objek dalam respons Lambda.

import _ from "lodash" export const handler = async (event) => { var users = [ { 'user': 'Carlos', 'active': true }, { 'user': 'Gil-dong', 'active': false }, { 'user': 'Pat', 'active': false } ]; let out = _.findLastIndex(users, function(o) { return o.user == 'Pat'; }); const response = { statusCode: 200, body: JSON.stringify(out + ", " + users[out].user), }; return response; };
Untuk men-deploy fungsi Lambda
  1. Buka direktori function/ tersebut. Jika saat ini Anda berada di layer/ direktori, maka jalankan perintah berikut:

    cd ../function-js
  2. Membuat paket deployment file .zip menggunakan perintah berikut:

    zip my_deployment_package.zip index.mjs
  3. Deploy fungsi. Dalam AWS CLI perintah berikut, ganti --role parameter dengan peran eksekusi AndaARN:

    aws lambda create-function --function-name nodejs_function_with_layer \ --runtime nodejs20.x \ --architectures "arm64" \ --handler index.handler \ --role arn:aws:iam::123456789012:role/lambda-role \ --zip-file fileb://my_deployment_package.zip
  4. Pasang lapisan ke fungsi Anda. Dalam AWS CLI perintah berikut, ganti --layers parameter dengan versi layer ARN yang Anda catat sebelumnya:

    aws lambda update-function-configuration --function-name nodejs_function_with_layer \ --cli-binary-format raw-in-base64-out \ --layers "arn:aws:lambda:us-east-1:123456789012:layer:nodejs-lodash-layer:1"
  5. Panggil fungsi Anda untuk memverifikasi itu berfungsi menggunakan AWS CLI perintah berikut:

    aws lambda invoke --function-name nodejs_function_with_layer \ --cli-binary-format raw-in-base64-out \ --payload '{}' response.json

    Anda akan melihat output seperti ini:

    { "StatusCode": 200, "ExecutedVersion": "$LATEST" }

    response.jsonFile output berisi rincian tentang respon.

Sekarang Anda dapat menghapus sumber daya yang Anda buat untuk tutorial ini, kecuali Anda ingin mempertahankannya. Dengan menghapus AWS sumber daya yang tidak lagi Anda gunakan, Anda mencegah biaya yang tidak perlu untuk Anda Akun AWS.

Untuk menghapus lapisan Lambda
  1. Buka halaman Fungsi di konsol Lambda.

  2. Pilih lapisan yang Anda buat.

  3. Pilih Hapus, lalu pilih Hapus lagi.

Untuk menghapus fungsi Lambda
  1. Buka halaman Fungsi di konsol Lambda.

  2. Pilih fungsi yang Anda buat.

  3. Pilih Tindakan, Hapus.

  4. Ketik delete kolom input teks dan pilih Hapus.