Web kancaları ve WebSockets, insanların sıklıkla karıştırdığı iki web geliştirme teknolojisidir. Birçok modern web uygulaması hem Webhooks'u hem de WebSocket'i kullanır. Oldukça farklı olmasına rağmen, Webhooks ve WebSockets, web uygulamalarında iletişimi ele alır.
Peki Web kancaları ve WebSockets nedir? Onları farklı kılan şeyler nelerdir?
Web kancaları nedir ve nasıl çalışırlar?
Bir Web kancasını “olayla tetiklenen HTTP isteği” olarak düşünebilirsiniz. Ne anlama geliyor? Web kancası, genellikle bir sunucudaki bir olay tarafından tetiklenen bir HTTP geri arama eylemidir. Hepsi bu kadar değil, genellikle önceden yapılandırılmış bir URL aracılığıyla başka bir sunucuya veri gönderir. Bu, Web kancalarının "sunucudan sunucuya" bir iletişim aracı olduğu fikrini doğurur.
Web kancalarının çalışma mekanizmasını daha iyi anlamak için ödemeleri almak için Stripe API'sini kullanan bir web uygulamasını düşünün. Bir müşteri ödeme yaptığında, Stripe parayı alır, ancak uygulamanızın hiçbir fikri yoktur. Web kancalarının devreye girdiği yer burasıdır. Aşağıdaki resmi düşünün:
Stripe, yeni bir ödeme olayı tetiklendiğinde müşterinin ödeme verilerini sunucunuza göndermek için bir Webhook bitiş noktası URL'si sağlamanızı gerektirir. Sunucunuz daha sonra verileri alır, üzerinde işlemler gerçekleştirir ve kalıcı verileri veritabanına kaydeder.
WebSockets Nedir ve Nasıl Çalışırlar?
WebSocket, genellikle JavaScript ile kullanacağınız bir protokoldür.. İki yönlü, kalıcı, çift yönlü bir iletişim kanalı kurar. Bunu tek seferde yapıyor iki TCP bağlantı noktası arasında yapılan bağlantı bir istemciden (tarayıcı) bir sunucuya. WebSockets'in en popüler uygulaması WhatsApp gibi sohbet uygulamalarıdır.
Web kancaları HTTP tabanlı olsa da (yani HTTP protokolünü kullanır), WebSocket, tıpkı HTTP gibi TCP'ye dayanan kendi başına bir protokoldür. WebSockets, düşük gecikmeli sunucu-istemci veri akışı uygulamaları üzerinde çalışırken çok faydalı olabilir.
Varsayılan HTTP'nin aksine işlemler arasında açık kaldığı için WebSocket bağlantısıyla düşük gecikme süresi elde edebilirsiniz. Bu, verilerin her iki taraf arasında sorunsuz bir şekilde akmasını sağlar.
WebSockets'ten önce geliştiriciler, HTTP üzerinden gerçek zamanlı veri almak için çeşitli yöntemler kullandılar. Bir süredir buralarda olmalarına rağmen, sınırlamalardan muzdaripler.
Örneğin, uzun yoklama, istemcinin belirli bir zaman aralığında sunucuya her zaman yeni bir istek göndermesini gerektirir. Bu, sunucuda yeni veri olduğunda onu döndürdüğü anlamına gelir. Ancak yoksa, istek etkin bir şekilde boşa harcanır.
Web kancalarından farklı olarak, WebSocket bağlantısının her iki ucu da diğerine veri gönderebilir. Bu, WebSockets'in özellikle sunucudan istemciye veri gönderilirken büyük bir hız avantajı sunmasının bir nedenidir. WebSockets kullanan uygulamalar, sunucudan veri alırken düşük gecikme süresinden yararlanmalıdır.
WebSockets'i de HTTP gibi TLS üzerinden kullanabilirsiniz. Bu, ilettiğiniz verilerin güvenliğini sağlayarak ortadaki adam saldırıları. Kalıcı bir bağlantı bile bu yaklaşımla güvende kalacaktır. Saldırganların verileri çalması veya iletişimi bozması konusunda endişelenmenize gerek kalmayacak.
Web kancalarını ne zaman kullanmalısınız?
Web kancaları ve WebSockets, web üzerinden daha iyi gerçek zamanlı iletişim araçları uygulamayı amaçlar. Ancak, bunu tamamen farklı şekillerde yaparlar. Uygulamanızda bu iki teknolojiden hangisini kullanmanız gerektiğine karar vermek genellikle zor olabilir. Hangisinin gereksinimlerinizi en iyi şekilde karşıladığını görmek için güçlü ve zayıf yönlerine dikkat etmelisiniz.
Peki, WebSockets yerine Webhooks'u ne zaman seçmelisiniz?
- Sahibi olmadığınız bir API'yi tüketirken. Önceki Webhook resmindeki Stripe örneğini düşünün. Stripe bir ödeme hizmeti sağlayıcısıdır ve uygulamanız yalnızca API'lerinin üzerine inşa edilebilir. Stripe üzerinde hiçbir kontrolünüz yok, bu yüzden onların sonunda bir WebSocket sunucusu oluşturamazsınız. Bu gibi durumlarda Webhooks kullanmalısınız.
- Uygulamanız başka bir sunucuyla iletişim kurması gereken bir sunucuysa, Web kancalarını kullanmak en iyisidir. Bu ideal "sunucudan sunucuya" iletişim sistemidir.
- Web kancaları çift yönlü veya kalıcı değildir. Web kancalarını yalnızca uygulamanız aynı kanal üzerinden yanıt verisi beklemiyorsa kullanmalısınız.
- Web kancalarının, sunucusuz işlevler olarak çalışan sunucu işlemleri için ideal yol olduğu da dikkate değerdir. Örnekler arasında AWS Lambda ve Google bulut işlevleri yer alır.
Web kancaları ile deneme yapabilirsiniz webhook.site. Bu site, bir Web kancasının uygulamanıza gönderdiği verilerin nasıl görüneceğini görmenizi sağlar. Uygulamanızda bir uç nokta uygulamaya çalışmadan önce bir Web kancasının iletişiminin doğasını anlamak çok faydalıdır.
WebSockets'i Ne Zaman Kullanmalısınız?
Gerçek zamanlı uygulamalar, bildirim sistemleri ve canlı veri paylaşım sistemleri, WebSockets'in bazı yaygın uygulamalarıdır. WebSockets ile bağlantı kanalının her zaman açık olması gerektiğini akılda tutarak, bu protokolün yalnızca maliyeti buna değdiğinde kullanılmalıdır.
- Uygulamanız istemci ve sunucu arasında sürekli veri alışverişi yaptığında WebSockets kullanmalısınız. Örneğin, canlı bir konum paylaşım uygulamasında, bir kullanıcının konumu, hareket ettikçe hem sunucuda hem de istemcide sürekli olarak güncellenir. WebSockets bunu mümkün kılar.
- WhatsApp gibi multimedya iletişim uygulamalarında WebSocket ideal iletişim protokolüdür. Bu tür uygulamaların merkezinde yer alan çok hızlı çift yönlü veri alışverişine olanak tanır.
- WebSockets'i ayrıca Livescore gibi gerçek zamanlı beslemeleri uygulayan uygulamalarda da kullanmalısınız. Bu web sitesi, gerçek zamanlı olarak canlı futbol maçı güncellemelerini paylaşır. Ancak bunu yeni isteklerde bulunmanıza veya tarayıcınızı yenilemenize gerek kalmadan yapar.
- WebSockets kullanmanız gereken diğer durumlar arasında canlı video/ses akışı uygulamaları, canlı bildirim sistemleri ve gerçek zamanlı çok oyunculu oyunlar bulunur. Ayrıca Google Dokümanlar, Notion vb. gibi ortak düzenleme uygulamalarında da faydalıdırlar.
Web kancaları ve WebSockets Farklıdır
Webhooks ve WebSockets benzer sorunları çözse de, bunların aynı olmadığı ve her birinin kendine özgü kullanım durumları olduğu açıktır. Web kancaları, HTTP protokolüne dayalı tek yönlü, olayla tetiklenen geri aramalardır. WebSocket teknolojisi, istek olmadan çift yönlü veri alışverişine izin veren bağımsız bir protokoldür.
Kaynak israfını önlemek için bir uygulama oluştururken ihtiyacınızı her zaman belirlemeniz önemlidir. Bazı durumlarda Webhooks'u tercih etmelisiniz, çünkü WebSockets bazen maliyet engelleyici olabilir. Bunları yalnızca gerektiğinde kullandığınızdan emin olun.