اجماع (علوم کامپیوتر)

یک مشکل اساسی در رایانش توزیع‌شده و سیستم‌های چندعاملی، دستیابی به قابلیت اطمینان کلی سیستم در صورت بروز تعدادی فرایند معیوب است. این اغلب مستلزم هماهنگی فرایندها برای دستیابی به اجماع، یا توافق بر روی مقدار داده‌ای است که در طول محاسبه مورد نیاز است. نمونه‌ای از کاربردهای اجماع عبارتند از توافق بر سر اینکه چه تراکنش‌هایی به چه ترتیبی به یک پایگاه داده سپرده شود، تکثیر ماشین حالت، و پخش اتمی. برنامه‌های کاربردی دنیای واقعی که اغلب نیاز به اجماع دارند شامل محاسبات ابری، همگام سازی ساعت، الگوریتمی برای رتبه‌بندی صفحات وب، شکل‌گیری دیدگاه، شبکه‌های برق هوشمند، تخمین وضعیت، کنترل پهپادها (و به‌طور کلی چندین ربات/عامل)، تعادل بار، زنجیره بلوکی و موارد دیگر می‌باشد.

شرح مشکل ویرایش

مشکل اجماع مستلزم توافق بین تعدادی از فرایندها (یا عامل‌ها) برای یک مقدار داده واحد است. برخی از فرایندها (عامل‌ها) ممکن است از راه‌های دیگر با مشکل مواجه شوند یا غیرقابل اعتماد باشند، بنابراین پروتکل‌های اجماع باید دارای تحمل خطا یا انعطاف‌پذیر باشند. فرایندها باید به نحوی مقدارهای موردنظر خود را بیان کنند، با یکدیگر ارتباط برقرار کنند و بر روی یک مقدار اجماع واحد توافق کنند.

مشکل اجماع یک مشکل اساسی در کنترل سیستم‌های چند عاملی است. یک رویکرد برای تولید اجماع این است که همه فرایندها (نمایندگان) بر روی مقدار اکثریت توافق کنند. در این زمینه، اکثریت به حداقل یک رای بیشتر از نیمی از آرای موجود نیاز دارد (که در آن به هر فرایند رای داده می‌شود). هرچند، یک یا چند فرایند معیوب ممکن است نتیجه حاصل را منحرف کند به طوری که ممکن است اجماع به دست نیاید یا به اشتباه حاصل شود.

پروتکل‌هایی که مشکلات اجماع را حل می‌کنند برای مقابله با تعداد محدودی از فرآیندهای معیوب طراحی شده‌اند. این پروتکل‌ها برای مفید بودن باید تعدادی از الزامات را برآورده کنند. به عنوان مثال، یک پروتکل بی‌اهمیت می‌تواند خروجی تمام فرایندها مقدار باینری ۱ را داشته باشد. این مفید نیست و بنابراین نیاز به گونه ای اصلاح می‌شود که خروجی به نحوی به ورودی بستگی داشته باشد؛ یعنی مقدار خروجی یک پروتکل اجماعی باید مقدار ورودی یک فرایند باشد. الزام دیگر این است که یک فرایند می‌تواند فقط یک بار در مورد مقدار خروجی تصمیم بگیرد و این تصمیم غیرقابل برگشت است. در صورتی که فرآیندی در اجرا با شکست مواجه نشود، صحیح نامیده می‌شود. یک پروتکل توافقی که خرابی‌های رخ داده را تحمل می‌کند باید ویژگی‌های زیر را برآورده کند.[۱]

پایان دهی
در نهایت، هر فرایند صحیح مقادیر را تعیین می‌کند.
تمامیت
اگر همه فرآیندهای صحیح یک مقدار   را پیشنهاد کنند، پس هر فرایند صحیح باید تصمیمش مقدار   باشد.
توافق
هر فرایند صحیح باید بر روی یک مقدار واحد توافق کنند.

طبق کاربرد، تغییرات در تعریف یکپارچگی می‌تواند مناسب باشد. به عنوان مثال، نوع ضعیف‌تر یکپارچگی می‌تواند این گونه تعریف شود که ارزش تصمیم برابر با مقداری باشد که برخی از فرآیندهای صحیح پیشنهاد کرده‌اند - نه لزوماً همه آنها.[۱] شرط یکپارچگی به عنوان اعتبار در ادبیات شناخته می‌شود.[۱]

پروتکلی که بتواند به درستی اجماع بین n فرایند، که حداکثر t فرایند از آن‌ها با شکست مواجه می‌شوند، را تضمین کند، t-مقاوم نامیده می‌شود.

در ارزیابی عملکرد پروتکل‌های اجماع دو عامل مورد علاقه زمان اجرا و پیچیدگی پیام است. زمان اجرا با نماد O بزرگ، در تعداد دورهای مبادله پیام به عنوان تابعی از برخی پارامترهای ورودی (معمولا تعداد فرایندها و/یا اندازه دامنه ورودی) نمایش داده می‌شود. پیچیدگی پیام به میزان ترافیک پیامی که توسط پروتکل ایجاد می‌شود اشاره دارد. عوامل دیگر ممکن است شامل استفاده از حافظه و اندازه پیام‌ها باشد.

منابع ویرایش

  1. ۱٫۰ ۱٫۱ ۱٫۲ Coulouris, George; Jean Dollimore; Tim Kindberg (2001), Distributed Systems: Concepts and Design (3rd Edition), Addison-Wesley, p. 452, ISBN 978-0-201-61918-8