İçeriğe Atla Menüye Atla
 

FilBlog

Sağladığımız hizmetler ile ilgili işinize yarayabilecek kısa bilgiler
filblog

Ölçeklenebilir Web Uygulamaları Nasıl Oluşturulur

Büyük bir web projesi geliştirmeyi planlıyorsanız, doğru ölçeklendirme hakkında düşünmeniz gerekir . Zaten tamamlanmış olan projedeki değişiklikler çok daha fazla çaba gerektireceğinden, tasarımdan önce bu sorun daha iyi çözülür.

Bir web uygulamasının ölçeklendirilmesi, bir projenin aynı görevleri gerçekleştiren fonksiyonel modüllerin sayısını artırarak kapasitesini artırma yeteneğidir .

Tipik olarak, ölçeklendirme mevcut sistem mevcut yüke dayanmadığında düşünülmeye başlar. Bunların çoğu, yüksek yüke sahip kamu siteleri gibi büyük projelerdir. En basit çözüm, sunucunun gücünü artırmaktır . Bunu yapmak için, sağlayıcıdan donanım güncellemesi sipariş etmek yeterlidir. Bu, soruna kısa vadeli bir çözümdür ve genelde bu yeterli değil. Mevcut bir sistemi yeniden tasarlamak çok fazla kaynak ve çaba gerektirir; bu nedenle geliştirmeye başlamadan önce ölçeklendirme seçeneklerini göz önünde bulundurmak akıllıca olacaktır. Bu, kararlı ve esnek bir web uygulaması oluşturmanıza olanak sağlar.

Her sitenin standart bir mimarisi yoktur, Ancak bir çok yazılım geliştirici şirket projeyi birkaç ana modüle bölmeyi tercih eder. Temelde ön uç (front-end), arka uç (back-end) ve veritabanı . Bu ileri düzey gelişmede büyük bir avantaj sağlar. Bu mimariyle, dosyalar arasındaki gezinme basitleştirilir ve sistem gelecekteki ölçeklendirme için çok daha esnek hale gelir. 

Arka uç (back-end) ölçeklendirme

Kural olarak, büyük projeler güçlü bir arka plana sahiptir. Karmaşık hesaplamaları işlemekle görevlendirilmiştir. Sıklıkla arka uç, web uygulamasının yavaş çalışmasının nedenidir. Karmaşık projeler geliştirme sürecinde, sorgu optimizasyonuna ve sunucu performansının rasyonel kullanımına dikkat edilerek geliştirilmelidir. Ancak yine de işler büyüdüğünde optimizasyon tek başına yeterli olmaz. Arka ucu birkaç sunucuya bölerek ölçeklendirmeye başlanabilir. Bazen bazı script ve modülleri ikinci sunucuya aktarmak yeterlidir. Bundan sonra, sorguları aralarında eşit olarak dağıtmanız gerekir. Bu, yükü ana sunucudan alıp başka bir donanıma yönlendirmeyi mümkün kılacaktır. Yönlendirmeler esas olarak ön uçta yapılır. Ancak proje ilerledikçe bu tip bir yük dağıtımı işleri daha da karmaşık hale getirecektir.

Başa çıkması daha kolay bir yaklaşım ise arka ucu birden çok makinada kopya olarak çalıştırmak ve bu makinalara giden yükü bir yük dengeleyicisi sistem ile dengelemektir. Bu şekilde iyi geliştirilmiş bir sistem ihtiyaç arttıkça yeni sunucular eklenerek yatay olarak ölçeklendirilebilir.

Veritabanını ölçeklendirme

Veritabanında çok miktarda veri varsa ve ayrı bir sunucu halinde bile yetersiz kalıyorsa veri tabanını ölçeklendirebilirsiniz. Veri tabanı ölçeklendirmede iki yaklaşım vardır:

  • Hesaplama işlemlerinin dağılımı. 
  • Veritabanını bölme.

Hesaplama işlemlerinin veritabanında dağıtımı

Büyük bir veritabanınız yoksa, sunucuyu yükleyen çok sayıda karmaşık hesaplamanız varsa, hesaplama işlemini ayırmanızı öneririz. Böylece, her sunucu veritabanının tam bir kopyasına sahip olacak ve yalnızca kendi sınırlı çalışma alanını gerçekleştirecektir. Bu, uygulamak için daha fazla çaba gerektiren daha karmaşık bir iştir. Her şeyden önce bu veritabanının her kopyasını güncel tutmak için gereken sunucular arasında veri senkronizasyonundan kaynaklanmaktadır.

Bu sorunu çözmenin birkaç yolu vardır:

  • Uygulama düzeyinde senkronizasyon. Bu durumda, komut dosyaları veritabanının her kopyasındaki değişiklikleri otomatik olarak kaydeder. Bu yaklaşımın birçok riski vardır, çünkü herhangi bir arıza veri senkronizasyonunu bozabilir.
  •  Çoğaltma. Bir "ana" sunucuda değişiklik yapmanıza izin verir, bundan sonra diğer sunucularda otomatik bir değişiklik olur.

Veritabanını bölme

Çok fazla hesaplama yapmıyorsanız, ancak veritabanı birçok öğeden oluşuyorsa (genellikle bu tür sorunların büyük e-ticaret web siteleri vardır ), bu durumda veritabanını birkaç sunucuya bölmeniz gerekir. Her sunucu bir miktar veriye sahip olacak ve diğer sunucularla etkileşime girecektir. Birkaç veri dağıtım şeması vardır

  •  Dikey bölümleme. Bu planın özü bazı tabloların başka bir sunucuya taşınmasıdır. Bu durumda, karmaşık SQL sorguları yapmanın bir yolu olmadığından esneklik kaybedilir. Veri tabanının doğru ve mantıklı bir şekilde bölünmesi durumunda, bu sorun en aza indirilebilir.
  • Yatay bölümleme. Bu düzende veritabanı tabloları birden çok sunucuya bölünür. Bu durumda, istekleri sunucular arasında doğru şekilde dağıtmak için arka uçta değişiklikler yapmanız gerekir.

Sonuç

Yükü fazla olan büyük projeler belli bir bilgi ve tecrübe gerektirir. Bir projeyi ölçeklendirmek, yazılım mimarisinin tasarımına başlamadan önce dikkate alınması gereken karmaşık bir süreçtir. Bu size gelecekte para ve zaman kazandıracaktır. Yüksek kaliteli bir sonuç almak için doğru mimariyi geliştirmeniz ve güvenilir sunucular kullanmanız gerekir.