از آنجا که ردیس دیگر یک نرمافزار آزاد نیست و البته همان موقع هم که بود چندان چیز جالبی نبود (دو نقطه دی) قصد دارم پیشنهاد یک نرمافزار آزاد بدهم که ردیس هست اما ردیس نیست! :))
با موفقیت پروژههایی مثل solidcache در روبی، به این فکر افتادم که چرا جای رم از هارد استفاده نکنیم؟ مخصوصا که solidcache دارد پشتش از یک پایگاه دادهای مرسوم (در حال حاضر یکی از سه مورد sqlite یا mysql یا postgres را) استفاده میکند و همین موضوع ایده یک کش مبتنی بر هارد - و به طور خاصتر SSD - را به ذهنم رساند که مسائل مصرف حافظه و برپاسازی ردیس را نداشته باشد و در عین حال سرعت و بازدهی نزدیک به ردیس هم بدهد.
در سطح پروتکل که همان پروتکل ردیس را پشتیبانی کند. اما برای خود کش، به جای یک پایگاه دادهای بیرونی از یک پیادهسازی بهینه B+-tree و Hash tree استفاده شود. البته میشود از همان sqlite و solidcache هم استفاده کرد و صرفا پروتکل ردیس را روی آن آورد. این شکلی هزینه نهایی پیادهسازی کمتر هم میشود. اما احتمالا برای پروژههای بزرگ - به علت محدودیتهای خود sqlite - کارا نباشد.
با این حال در صورتی که از یک hash tree دو مرحلهای به عنوان کلید و یک B+tree به عنوان اندیس استلفاده شود احتمالا بازدهی معقولتری از استفاده از یک پایگاهدادهای مجزا بگیریم زیرا سربار شبکه و سربار خود پایگاه دادهای هم حذف شده و فقط همان قسمتی که مورد استفاده است پیادهسازی شده است.
اما ممکن است بپرسید این B+tree چیست؟ آن را سعی میکنم در مطلبی دیگر مفصلتر توضیح دهم. عجالتا بدانیم که یک ساختمان دادهای بهینهشده برای دسترسی و جست و جوی داده روی انواع دیسکهای سخت است کفایت میکند. یک hash tree اما در واقع نوعی از interval tree است که کلیدهای آن به جای بازههای عددی مقادیر hash هستند. این شکلی پیدا کردن یک کلید در کش مساوی است با هش کردن آن، پیدا کردن جایگاه آن در hash tree و سپس درخواست داده متناظر با آن کلید در B+tree. این شکلی پیادهسازی به شدت ساده و به شدت بهینه میشود.
پیشنهاد دیگر البته آن است که این چیزی که در بالا توضیح دادم در خود solidcache پیادهسازی شود و سپس پروتکل ردیس هم به آن اضافه گردد. این شکلی هم پروژه بالادستی سود میبرد که بسیاری دارند از آن استفاده میکنند و هم ما یک جایگزین آزاد و البته بسیار بهینه برای ردیس داریم که از پارادایم ردیس خارج شده و با هزینههای اجرایی و عملیاتی کمتر همان کارایی را به ما خواهد داد.
عکس مطلب نماگرفتی از readme پروژه solidcache است. همچنین این مطلب اولین بار برای ارائه در دونا نوشته شده است.
Comments
October 28, 2024 12:44
seo
You completed a few fine points there. I did a search on the subject and found nearly all persons will go along with with your blog. łóżka piętrowe dla dzieci
October 29, 2024 07:07
seo
Positive site, where did u come up with the information on this posting? I’m pleased I discovered it though, ill be checking back soon to find out what additional posts you include. 1xbet sn
November 5, 2024 17:10
The best 1xBet promo code: 1XBIG777, you will be able to get a 100% welcome bonus up to $130 on sports and up to $1,500 bonus and 150 free spins on the casino. The bonus will be activated only once you have made a first payment. This welcome bonus will be equivalent to 100% on your account, up to approximately $130 or an amount equivalent to their currency. 1xbet registration promo code
November 7, 2024 11:42
I just couldn’t leave your website before telling you that I truly enjoyed the top quality info you present to your visitors? Will be back again frequently to check up on new posts. togelonline
November 9, 2024 12:54
You have done a great job on this article. It’s very readable and highly intelligent. You have even managed to make it understandable and easy to read. You have some real writing talent. Thank you. point buy calculator 5e
November 9, 2024 13:33
I wanted to thank you for this great read!! I definitely enjoying every little bit of it I have you bookmarked to check out new stuff you post. 슬롯사이트
November 9, 2024 13:48
You know your projects stand out of the herd. There is something special about them. It seems to me all of them are really brilliant! 바카라사이트
November 9, 2024 13:59
Link slot gacor terbaru dari situs Jackpot86 JP86 yang telah dinobatkan sebagai situs slot demo pg zeus jp anti rungkad resmi dan terpercaya. Salam JP slot gacor
October 21, 2024 06:23
Wonderful article. Fascinating to read. I love to read such an excellent article. Thanks! It has made my task more and extra easy. Keep rocking. kinggame