📎💡 توضیح ساده Read Your Own Writes Consistency یا (RYW) توی سیستمهای توزیعشده
📎💡 توضیح ساده Read Your Own Writes Consistency یا (RYW) توی سیستمهای توزیعشده
وقتی یه سیستم بزرگ داریم با تعداد زیاد کاربر یا درخواست همزمان، یکی از چالشهای اصلی اینه که هر کاربر بتونه تغییراتی که خودش ایجاد کرده رو بلافاصله ببینه. مثلاً وقتی توی یه شبکه اجتماعی پست میذارید، انتظار دارید همون لحظه پستتون رو ببینید، نه اینکه چند ثانیه صبر کنید. به این قابلیت میگن Read Your Own Writes یا RYW (خیلیجاها own حذف میشه و در نتیجه read your writes میشه RYW).
وقتی سیستمهامون کوچیکن، کار این موضوع آسونه؛ ولی هرچی سیستم بزرگتر و کاربرها بیشتر میشن، کار پیچیدهتر میشه. مثلاً تو سیستمهای توزیعشده (خصوصا دارای پراکندگی جغرافیایی و چند دیتاسنتری)، هماهنگی تغییرات میتونه باعث تأخیر بشه. یا وقتی از eventual consistency استفاده میکنیم، ممکنه یه تغییر جدید به کاربر نشان داده نشه چون اطلاعات هنوز بهروز نشدهاند. اینجاست که باید بین سرعت عملکرد و صحت دادهها تعادل برقرار کرد.
⚙️راهکارها:
*️⃣استفاده از region-aware routing یعنی تمام درخواستهای کاربر به یک منطقه مشخص هدایت بشه تا از تأخیرهای ناشی از تبادل داده بین مناطق مختلف جلوگیری بشه.
*️⃣استفاده از CRDTها (Conflict-Free Replicated Data Types) برای ادغام تغییرات هم به کار میرن تا توی مواقعی که چندین کاربر همزمان روی یه داده تغییر ایجاد میکنن، همگی به صورت یکپارچه بهروز بشن
*️⃣استفاده از Session Token یعنی اطلاعاتی در مورد آخرین تغییراتی که کاربر ایجاد کرده رو نگه توی این توکنها نگهداری کنیم.
یه روش دیگه که خیلی جالب عمل میکنه، استفاده از خواندن مبتنی برQuorum-Based Reads With Vector Clocks هست. توی این روش، وقتی میخوایم یه داده رو بخونیم، از چند سرور درخواست میدیم و آخرین نسخه رو بر اساس زمانبندی منطقی انتخاب میکنیم. همچنین تکنیکهایی مثل read repair وجود دارن که وقتی میبینیم دادهها بهروز نیستن، بهطور خودکار اونها رو دوباره از دیتابیس اصلی میخونن و تازه میکنن. (برای این مورد باید پراکنده جغرافیایی وسیعی داشته باشیم تا توجیه پیدا کنه).
در نهایت، باید بگم که رسیدن به یه سیستم با Read Your Own Writes consistency توی مقیاس بزرگ نیازمند برنامهریزی دقیق و نظارت مداوم هست. نمونههای موفق توی دنیای واقعی مثل پلتفرمهای شبکههای اجتماعی، سایتهای تجارت الکترونیک و ابزارهای همکاری آنلاین ثابت کردن که با استفاده از این تکنیکها، میشه تجربه کاربری فوقالعادهای رو تضمین کرد. ولی برای سیستمهایی که مثلا توی یک کشور و حتی توی یک دیتاسنتر هستن اگر چالش RYW داشته باشیم، احتمالا و تکیه میکنم احتمالا یه مشکلی توی طراحی و پیادهسازی داریم...