Azure Storage - Queue Nedir?

   

Azure Storage servisleri içerisinde Queue, Blob, Table, File(preview) gibi farklı depolama seçenekleri var, ben bu post'ta Queue'ya değineceğim.

Nedir bu Queue?

Queue, türkçede kuyruk.

Bilgisayar mühendisliği veya benzeri bölümler okuyan arkadaşların iyi hatırlayacağı üzere queue(kuyruk) bir abstract data type (ADT), aslında bakarsanız Azure üzerinde kuyruk kullanmak o derste öğretilen kadar zor ve karmaşık değil.

   

Yukarıdaki resim MSDN'den aldığım bir image ve bence kuyruğu en iyi ifade eden görsellerden biri.

Öncelikle bileşenleri tanıtıyım,

  • Solda görmüş olduğunuz Web Role -> bildiğiniz web sitesi
  • Orta ve aşağıdaki Windows Azure Queue -> türkçesi kuyruk, bu arkadaşın nasıl çalıştığını anlamaya çalışıyoruz.
  • Sağdaki Worker Role -> basit olarak anlatmak gerekirse sürekli çalışan bir program.

   

Yukarıdaki görselde gördüğünüz gibi kuyruğa sürekli web sitesi tarafından bir şeyler ekleniyor ve worker role bunları okuyup işliyor. Tam olarak üniversitelerde öğrenmiş olduğumuz kuyruk yapısı gibi "FIFO" first-in-first-out çalışmıyor aslına bakarsanız. Buna daha sonra değiniriz.

   

Örnek senaryo

Bir e ticaret sitemiz olduğunu düşünelim ve kullanıcı ödeme işlemenini yaptıktan sonra 3 farklı işlem yapılması gerektiğini düşünelim.

  • Satış stok takip programına işlenmeli
  • Kargo firmasının api'lari ile işlem yapılmalı
  • Kullanıcıya mail atılmalı

Bu işlemlerin hepsi kullanıcı ödemesini tamamladıktan sonra yapılmalı. Baktığımızda bu işi buton'a basıldığında yapabiliriz diye düşünebiliriz ancak gerçekte iş biraz daha karışık. Butona basıldığı anda bu kadar işi bir anda yaparsanız kullanıcı cok fazla bekler belkide request timeout olur. Bu işlemlerden bazıları o anda teknik sebeplerden ötürü yapılamaya bilir ve sizin bir retry logic kurmanız gerebilir. Bu konuların hepsinden kaçınıp kuyruk kullanarak bu senaryoyu başarabiliriz.

Nasıl yapmalıyız?

Kullanıcı ödeme işlemini tamamladığından bu satış işleminin identifier'ini web sitesi kuyruğa koyar. Worker role bu kuyruğu sürekli kontrol eder ve satış bilgisi geldiği anda yukarıdaki 3 adımı sırası ile gerçekleştirir. Eğer bir hata oluşursa otomatik olarak kuyruğa tekrar ekler ve ilerleyen zamanlarda tekrar dener.

   

Dizayn olarak bakacak olursak, bu yapıyı kullanarak sistemlerimizi birbirinden bağımsız hale getirirerek daha iyi bir mimari dizayn ortaya koyabiliriz. Örneğin bizim birden çok e ticaret sitemiz var ancak hepsi için az önce yukarıda anlattığımız senaryo aynı, bütün siteler tek depo ile çalışıyor ve aynı kargo firması ile çalışıyor. Bu durumda farklı web sitelerimiz aynı kuyruğa mesaj koyabilir ancak okuyacak worker role bunların nereden geldiğini önemsemeden alır ve işler böylece sistemimiz daha güzel bir mimariye sahip olmuş olur. Sistemin bileşenleri arasında bağımlılık en aza indirilmiş olur. Keyword: decoupling

   

Azure Queue'da mesaj aynı anda sadece bir alıcıya ulaşır. Yani eğer sizin iki tane worker role'unuz var ve aynı kuyrugu kontrol ediyorsa bunlardan biri mesajı alır ve diger alamaz. Birbirlerinden mesajları çalarak ilerlerler. Eğer sisteminizde bir worker role yetmiyorsa ikinci worker role'u eklerseniz sisteminizin çalışma hızı yaklaşık 2 ye katlanmış olur. Eğer mesajların aynı anda iki worker role'ede iletilmesini istiyorsanız Service Bus'ı kullanmayı düşünmelisiniz.

Xamarin Ücretsiz Öğrenci Lisansı

Xamarin ile C# kullanarak Android, IOS ve Windows Phone platformlarına cross platform uygulama yazmak mümkün. Mümkün olduğunca tek kodun Android, IOS ve Windows Phone'da çalışmasını sağlıyor. Aslına bakarsanız gün geçtikçe iyi noktaya geldi. Channel9 takip ediyorsanız konu ile ilişkili güzel videolar olduğunu elbet görmüşsünüzdür.

   

Microsoft teknolojilerini temel alarak bu kadar farklı platforma ulaşmak açıkcası heyecan verici.

   

Geçen akşam, Xamarin lisans modellerini incelerken https://xamarin.com/student sayfası ile karşılaştım. Bu link ile beraber üniversite öğrencilerine ücretsiz indie lisans sağlıyorlar. 24 saat içerisinde başvuruma karşılık geldi ve benden öğrenci belgesi istediler, öğrenci belgesi gönderdikten hemen sonra belgemi doğruladıklarını söyleyen bir mail aldım. Bu mailde link ile beraber ürünü lisansımı aktifleştirdim.

   

Madem andriod ve ios'a uygulama yazmak istiyorsun neden kendi dilleri ile native app yazmıyorsun diyenler oluyor. Ancak bugune kadar öğrendiğim C# , .net gibi Microsoft teknolojilerini temel alarak IOS ve Android uygulaması yazmak bence daha heyecan verici özellikle arkasında Azure var ise. Backendde Azure olan güzel cross platform uygulamalarımı bekleyin ... :)