Webhook-urile și WebSocket-urile sunt două tehnologii de dezvoltare web pe care oamenii le confundă adesea. Multe aplicații web moderne folosesc atât Webhooks, cât și WebSockets. Deși destul de diferite, Webhook-urile și WebSocket-urile abordează comunicarea în aplicațiile web.
Deci, ce sunt Webhook-urile și WebSocket-urile? Care sunt lucrurile care le fac diferite?
Ce sunt webhook-urile și cum funcționează?
Vă puteți gândi la un Webhook ca la o „cerere HTTP declanșată de eveniment”. Ce inseamna asta? Un Webhook este o acțiune HTTP de apel invers declanșată de obicei de un eveniment pe un server. Asta nu este tot, de obicei trimite date printr-o adresă URL preconfigurată către un alt server. Acest lucru naște ideea ca Webhook-urile să fie un mijloc de comunicare „de la server la server”.
Pentru a înțelege mai bine mecanismul de funcționare al Webhooks, luați în considerare o aplicație web care utilizează API-ul Stripe pentru a primi plăți. Ori de câte ori un client face o plată, Stripe primește banii, dar aplicația ta habar nu are. Aici intervin Webhook-urile. Luați în considerare imaginea de mai jos:
Stripe vă solicită să furnizați o adresă URL a punctului final Webhook pentru a trimite datele de plată ale clientului către serverul dvs. atunci când este declanșat un nou eveniment de plată. Serverul dvs. primește apoi datele, efectuează operațiuni pe ele și salvează date persistente în baza de date.
Ce sunt WebSocket-urile și cum funcționează?
WebSocket este un protocol pe care îl veți utiliza de obicei cu JavaScript. Acesta stabilește un canal de comunicare bidirecțională, persistentă, bidirecțională. O face peste un singur conexiune realizată între două porturi TCP de la un client (browser) la un server. Cea mai populară aplicație a WebSockets este în aplicațiile de chat precum WhatsApp.
În timp ce Webhook-urile sunt bazate pe HTTP (adică folosesc protocolul HTTP), WebSocket este un întreg protocol în sine bazat pe TCP, la fel ca HTTP. WebSocket-urile pot fi foarte benefice atunci când lucrați pe aplicații de streaming de date server-client cu latență scăzută.
Puteți obține o latență scăzută cu o conexiune WebSocket, deoarece rămâne deschisă între tranzacții, spre deosebire de HTTP implicit. Acest lucru permite ca datele să circule fără probleme între ambele părți.
Înainte de WebSockets, dezvoltatorii foloseau diverse metode de obținere a datelor în timp real prin HTTP. Deși există de ceva vreme, suferă de limitări.
De exemplu, sondarea lungă necesită ca clientul să trimită întotdeauna o nouă cerere către server la un interval de timp specificat. Aceasta înseamnă că atunci când există date noi pe server, le returnează. Dar dacă nu există, cererea este efectiv irosită.
Spre deosebire de Webhooks, oricare capăt al unei conexiuni WebSocket poate trimite date celuilalt. Acesta este unul dintre motivele pentru care WebSockets oferă un avantaj uriaș de viteză, mai ales atunci când datele sunt trimise de la server la client. Aplicațiile care utilizează WebSockets ar trebui să beneficieze de o latență scăzută atunci când preiau date de pe server.
Puteți utiliza WebSockets și peste TLS, la fel ca HTTP. Acest lucru securizează datele pe care le transmiteți, ajutând la atenuare atacuri de tip om-in-the-middle. Chiar și o conexiune persistentă va rămâne sigură cu această abordare. Nu va trebui să vă faceți griji că atacatorii vor fura date sau că comunicațiile le vor corupe.
Când ar trebui să utilizați webhooks?
Webhooks și WebSockets urmăresc să implementeze mijloace mai bune de comunicare în timp real pe web. Cu toate acestea, o fac în moduri total diferite. Poate fi adesea o provocare să decideți care dintre aceste două tehnologii ar trebui să utilizați în aplicația dvs. Ar trebui să acordați o atenție deosebită punctelor forte și punctelor lor slabe pentru a vedea care corespunde cel mai bine cerințelor dvs.
Deci, când ar trebui să alegeți Webhooks în locul WebSockets?
- Când consumați un API pe care nu îl dețineți. Luați în considerare exemplul Stripe din ilustrația anterioară a Webhook. Stripe este un furnizor de servicii de plată, iar aplicația dvs. se poate construi numai pe baza API-ului lor. Nu aveți control asupra Stripe, așa că nu puteți crea un server WebSocket la sfârșitul lor. În astfel de cazuri, ar trebui să utilizați Webhooks.
- Dacă aplicația dvs. este un server care trebuie să comunice cu un alt server, cel mai bine este să utilizați Webhooks. Acesta este sistemul de comunicare ideal „de la server la server”.
- Webhook-urile nu sunt bidirecționale sau persistente. Ar trebui să utilizați Webhook-uri numai atunci când aplicația dvs. nu așteaptă date de răspuns pe același canal.
- De asemenea, este de remarcat faptul că Webhook-urile sunt calea ideală pentru operațiunile de server care rulează ca funcții fără server. Exemplele includ AWS Lambda și funcțiile cloud Google.
Puteți experimenta cu Webhooks activat webhook.site. Acest site vă permite să vedeți cum vor arăta datele pe care un Webhook le trimite către aplicația dvs. Este foarte util să înțelegeți natura comunicării unui Webhook înainte de a încerca să implementați un punct final în aplicația dvs.
Când ar trebui să utilizați WebSockets?
Aplicațiile în timp real, sistemele de notificare și sistemele de partajare a datelor în direct sunt câteva aplicații comune ale WebSockets. Ținând cont de faptul că, cu WebSockets, canalul de conexiune trebuie să fie întotdeauna deschis, acest protocol ar trebui utilizat numai atunci când costul merită.
- Ar trebui să utilizați WebSockets atunci când aplicația dvs. face schimb continuu de date între client și server. De exemplu, într-o aplicație live de partajare a locației, locația unui utilizator este actualizată continuu atât pe server, cât și pe client, pe măsură ce se deplasează. WebSockets fac acest lucru posibil.
- În aplicațiile de comunicare multimedia precum WhatsApp, WebSocket este protocolul de comunicare ideal. Permite un schimb de date bidirecțional foarte rapid, care este esențial pentru aceste tipuri de aplicații.
- De asemenea, ar trebui să utilizați WebSockets în aplicații care implementează fluxuri în timp real, cum ar fi Livescore. Acest site web oferă actualizări live despre meciurile de fotbal, așa cum se întâmplă în timp real. Dar face acest lucru fără a fi nevoie să facă noi solicitări sau să vă solicite să vă reîmprospătați browserul.
- Alte cazuri în care ar trebui să utilizați WebSockets includ aplicații de streaming video/audio live, sisteme de notificare live și jocuri multiplayer în timp real. De asemenea, sunt utile în aplicații de editare colaborativă precum Google Docs, Notion etc.
Webhook-urile și WebSocket-urile sunt diferite
Este clar că, deși Webhook-urile și WebSocket-urile rezolvă probleme similare, ele nu sunt la fel și fiecare are propriile sale cazuri de utilizare. Webhook-urile sunt apeluri unidirecționale, declanșate de evenimente, bazate pe protocolul HTTP. Tehnologia WebSocket este un protocol de sine stătător, care permite schimbul bidirecțional de date fără solicitări.
Este important să vă identificați întotdeauna nevoia atunci când construiți o aplicație pentru a evita risipa de resurse. În unele cazuri, ar trebui să preferați Webhooks, deoarece WebSockets poate fi uneori prohibitiv. Asigurați-vă că le folosiți numai atunci când este necesar.