Apabila bekerja dengan sistem Senibina Berorientasikan Perkhidmatan (SOA), anda mungkin memerlukan API dalaman untuk komunikasi antara perkhidmatan. Pendekatan biasa ialah menggunakan AWS Lambda bersama Gerbang API. Walau bagaimanapun, untuk API dalaman, terdapat pilihan yang lebih mudah dan cekap: gunakan AWS Lambda terus.
Pengesahan Terbina dalam dengan IAM
AWS Lambda secara asli berintegrasi dengan Pengurusan Identiti dan Akses (IAM) AWS, membolehkan anda mendapatkan akses kepada API dalaman anda tanpa lapisan pengesahan tambahan.
Konfigurasi Lebih Mudah & Seni Bina Keseluruhan
Invokasi Lambda langsung menghapuskan keperluan untuk mengkonfigurasi Gerbang API, pengepala tersuai atau persediaan pelayan yang kompleks. Ia merupakan penyelesaian ringan yang disesuaikan untuk kes penggunaan dalaman.
Mari mulakan dengan mencipta fungsi Lambda mudah dalam Python yang menambah dua nombor. Ini kodnya:
def lambda_handler(event, context): if 'number1' not in event: return {'status':'error','msg':"Number1 is missing"} if 'number2' not in event: return {'status':'error','msg':"Number1 is missing"} result = int(event['number1']) + int(event['number2']) return {"status":"success","result":result}
Berikut ialah versi dokumen anda yang dipertingkatkan dan digilap:
Memudahkan API Dalaman dengan Direct AWS Lambda Invocation
Apabila bekerja dengan sistem Seni Bina Berorientasikan Perkhidmatan (SOA), anda mungkin memerlukan API dalaman untuk komunikasi antara perkhidmatan. Pendekatan biasa ialah menggunakan AWS Lambda bersama Gerbang API. Walau bagaimanapun, untuk API dalaman, terdapat pilihan yang lebih mudah dan cekap: gunakan AWS Lambda secara terus.
Mengapa Mendapat AWS Lambda Secara Terus?
Built-in Authentication with IAM AWS Lambda natively integrates with AWS Identity and Access Management (IAM), allowing you to secure access to your internal API without additional layers of authentication. Simpler Configuration Direct Lambda invocation eliminates the need to configure API Gateways, custom headers, or complex server setups. It’s a lightweight solution tailored for internal use cases.
Contoh: Menambah Dua Nombor dengan AWS Lambda
Langkah 1: Cipta Fungsi Lambda
Mari mulakan dengan mencipta fungsi Lambda mudah dalam Python yang menambah dua nombor. Ini kodnya:
def lambda_handler(acara, konteks):
jika 'nombor1' tiada dalam acara:
kembalikan {'status': 'error', 'msg': "Nombor1 tiada"}
jika 'nombor2' tiada dalam acara:
kembalikan {'status': 'error', 'msg': "Nombor2 tiada"}
result = int(event['number1']) + int(event['number2']) return {"status": "success", "result": result}
Fungsi Lambda ini:
Input dengan syarat bahawa apl kami yang menggunakan API disediakan terus ke dalam acara tersebut. Tiada objek mewah di sini hanya dict biasa, tiada POST, Not GET tiada tajuk apa-apa. Seperti yang dinyatakan di atas, akses ditakrifkan oleh IAM sendiri.
Untuk menguji fungsi Lambda secara setempat, gunakan Model Aplikasi Tanpa Pelayan (SAM) AWS. Berikut ialah contoh templat SAM:
AWSTemplateFormatVersion: '2010-09-09' Transform: AWS::Serverless-2016-10-31 Description: > Dummy Lambda that adds 2 numbers # More info about Globals: https://github.com/awslabs/serverless-application-model/blob/master/docs/globals.rst Globals: Function: Timeout: 3 MemorySize: 128 Resources: AddTwoNumbersFunction: Type: AWS::Serverless::Function # More info about Function Resource: https://github.com/awslabs/serverless-application-model/blob/master/versions/2016-10-31.md#awsserverlessfunction Properties: CodeUri: hello_world/ Handler: app.lambda_handler Runtime: python3.10 Architectures: - x86_64
Kami boleh menjalankan lambda kami melalui skrip ini
def lambda_handler(event, context): if 'number1' not in event: return {'status':'error','msg':"Number1 is missing"} if 'number2' not in event: return {'status':'error','msg':"Number1 is missing"} result = int(event['number1']) + int(event['number2']) return {"status":"success","result":result}
Seperti yang anda lihat, Input lambda dikodkan sebagai json rentetan parameter number1 dan number2. (Kod daripada contoh di atas)
Built-in Authentication with IAM AWS Lambda natively integrates with AWS Identity and Access Management (IAM), allowing you to secure access to your internal API without additional layers of authentication. Simpler Configuration Direct Lambda invocation eliminates the need to configure API Gateways, custom headers, or complex server setups. It’s a lightweight solution tailored for internal use cases.
Parameter mestilah sebagai json rentetan dan bukan sebagai tatasusunan. Results juga boleh dinyahkodkan sebagai Json, hanya jika lambda mengembalikan dict, atau dalam kes Javascript lamdas objek.
Nilai pulangan sentiasa rentetan dan mesti dinyahkodkan ke dalam bentuk yang diingini.
Jika skrip php digunakan semasa pengeluaran, atau skrip menggunakan lambda dilaksanakan pada AWS itu sendiri, pelanggan harus dikonfigurasikan tanpa tetapan titik akhir:
result = int(event['number1']) + int(event['number2']) return {"status": "success", "result": result}
Sudah tentu letak kunci dan rahsia dengan kunci yang dikonfigurasikan pada AWS IAM.
Skrip pemanggilan memerlukan kebenaran IAM untuk mengakses fungsi Lambda. Gunakan IAM dasar berikut:
AWSTemplateFormatVersion: '2010-09-09' Transform: AWS::Serverless-2016-10-31 Description: > Dummy Lambda that adds 2 numbers # More info about Globals: https://github.com/awslabs/serverless-application-model/blob/master/docs/globals.rst Globals: Function: Timeout: 3 MemorySize: 128 Resources: AddTwoNumbersFunction: Type: AWS::Serverless::Function # More info about Function Resource: https://github.com/awslabs/serverless-application-model/blob/master/versions/2016-10-31.md#awsserverlessfunction Properties: CodeUri: hello_world/ Handler: app.lambda_handler Runtime: python3.10 Architectures: - x86_64
Ganti:
Kebenaran yang sepatutnya ada pada dasar ialah lambda:InvokeFunctionUrl satu. Anda boleh menggunakan editor kebenaran grafik dan meletakkan ARN lambda di bahagian Sumber yang dinyatakan dalam dasar di atas.
Menggunakan AWS Lambda secara langsung memudahkan persediaan API dalaman. Dengan memanfaatkan IAM untuk pengesahan dan mengalih keluar perisian tengah yang tidak diperlukan, pendekatan ini cekap dan mudah untuk dilaksanakan. Sama ada anda membina perkhidmatan mikro atau mengendalikan tugas dalaman, kaedah ini boleh menjimatkan masa dan usaha.
Atas ialah kandungan terperinci Memudahkan API Dalaman dengan Direct AWS Lambda Invocation. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!