O introducere în declanșatoarele disponibile pentru a invoca o funcție Lambda

O Introducere In Declansatoarele Disponibile Pentru A Invoca O Functie Lambda



AWS Lambda este un serviciu uimitor bazat pe cloud care a revoluționat lumea fără server. Este de fapt un software ca serviciu (SaaS) care poate fi configurat ușor și rapid și este util pentru a reduce bugetul general al infrastructurii dvs. cloud. Ceea ce trebuie să faceți este să vă proiectați codul și să-l executați folosind funcția lambda.

Acum, punctul aici este cum ar trebui să executați codul în funcție și răspunsul la aceasta este că există o listă lungă de metode prin care puteți invoca sau declanșa funcțiile lambda. Aceasta include multe alte servicii AWS care pot fi utilizate pentru a apela funcția dorită atunci când este necesar.

În acest articol, veți vedea o scurtă explicație cu privire la serviciile și tehnicile care pot fi aplicate pentru a vă invoca funcțiile lambda în Amazon.







Tipuri de invocari

Înainte de a merge mai departe, să discutăm următoarele două tipuri majore de invocații pe care funcția lambda le poate gestiona.



  • Invocari sincrone
  • Invocari asincrone
  1. Invocari sincrone
    În invocările sincrone, serviciul care invocă lambda trebuie să aștepte până când rezultatele îi sunt returnate și apoi să continue restul procesului. De asemenea, putem spune că ieșirea funcției lambda este cerută de funcția sau serviciul însuși care a invocat această lambda.
  2. Invocari asincrone

    Aici, nu trebuie așteptat ca funcțiile lambda să ofere rezultatele înapoi către invocator. Acesta este utilizat în principal pentru notificări sau pentru a declanșa alte evenimente independente în AWS. Serviciul care dorește să invoce funcția lambda doar trimite declanșatorul și acea operație este pusă în coadă în lambda și va fi executată la rândul său.



Diferite moduri de a invoca Lambda

Aici, veți vedea numeroase moduri de a invoca funcțiile lambda. Știind acest lucru, vă este de mare ajutor data viitoare când vă proiectați infrastructura AWS simplă, dar eficientă din punct de vedere al costurilor.





Invocați direct funcțiile Lambda

În cele mai multe cazuri, funcțiile lambda sunt concepute pentru a fi declanșate folosind alte servicii, dar le puteți invoca direct folosind consola de management AWS, AWS CLI și prin adresa URL a funcției.

Invocarea Lambda din Consola de administrare

Când creați orice funcție lambda în consola dvs. AWS, o puteți declanșa cu ușurință folosind opțiunea de testare a rulării din consolă. The Test butonul este disponibil în secțiunea de cod a funcției lambda.



Puteți crea un eveniment personalizat și puteți utiliza consola cu modelul dvs. de eveniment personalizat.

În acest fel, funcția lambda poate fi declanșată din consola AWS.

AWS CLI

AWS vă oferă posibilitatea de a utiliza toate resursele sale folosind interfața de linie de comandă AWS. Orice funcție lambda poate fi, de asemenea, invocată cu acest CLI. Acest lucru poate fi foarte eficient pentru a testa lucrurile în timpul etapelor de dezvoltare. Urmărirea comenzii AWS CLI poate fi folosită ca declanșator pentru a invoca funcția lambda.

[e-mail protejat] :~$ aws lambda invoke \
--nume-funcție < Introduceți numele funcției Lambda > \
--încărcătură utilă < Valoarea de intrare pentru Funcția Lambda > \
--cli-binary-format < baza64 | raw-in-base64-out > < Nume fișier de ieșire >

Funcția este declanșată cu succes și puteți observa acest lucru și în ieșire.

Adresa URL a funcției

Adresa URL a funcției este de fapt un punct final HTTP pe care îl puteți configura pentru funcțiile lambda. Această adresă URL poate fi utilizată pentru a declanșa funcțiile lambda și, de asemenea, puteți partaja această adresă URL cu alți utilizatori chiar și în afara contului dvs. AWS pentru a invoca funcțiile lambda. Deși ar trebui să fii atent cu adresele URL ale funcțiilor, oricine are acest link poate declanșa funcția lambda de nenumărate ori, iar toate costurile vor fi pe capul tău.

O adresă URL a funcției poate fi configurată în timpul creării, precum și după crearea funcției lambda. Pentru aceasta, pur și simplu accesați setările avansate din secțiunea de configurare și verificați Activați adresa URL a funcției cutie.

În cazul în care nu ați atașat o adresă URL a funcției în timp ce creați funcția lambda, o puteți face mai târziu. Pentru aceasta, trebuie să mergeți la fila de configurare, să selectați URL-ul funcției și să faceți clic pe Creați adresa URL a funcției .

