Rumah > pembangunan bahagian belakang > tutorial php > Memudahkan API Dalaman dengan Direct AWS Lambda Invocation

Memudahkan API Dalaman dengan Direct AWS Lambda Invocation

DDD
Lepaskan: 2024-12-24 13:28:25
asal
856 orang telah melayarinya

Simplifying Internal APIs with Direct AWS Lambda Invocation

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.

Mengapa Gunakan AWS Lambda Secara Terus?

  1. 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.

  2. 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.


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(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}

Salin selepas log masuk
Salin selepas log masuk

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.
Salin selepas log masuk
Salin selepas log masuk

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}
Salin selepas log masuk
Salin selepas log masuk

Fungsi Lambda ini:

  • Mengesahkan input untuk memastikan kedua-dua nombor1 dan nombor2 disediakan.
  • Menambah dua nombor dan mengembalikan keputusan dalam a sebagai dict.

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.

Berjalan Setempat dengan AWS SAM

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

Salin selepas log masuk
Salin selepas log masuk

Langkah 2: Guna Fungsi Lambda Secara Terus (Contoh PHP)

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}

Salin selepas log masuk
Salin selepas log masuk

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.
Salin selepas log masuk
Salin selepas log masuk

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.

Pertimbangan Pengeluaran

Konfigurasi AWS Cli pada skrip PHP

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}
Salin selepas log masuk
Salin selepas log masuk

Sudah tentu letak kunci dan rahsia dengan kunci yang dikonfigurasikan pada AWS IAM.

Konfigurasi Peranan 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

Salin selepas log masuk
Salin selepas log masuk

Ganti:

  • XXXXXX dengan ID akaun AWS anda.
  • AddTwoNumbersFunction dengan nama fungsi Lambda anda.

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.


Kesimpulan

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!

sumber:dev.to
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan