Redis - Bölümleme
Bölümleme, verilerinizi birden çok Redis örneğine bölme işlemidir, böylece her örnek yalnızca anahtarlarınızın bir alt kümesini içerecektir.
Bölümlemenin Yararları
Birçok bilgisayarın bellek toplamını kullanarak çok daha büyük veritabanlarına izin verir. Bölümlere ayırmadan, tek bir bilgisayarın destekleyebileceği bellek miktarıyla sınırlandırılırsınız.
Hesaplama gücünü birden çok çekirdeğe ve birden çok bilgisayara ve ağ bant genişliğini birden çok bilgisayara ve ağ bağdaştırıcısına ölçeklemeye olanak tanır.
Bölümlemenin Dezavantajları
Birden çok anahtarı içeren işlemler genellikle desteklenmez. Örneğin, farklı Redis örnekleriyle eşlenen anahtarlarda depolanmışlarsa, iki küme arasında kesişim gerçekleştiremezsiniz.
Birden çok anahtarı içeren Redis işlemleri kullanılamaz.
Bölümleme granuliary anahtardır, bu nedenle bir veri kümesini tek bir dev anahtarla çok büyük sıralanmış bir küme gibi parçalamak mümkün değildir.
Bölümleme kullanıldığında, veri işleme daha karmaşıktır. Örneğin, birden çok RDB / AOF dosyasını işlemeniz gerekir ve verilerinizin yedeğini almak için, birden çok örnek ve ana bilgisayardan kalıcılık dosyalarını toplamanız gerekir.
Kapasitenin eklenmesi ve kaldırılması karmaşık olabilir. Örneğin, Redis Kümesi, çalışma zamanında düğüm ekleme ve kaldırma yeteneği ile çoğunlukla şeffaf veri dengelemesini destekler. Ancak, istemci tarafı bölümleme ve proxy'ler gibi diğer sistemler bu özelliği desteklemez. Denen bir teknikPresharding bu konuda yardımcı olur.
Bölümleme Türleri
Redis'te iki tür bölümleme vardır. Dört Redis örneğimiz olduğunu varsayalım, R0, R1, R2, R3 ve user: 1, user: 2, ... gibi kullanıcıları temsil eden birçok anahtarımız var.
Aralık Bölümleme
Aralık bölümleme, nesne aralıklarını belirli Redis örnekleriyle eşleyerek gerçekleştirilir. Örneğimizde, ID 0'dan ID 10000'e kadar olan kullanıcıların R0 örneğine gideceğini ve ID 10001'den ID 20000'e kadar olan kullanıcıların R1 örneğine gideceğini varsayalım.
Hash Bölümleme
Bu tür bölümlemede, anahtarı bir sayıya dönüştürmek için bir karma işlevi (örn. Modül işlevi) kullanılır ve ardından veriler farklı farklı Redis örneklerinde depolanır.