În acest fel, URL-ul funcției este creat și utilizat pentru a invoca funcția lambda.

Invocați funcții Lambda utilizând serviciile AWS

O mulțime de servicii AWS pot fi configurate ca declanșator pentru a invoca funcția lambda. Trebuie doar să configurați serviciile AWS ca declanșator pentru a invoca funcția lambda. Aici, parcurgem toate aceste servicii cu o explicație despre cum să le folosiți ca declanșatoare lambda.

Gateway API

Acesta este un serviciu AWS care este utilizat pe scară largă pentru a crea și gestiona API-urile din modelul dvs. de aplicație. API-urile oferă o modalitate foarte flexibilă de a genera solicitări sau apeluri de la un pachet software la un alt pachet pe care nu le putem expune direct și dorim doar să le păstrăm în culise.

Pentru a adăuga orice serviciu ca declanșator la funcția lambda, pur și simplu accesați funcția lambda și faceți clic pe adăugare declanșator.

Apoi, puteți selecta serviciul pe care doriți să îl atașați ca declanșator la funcția dvs. lambda. Pentru această secțiune, selectăm gateway-ul API ca declanșator pentru funcția lambda.

Apoi, configurați serviciul așa cum doriți să acționeze în structura aplicației dvs.

Există două tipuri de API-uri acceptate de gateway-ul API și acestea pot fi utilizate pentru a invoca o funcție lambda.

API-uri HTTP : sunt folosite pentru a genera punctele finale HTTP care sunt direcționate către funcțiile dumneavoastră lambda. API-urile HTTP oferă mai puține funcționalități și sunt mai puțin costisitoare de utilizat.

API-urile REST : Dacă doriți mai multe funcții în API-ul dvs., trebuie să alegeți un API REST. Aceste API-uri pot invoca funcția lambda și pot folosi aceleași metode HTTP, oferind mai multă flexibilitate și independență.

Găleată S3

Există o mulțime de cazuri de utilizare în care veți vedea că gălețile S3 acționează ca un declanșator pentru a invoca funcția lambda. Puteți configura o găleată S3 pentru a declanșa funcția lambda pentru un anumit eveniment S3.

De exemplu, doriți să colectați metadatele oricărui fișier atunci când este încărcat în compartimentul dvs. Pentru aceasta, dezvoltați un cod și îl implementați pe funcția lambda. Pentru declanșatorul Lambda, selectați găleata S3. Pentru tipul de eveniment, selectați pune obiect . Astfel încât, ori de câte ori un fișier nou este adăugat în găleată, funcția lambda este declanșată și metadatele obiectului sunt colectate și stocate în locația de destinație atunci când specificați.

Pot exista multe alte scenarii în care S3 poate fi folosit ca declanșator pentru a invoca funcția lambda.

Echilibrarea greutății

Să presupunem că aplicația dvs. este proiectată să ruleze pe funcții lambda, deoarece funcția lambda este soluția cea mai rentabilă pentru o aplicație simplă bazată pe cloud. Acum, pentru a vă expune aplicația utilizatorilor finali, este posibil să doriți să atașați un echilibrator de încărcare în fața acesteia. Pentru această secțiune, selectați echilibrul de încărcare care acționează ca declanșator pentru a invoca funcția lambda. Amintiți-vă că puteți configura doar echilibrul de încărcare al aplicației pentru această sarcină, deoarece alte dispozitive de echilibrare a încărcăturii nu sunt acceptate de funcțiile lambda.

Pentru a adăuga echilibrul de încărcare a aplicației la funcția lambda, mai întâi trebuie să creați un grup țintă, iar funcția lambda este adăugată la acel grup țintă. Acum, grupul țintă nou creat poate fi adăugat la ascultătorii aplicației de echilibrare a încărcăturii.

CloudFront

Amazon CloudFront este de fapt un CDN (Content Delivery Network) și este folosit pentru a stoca în cache datele aplicației în locații marginale care sunt mult mai apropiate de utilizatorii finali în comparație cu serverele de aplicații reale. Folosind CloudFront, puteți îmbunătăți cu adevărat timpul de răspuns pentru a oferi conținut static utilizatorilor finali de pe tot globul.

Funcțiile lambda pot fi declanșate folosind serviciul CloudFront. Pentru aceasta, trebuie să implementați funcția lambda în locații de margine de pe tot globul, cunoscute ca [e-mail protejat]

Puteți seta CloudFront ca declanșator pentru a trimite solicitările către [e-mail protejat] prin CloudFront pentru a îmbunătăți timpul de răspuns. Dupa cum [e-mail protejat] este implementat în toate locațiile de margine de pe tot globul, utilizatorii finali se confruntă cu un timp de răspuns minim accesând cea mai apropiată locație de margine instalată lambda.

Pentru a configura acest lucru, accesați pur și simplu adăugați declanșator și alegeți serviciul CloudFront. Acolo, vei vedea disloca la [e-mail protejat] opțiune.

Acum, trebuie doar să finalizați pașii de configurare și să începeți.

Jurnalele CloudWatch

Ori de câte ori vă gândiți la monitorizarea în cloud-ul AWS, primul lucru care vă vine în minte este CLoudWatch, deoarece acesta este un serviciu de monitorizare foarte vast care poate fi configurat pentru diferite servicii într-un mod foarte util.

Jurnalele CloudWatch, așa cum definește și numele, este un serviciu de înregistrare care poate fi folosit pentru a stoca tot felul de jurnale. Puteți crea diferite grupuri de jurnal pentru diferite servicii pentru a păstra jurnalele separate. Aceste jurnale pot fi folosite pentru a declanșa funcția lambda pe baza evenimentelor pe care le primesc, indiferent de serviciul sau procedura care produce aceste evenimente.

Puteți configura declanșatorul fie din consola funcției lambda, fie direct din jurnalele CloudWatch. Pentru a face acest lucru din consola CloudWatch, pur și simplu accesați serviciul CloudWatch și deschideți grupurile de jurnal. Aici, trebuie să creați un filtru de abonament lambda.

Apoi, alegeți funcția lambda pe care o doriți și sunteți gata.

Acum, ori de câte ori CloudWatch primește acel flux de jurnal, acționează ca un declanșator pentru a invoca funcția lambda.

EventBridge

Amazon EventBridge (cunoscut anterior ca CloudWatch Events) este un serviciu AWS care vă permite să creați reguli de eveniment pentru a declanșa un anumit serviciu AWS la un anumit eveniment care are loc într-un cont AWS.

Există o mare varietate de reguli pe care le puteți seta pentru serviciile AWS (cum ar fi crearea instanțelor EC2 sau evenimentele bazei de date RDS), precum și pentru serviciile terțelor părți (cum ar fi evenimentul push GitHub). Aceste reguli pot fi conectate în continuare cu alte servicii, cum ar fi funcțiile lambda, în așa fel încât ori de câte ori această regulă este îndeplinită, invocă funcția lambda.

Dacă aveți deja setată o regulă EventBridge, puteți adăuga cu ușurință această regulă ca declanșator la funcția lambda. Selectați EventBridge ca declanșator și furnizați pur și simplu numele regulii.

O regulă existentă este adăugată aici ca declanșator, dar puteți crea și o regulă în acest moment.

DynamoDB

S-ar putea să fi știut că DynamoDB este doar o bază de date NoSQL și apare ca un serviciu complet separat în AWS. Aceasta este o bază de date fără server complet configurată și puteți începe direct să creați tabele în ea. Aceste tabele DynamoDB pot fi configurate să acționeze ca declanșatori pentru a invoca funcțiile lambda.

Datele din DynamoDB pot fi încărcate în lambda ca intrare sub formă de loturi și sunt procesate folosind codul care este implementat în lambda.

Kinesis

Dacă doriți să colectați și să analizați datele în timp real la o rată ridicată, puteți beneficia de AWS Kinesis. Să presupunem că doriți să procesați datele colectate de fluxurile de date Kinesis folosind funcțiile lambda. Trebuie pur și simplu să declanșați funcția lambda de fiecare dată când datele sunt înregistrate de Kinesis.

Tocmai ați terminat de configurat fluxul de date Kinesis pentru a invoca funcția lambda.

SNS

Este pur și simplu un serviciu de notificare care este folosit în mod obișnuit pentru a trimite notificări de la un serviciu AWS la altul, deoarece uneori nu există nicio modalitate de a configura notificările direct de la un serviciu la altul. Funcțiile lambda pot fi declanșate folosind acest serviciu.

Creați mai întâi un subiect SNS, apoi utilizați-l pentru a vă invoca funcția lambda.

Trebuie să selectați numele subiectului dvs. SNS. Nu există alte configurații sau setări.

Concluzie

Amazon Lambda este cu adevărat o descoperire în arhitectura cloud. Dezvoltarea și implementarea aplicațiilor nu au fost niciodată atât de ușoare și directe înainte. Vă permite să vă creați pur și simplu codul în orice cadru comun și să încărcați codul în lambda și este executat. Există o listă lungă de alte servicii care pot fi cuplate cu AWS lambda și acționează ca un declanșator pentru a invoca funcția lambda numai atunci când este necesar. Nu există un cost de funcționare continuu al serverului, dar veți fi taxat în funcție de numărul de declanșatoare și timpul de execuție a codului.