زمان‌بندی پردازه‌ها در سیستم‌های توزیع‌شده استاد درس:

Slides:



Advertisements
Similar presentations
Washington WASHINGTON UNIVERSITY IN ST LOUIS Real-Time: Periodic Tasks Fred Kuhns Applied Research Laboratory Computer Science Washington University.
Advertisements

Real Time Scheduling.
ECE 697: Real-Time Systems
1 Advanced Embedded Systems, BAE 5030 Presentation Topic: Rate Monotonic Analysis By Aswin Ramachandran
An Introduction to Real Time Systems
Task Allocation and Scheduling n Problem: How to assign tasks to processors and to schedule them in such a way that deadlines are met n Our initial focus:
1 Swiss Federal Institute of Technology Computer Engineering and Networks Laboratory Embedded Systems Exercise 2: Scheduling Real-Time Aperiodic Tasks.
Martha Garcia.  Goals of Static Process Scheduling  Types of Static Process Scheduling  Future Research  References.
Cloud Scheduling Dynamic Request Allocation with Respect to Context and SLA Charles Snyder.
Embedded Parallel Systems Based on Dynamic Look-Ahead Reconfiguration in Redundant Systems Stephen Holmes.
Chapter 2 1 SIMD-MIMD Real-Time Comparisons (Chapter 7) References: –Stankovic, Spuri, Ramamritham, Buttazzo, “Deadline Scheduling for Real-Time Systems”,
ECE 697: Real-Time Systems n Instructor: C. M. Krishna » (413) » Office Hours (on-campus): Tues: 4:00--4:45 PM n Off-campus.
Strategic Directions in Real- Time & Embedded Systems Aatash Patel 18 th September, 2001.
By Group: Ghassan Abdo Rayyashi Anas to’meh Supervised by Dr. Lo’ai Tawalbeh.
Misconceptions About Real-time Computing : A Serious Problem for Next-generation Systems J. A. Stankovic, Misconceptions about Real-Time Computing: A Serious.
Summary for Chapter 5 --Distributed Process Scheduling
Multiprocessor Real- Time Scheduling Aaron Harris CSE 666 Prof. Ganesan.
Niranjan Rao Julapelly Real-Time Scheduling [ Chapter 5.5]
Real-time Scheduling Review Venkita Subramonian Research Seminar on Software Systems February 2, 2004.
Task Alloc. In Dist. Embed. Systems Murat Semerci A.Yasin Çitkaya CMPE 511 COMPUTER ARCHITECTURE.
Binghamton University EngiNet™ State University of New York
系統晶片設計 - 論文報告 指導老師:陳朝烈老師 學生: 陳宗廷 向崇羽 Monot, A.; Navet, N.; Bavoux, B.; Simonot-Lion, F.,” Multisource Software on Multicore Automotive.
Static Process Schedule Csc8320 Chapter 5.2 Yunmei Lu
Scheduling policies for real- time embedded systems.
Multiprocessor Real-time Scheduling Jing Ma 马靖. Classification Partitioned Scheduling In the partitioned approach, the tasks are statically partitioned.
 A System Performance Model  Static Process Scheduling  Dynamic Load Sharing and Balancing  Real-Time Scheduling.
BFair: An Optimal Scheduler for Periodic Real-Time Tasks
Real-Time Scheduling CS4730 Fall 2010 Dr. José M. Garrido Department of Computer Science and Information Systems Kennesaw State University.
Aravind Venkataraman. Topics of Discussion Real-time Computing Synchronous Programming Languages Real-time Operating Systems Real-time System Types Real-time.
Static Process Scheduling Section 5.2 CSc 8320 Alex De Ruiter
1 Scheduling Processes with Release Times, Deadlines, Precedence and Exclusion Relations J. Xu and D. L. Parnas IEEE Transactions on Software Engineering,
2004/06/01 1 Issues about Scheduling for Dependent Multimedia Tasks 電機所控制組 R 馮天俊 R 戴兆弘 Adviser :陳少傑 老師 Date : 2004/06/01.
CprE 458/558: Real-Time Systems (G. Manimaran)1 CprE 458/558: Real-Time Systems RMS and EDF Schedulers.
End-To-End Scheduling Angelo Corsaro & Venkita Subramonian Department of Computer Science Washington University Distributed Systems Seminar, Spring 2003.
CSE 522 Real-Time Scheduling (2)
CSCI1600: Embedded and Real Time Software Lecture 24: Real Time Scheduling II Steven Reiss, Fall 2015.
Static Process Scheduling
CSCI1600: Embedded and Real Time Software Lecture 23: Real Time Scheduling I Steven Reiss, Fall 2015.
Introduction to Real-Time Systems
Sandtids systemer 2.modul el. Henriks 1. forsøg m. Power Point.
ECRTS/WiP, July 2009 André M. van Renssen, TU/e, Mathematics & Computer Science 1 André M. van Renssen, Stefan J. Geuns, Joost.
Pradeep Konduri Static Process Scheduling:  Proceedance process model  Communication system model  Application  Dicussion.
Distributed Process Scheduling- Real Time Scheduling Csc8320(Fall 2013)
Real-Time Operating Systems RTOS For Embedded systems.
Embedded System Scheduling
Scheduling in Real-Time Systems
REAL-TIME OPERATING SYSTEMS
Some Topics in OR.
RTOS Scheduling 3 Cyclic scheduling, EDF. Tasks with precedence, Scheduling impact of DMA, cache, interrupts & context switch overhead, Aperiodic Georgio.
Introduction | Model | Solution | Evaluation
Chapter – 5.2 Static Process Scheduling
Unit OS9: Real-Time and Embedded Systems
EEE 6494 Embedded Systems Design
Imprecise Computation September 7, 2006
Lecture 24: Process Scheduling Examples and for Real-time Systems
Realtime Scheduling Algorithms
Real Time Scheduling Mrs. K.M. Sanghavi.
Sanjoy Baruah The University of North Carolina at Chapel Hill
CSCI1600: Embedded and Real Time Software
CSCI1600: Embedded and Real Time Software
Enforcing Real-Time Behavior I
Networked Real-Time Systems: Routing and Scheduling
Overview of AIGA platform
NET 424: REAL-TIME SYSTEMS (Practical Part)
CSCI1600: Embedded and Real Time Software
Processes and operating systems
Examples of real-time applications
The End Of The Line For Static Cyclic Scheduling?
Ch 4. Periodic Task Scheduling
CS 491z / CS 791z Topics on Software Engineering
Presentation transcript:

زمان‌بندی پردازه‌ها در سیستم‌های توزیع‌شده استاد درس: ارائه درس « سیستم عامل‌های پیشرفته » استاد درس: جناب آقای دکتر جلیلی گردآورنده: رامتین باقری

مقدمه سیستم‌های توزیع شده تعریف زمان‌بندی و طبقه‌بندی الگوریتم‌های آن در سیستم‌های توزیع‌شده مدل‌های پردازه‌ای تقدم پردازه ارتباط پردازه پردازه‌ منفصل سیستم‎‌های بلادرنگ و الگوریتم‌های زمان‌بندی در آن

سیستم‌های توزیع شده مجموعه‌ای از کامپیوترهای مستقل از هم که برای کاربرانش یک سیستم منفرد منسجم به نظر می‌آید

زمان‌بندی در سیستم‌های توزیع شده متوزان نبودن بار پردازشی پردازنده‌ها در سیستم چند پردازنده بیکار (Idle) و دیگر پردازنده‌ها به شدت مشغول هستند می‌توان با مهاجرت کارها و اجرای از راه دور آنها کارایی سیستم را ارتقا داد زمان‎بندی (واگذاری) پردازه‌ها به پردازنده‌ها در متون معتبر، اغلب تمایز ضمنی میان زمان‌بندی (Scheduling) و تخصیص (Allocation) وجود دارد از نظر کاساوانت و کول هر دو مربوط به یک مساله ولی با طرز نگاه‌های مختلف هستند از نقطه نظر منابع، مساله این است که چطور پردازنده‌ها به پردازه‌ها تخصیص داده شود از نگاه کاربران، زمان‌بندی (واگذاری) پردازه‌ها به پردازنده‌ها مساله محسوب می‌شود!

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

تخصیص منابع پردازشی محلی میان پردازه‌های مقیم در یک گره زمان‌بندی در سیستم‌های توزیع شده سیاست زمان‌بندی برای سیستم‌های عام منظوره از لحاظ منطقی به دو بخش تقسیم می‌شود: زمان‌بند محلی (Local Scheduler) زمان‌بند (سراسری) بار (Load Scheduler) تخصیص پردازه‌‌های جدید به گره‌ها و پخش بار در سیستم بوسیله مهاجرت پردازه‌ها «در چه زمانی، چه پردازه‌ای باید به کجا منتقل شود» تخصیص منابع پردازشی محلی میان پردازه‌های مقیم در یک گره

طبقه‌بندی الگوریتم‌های زمان‌بندی‌ها تقریبی(Approximate) ← رسیدن به یک راه حل "خوب" در فضای حالت اکتشافی (Heruistic) ← استفاده از پارامترهای ویژه که روی عملکرد سیستم تاثیر غیرمستقیم می‌گذارد ایستا (Static) ← تخصیص پردازه‌ها به پردازنده‌ها در زمان کامپایل یا زودتر پویا (Dynamic) ← تخصیص پردازه‌ها به پردازنده‌ها در زمان شروع اجرای آنها محلی (Local) ← چگونگی تخصیص زمان یک پردازنده به پردازه‌های خود سراسری (Global) ← تصمیم‌گیری درباره محل (پردازنده) اجرای پردازه در کل سیستم Static: تصمیماشو بر اساس اطلاعات پردازه ها (مثل زمان اجرای تخمینی) و اطلاعات ایستای سیستم میگیره. مزیتش توی ساده بودنشه. موقع هایی که بار کاری سیستم به خوبی قابل توصیفه خوب عمل میکنه، ولی موقع نوسانات تو بار سیستم، نمیتونه خودشو هماهنگ کنه. Dynamic: در زمان شروع به اجرا زمان بندی میشن و این یعنی میتونن در حال اجرای یکی، زمان بندی دوباره انجام بشه. این نوع زمانبندی حالت کنونی سیستم (مثل طول صف و مقدار بار و ...) رو هم تو تصمیمش در نظر میگیره ----------------------------- Optimal: چون اطلاعات مربوط به حالت سیستم و نیازهای پردازه ها نسبت به منابع رو داریم، میتونیم یه زمان بندی بهینه ارائه کنیم. مثلا میتونیم یه جوری کارهارو بچینیم که زمان اجرای کلی پردازه کمینه بشه، یا بهره سیستم ماکیزمم بشه. در سیستم های توزیع شده بزرگ، به خاطر سایز مساله (تعداد پردازه ها، پردازنده ها و محدودیت های ممکن) زمان بندی ایستای بهینه خیلی کار سختی میشه (چون باید همه اینارو اول کار آنالیز کنیم) و در بعضی مواقع نشدنی! برا همین به یه راه حل نیمه بهینه هم راضی میشیم! Approximate-semi-optimal: هدف رسیدن به یه راه حل "خوبه"! خوب بودن هم توسط یه سری معیار تعیین میشه، مثل زمان لازم برای ارزیابی راه حل، وجود یک مکانیزم برای هرس هوشمندانه فضای راه حل و امثال اینها Heruestic: استفاده از یه سری پارامترهای ویژه که روی عملکرد سیستم تاثیر میذاره. زمان و منابع معقولی برای اجرا لازم دارند. مثلا تخصیص پردازه هایی که با همدیگه خیلی اطلاعات رد و بدل میکنن به یه پردازنده واحد، یه مثال از راه حل heruestic عه!

مدل تقدم پردازه هر برنامه با یک DAG (Directed Acyclic Graph) نمایش داده می‌شود که هر گره در آن معرف یک task با زمان اجرای مشخص است هر لبه معرف یک رابطه تقدم و وزن آن معرف تعداد پیغام‌هایی است که بعد از اتمام task باید به گره (task) بعدی ارسال شود هدف اصلی ← موازی‌سازی حداکثری در اجرای وظایف درون برنامه پیدا کردن یک جواب برای مساله (minimum makespan) از نوع NP-Complete است. پس از الگوریتم های اکتشافی استفاده میکنیم. مفهوم مسیر بحرانی در اینجا به دردمون میخوره (طولانی ترین مسیر در DAG) که حد پایین زمان اجرای ماست. مثلا یه راه اکتشافی این میتونه باشه که تمام وظایف در یک مسیر بحرانی رو توی یه پردازنده قرار بدیم.

مدل تقدم پردازه (ادامه) استراتژی Earliest Task First (ETF): نزدیک‌ترین وظیفه قابل زمان‌بندی توسط پردازنده انتخاب می‌شود (با ملاحظه سربار ارتباطی) استراتژی Extended List Scheduling (ELS): اعمال سربار ارتباطی میان پردازه‌ای + LS استراتژی List Scheduling (LS): هیچ پردازنده‌ای بیکار نماند، اگر وظایفی موجود باشد که امکان پردازش داشته باشند ELS: با پاسخ بهینه خیلی فاصله داره، چون صرفا سربار ارتباطی رو اعمال کرده و تو تصمیم گیری رعایتش نکرده! ETF: اون پردازه هایی که هزینه ارتباطی شون با هم زیاده رو میندازیم توی یه پردازنده دلیل نمیشه زمانبندی بهینه روی یک بستر ارتباطی، روی یک بستر ارتباطی متفاوت دیگه هم بهینه باشه (؟؟)

مدل ارتباط پردازه زمان‌بندی پردازه‌ها برای بسیاری از برنامه‌های سیستم‌، متفاوت از مدل تقدم است مدل ارتباط پردازه یک گراف بدون جهت G با مجموعه گره‌های V و مجموعه یال‌های E است که گره‌ها معرف پردازه‌ها و وزن روی یال‌ها معرف هزینه ارتباط میان دو پردازه متصل است اهداف اصلی ← بهره‌وری منابع بیشینه و ارتباط کمینه میان پردازنده‌ای پردازه‌ها در مدل قبلی محدودیت تقدم توسط کاربران صراحتا تعیین میشد. در بعضی از سیستم ها این محدودیت وجود نداره مگر ارتباط بین پردازه های خودکفا پردازه ها زمان تکمیل مشخصی ندارن

مدل ارتباط پردازه (ادامه) با کمینه کردن مقدار تابع زیر (Module Allocation) می‌توان تخصیص بهینه‌ m پردازه میان P پردازنده را پیدا کرد 𝑒 𝑗 ( 𝑝 𝑖 ) هزینه اجرای پردازه 𝑗 بر پردازنده 𝑝 𝑖 (پردازنده تخصیص یافته به آن پردازه) است 𝑐 𝑖,𝑗 ( 𝑝 𝑖 , 𝑝 𝑗 ) هزینه ارتباط میان دو پردازه 𝑗 و 𝑖 که به پردازه‌های مختلف 𝑝 𝑖 و 𝑝 𝑗 تخصیص داده شده‌اند به طور کلی جزو مساله‌های NP-Complete محسوب می‌شود برای 𝑃 =2 در زمان چند جمله‌ای قابل حل است در مدل قبلی محدودیت تقدم توسط کاربران صراحتا تعیین میشد. در بعضی از سیستم ها این محدودیت وجود نداره مگر ارتباط بین پردازه های خودکفا پردازه ها زمان تکمیل مشخصی ندارن هدف ->

مدل ارتباط پردازه (ادامه) راه حل اکتشافی:

مدل پردازه‌‌ای مجزا فرض دانش قبلی راجب پردازه‌ها، در بیشتر برنامه‌های توزیع‌شده فرض واقع‌گرایانه‌ای نیست مدل پردازه‌ای مجزا تاثیر وابستگی میان پردازه‌ها را در نظر نمی‌گیرد اهداف اصلی ← بهره‌وری بیشینه و برقراری عدالت میان پردازه‌های کاربران برداشت‌ها از "عدالت" یکی نیست: از دید سیستم ← بار پردازشی برابر بر روی هر پردازنده (توسط انتقال پردازه‌ها) از دید کاربر ← هرکس به اندازه مساوی از منابع بهره ببرد راه حل‌ها بدون استفاده از کنترلر مرکزی: الگوریتم‌های فرستنده-آغاز الگوریتم‌های گیرنده-آغاز

مدل پردازه‌‌ای مجزا (ادامه) الگوریتم‌های فرستنده-آغاز: فرستنده می‌خواهد بخشی از وظایف محاسباتی خود را بر عهده دیگری بگذارد سه تصمیم لازم است تا گرفته شود: سیاست انتقال: چه موقع یک پردازنده فرستنده می‌شود؟ سیاست انتخاب: چگونه فرستنده، پردازه‌ای را برای انتقال انتخاب می‌کند؟ سیاست محل: گیرنده، چه پردازنده‌ای باید باشد؟ در بار کم، سربار کمی دارد اگر تنها مشخص کننده بار کاری، اندازه صف باشه ، نمودار سیاست ها رو تعریف میکنه

مدل پردازه‌‌ای مجزا (ادامه) الگوریتم‌های گیرنده-آغاز: گیرنده می‌خواهد به سایر پردازنده‌ها کمک کند در اینجا نیز سه تصمیم لازم است تا گرفته شود: سیاست انتقال: چه موقع یک پردازنده گیرنده می‌شود؟ سیاست انتخاب: چگونه گیرنده، پردازه‌ای را برای انتقال از آن انتخاب می‌کند؟ سیاست محل: فرستنده، چه پردازنده‌ای باید باشد؟ به نسبت الگوریتم‌های فرستنده-آغاز پایا تر است در بار سنگین بهتر عمل می‌کند در بار سبک، کارایی اش کمتر است سود اشتراک باید از هزینه توقف و مهاجرت پردازه بیشتر باشد، وگرنه کار بیهوده ای انجام دادیم. می‌توان از الگوریتم ترکیبی نیز استفاده کرد (تشخیص بار سیستم و انتخاب الگوریتم مناسب)

سیستم‌های بلادرنگ (RTS) "سیستمی‌هایی که درستی و صحت آنها نه‌تنها به نتیجه منطقی محاسبات، بلکه بر روی زمانی که آن نتایج تولید می‌شود نیز بستگی دارد“ بلادرنگ لزوما به معنای "واقعا سریع" نیست قابل پیش‌بینی بودن مهمترین نیازمندی در اینگونه از سیستم‌ها است زمان اجرای تقریبی کارها و مهلت انجام آنها مشخص است قابل پیش بینی بودن: refers to the system’s deadline in terms of relative and absolute time, For instance, it must be mathematically predictable to determine if the amount of work to be done can be completed before a given deadline J. Stankovic, "Misconceptions About Real-Time Computing," IEEE Computer, 21(10), October 1988.

مشخصات وظایف در RTS الگوی رسیدن کارها "رسیدن" ← به معنی آماده بودن برای اجرا "غیرمتناوب" (و "پراکنده") هیچکدام از الگوریتم‌های زمان‌بندی شناخته‌شده "غیر متناوب" بهینه نیستند "متناوب" زمان رسیدن وظایف ثابت ولی اجرای آنها شاید متغیر باشد ( به دلیل برخی محدودیت‌ها) وابستگی میان وظیفه‌ای وظیفه 𝑗 به مجموعه وظایف 𝑆(𝑗) وابسته است، اگر نتواند تا قبل از اتمام اجرای آن‌ها، اجرا شود وابستگی میان وظیفه‌ها در قالب یک DAG نمایش داده می‌شود غیر متناوب یعنی زمان اومدنشم ندونیم! رسیدن به معنی اجرا شدن نیست! "رسیدن" یعنی خودش میخواد که انجام شه، ولی باید اول محدودیت هایی که داریم رعایت بشه، مثل وابستگی میان وظایف زمان‌بندی بدون وابستگی میان کارها به وضوح راحت تره!

مشخصات وظایف در RTS (ادامه) لختی مهلت انجام (Deadline Laxity) مهلت سخت (Hard) با انجام نشدن حتی یکی از کارها در مهلت انجامش، فاجعه رخ می‌دهد مهلت نرم (Soft) با کمتر شدن فایده نتیجه وظیفه بعد از مهلت انجام، از کیفیت خروجی می‌کاهد

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

طراحی الگوریتم زمان‌بندی در RTS (ادامه) وظیفه‌گرا (Assignment-Oriented) یا ترتیب‌گرا (Sequence-Oriented) نمایش مساله زمان‌بندی با درخت، زمان‌بندی (نه لزوما قابل اجرا) در قالب مسیر از ریشه تا برگ وظیفه‌گرا ← پیدا کردن پردازنده برای یک پردازه در هر مرحله ترتیب‌گرا ← انتخاب پردازه برای یک پردازنده در هر مرحله هر دو درخت را به صورت DFS جستجو می‌کنند و زمان اجرا و حافظه لازم هر دوی آنها نمایی است مساله زمانبندی وظایف بر روی چند پردازنده رو میشه به عنوان یه جستجو برای زمانبندی قابل اجرا دانست فضای جستجو رو میشه با یه درخت نمایش داد که هر مسیر از ریشه به برگ یه زمان‌بندی (نه لزوما قابل اجرا) معلوم شده که الگوریتم‌های ترتیب گرا خیلی مقیاس پذیر نیستن. چون بیشتر هدف توازن بار دارن تا تحقق مهلت اجرای کارها Assignment-Oriented Sequence-Oriented

الگوریتم نرخ یکنواخت (RMA) یک الگوریتم‌ زمان‌بندی ایستای پیشگیرانه مبتنی بر نرخ اجرا (معکوس دوره تناوب) به عنوان اولویت است در سال 1973 توسط Liu و Layland پیشنهاد شد برای حل مشکل زمان‌بندی روی پردازنده واحد ارائه شد ولی قابلیت اجرا روی سیستم‌های توزیع‌شده را نیز دارا است هرچه نرخ اجرا بیشتر باشد، اولویت کار نیز بالاتر است اولویت دوره تناوب زمان اجرا پردازه 2 50 20 P1 1 120 37 P2

الگوریتم نرخ یکنواخت (RMA) (ادامه) الگوریتم مذکور برای n پردازنده تضمین زمان‌بندی‌ای قابل اجرا برای آنها می‌کند، اگر رابطه زیر برقرار باشد: 𝑈= 𝑖=1 𝑛 𝐶 𝑖 𝑇 𝑖 ≤𝑛( 2 1 𝑛 −1) U مصرف پردازنده، Ci زمان اجرای وظیفه i ام و Ti دوره تناوب آن وظیفه است برقرار نبودن این رابطه، لزوما بر قابل اجرا نبودن زمان‌بندی دلالت نمی‌کند

الگوریتم نرخ یکنواخت (RMA) (ادامه) مصرف اولویت دوره تناوب (ms) زمان اجرا (ms) پردازه 0.24 1 50 12 a 0.25 2 40 10 b 0.33 3 30 c 𝑈=0.82≰3 2 1 3 −1 =0.78

الگوریتم نرخ یکنواخت (RMA) (ادامه) مصرف اولویت دوره تناوب (ms) زمان اجرا (ms) پردازه 0.5 1 80 a 0.25 2 40 b 3 20 5 c 𝑈=1.0≰3 2 1 3 −1 =0.78

الگوریتم نرخ یکنواخت (RMA) (ادامه) به آزمونی نیاز داریم تا بتواند مشخص کند که آیا یک مجموعه از وظایفی که در آزمون Liu و Layland ناموفق بوده‌اند واقعا قابل زمان‌بندی هستند یا خیر! تست Lehoczky ← یک مجموعه از وظایف متناوب بلادرنگ در RMA در هر فازی قابل زمان‌بندی هستند، اگر همه آنها اولین مهلت انجام‌شان را در شرایط بدون فاز، رعایت کنند Lehoczky, John, Lui Sha, and Ye Ding. "The rate monotonic scheduling algorithm: Exact characterization and average case behavior." Real Time Systems Symposium, 1989., Proceedings.. IEEE, 1989.

الگوریتم نرخ مهلت (DMA) از نوع زمان‌بندی ایستای اولویت ثابت هرچه مهلت انجام دادن نسبی یک کار کوتاه‌تر باشد، اولویت آن بالاتر است مهلت انجام نسبی یعنی زمان باقی‌مانده تا مهلت انجام کار از لحظه ورود به زمان‌بند اگر مهلت انجام نسبی برابر با دوره تناوب باشد، RMA با DMA فرقی نمی‌کند، در غیر اینصورت DMA در مواقع بیشتری زمان‌بندی قابل اجرا ایجاد خواهد کرد اولویت در DMA اولویت در RMA دوره تناوب (ms) مهلت انجام (ms) زمان اجرا (ms) پردازه 2 3 50 35 10 P1 100 20 15 P2 1 200 P3 مثال بالا در RMA غیر قابل زمان‌بندی و در DMA قابل زمان‌بندی است

الگوریتم Deadline-Driven با توجه به بهره‌وری پایین پردازنده با الگوریتم RMA، Liu و Layland الگوریتم دیگری با نام Deadline-driven که از تخصیص اولویت پویا استفاده می‌کرد ارائه دادند اولویت بر اساس مهلت انجام (مطلق) درخواست کنونی، به کارها تخصیص داده می‌شود هرچه مهلت انجام نزدیک‌تر باشد، اولویت کار بالاتر است حد بالای مصرف پردازنده در این الگوریتم 1.0 است 𝑈 = 𝑖=1 𝑛 𝐶 𝑖 𝑇 𝑖 ≤1 مشکل ← در آن زمان حمایت سخت‌افزاری برای تخصیص اولویت پویا وجود نداشت راه حل ← استفاده از مخلوطی از هر دو الگوریتم؛ RMA برای اکثر وظایف و DDA برای بقیه تسک بیشترین اولویت رو میگیره اگه مهلتش نزدیکترین باشه. تخصیص اولویت هربار که یک تسک آماده زمان‌بندی شدنه انجام میشه. یک الگوریتم مشابه دیگر ← زمان‌بندی بر اساس کمترین لَختی (Least Laxity First) لَختی = زمان اجرا در بدترین حالت - مهلت انجام مطلق

مدل وظیفه‌ای انتها-به-انتها یک وظیفه (Task) از چندین زیروظیفه (Subtask) که بر روی چندین پردازنده اجرا می‌شوند تشکیل شده است رخدادهای غیر محلی فراخوانی از راه دور متد محدودیت‌های اولویتی مربوط به زیروظیفه‌ها می‌شود وظیفه = زنجیره‌ای از زیروظیفه‌ها یک وظیفه مقید به رعایت مهلت انجام انتها به انتها است به زمان پاسخ زیروظیفه‌اش اهمیتی نمی‌دهد مدل وظیفه‌ای انتها-به-انتها موارد زیر را پوشش می‌دهد تخصیص وظایف (به پردازنده‌ها) پروتکل‌های همگام‌سازی (برای اعمال محدودیت‌های اولویتی)

مساله همگام‌سازی اولویت‌ها به زیروظیفه‌ها در یک زنجیره وظیفه با استفاده از یک الگوریتم تخصیص اولویت ثابت، اختصاص داده شده است چطور می‌توان اجرای زیروظیفه‌ها را به گونه‌ای زمان‌بندی کرد که قید تقدم میان زیروظیفه‌ها ارضا شود مهلت انجام زیروظیفه‌ها رعایت شود مهلت انجام انتها-به-انتها رعایت شود

مساله همگام‌سازی (ادامه) شرایط مساله به عنوان مثال به این صورت فرض می‌شود اولویت ← T1 > T2,1 و T2,2 > T3 (زمان اجرا، دوره تناوب) وظیفه T3 دارای فاز 4 است (بعد از 4 واحد زمانی به زمان‌بند وارد می‌شود)

پروتکل Direct Synchronization از دسته الگوریتم‌های حریصانه به محض اتمام زیروظیفه، به پردازنده حاوی زیروظیفه بعدی سیگنالی ارسال می‌شود و زیروظیفه بعدی را آماده اجرا می‌کند مزایا ← پیاده‌سازی راحت، کمترین سربار اجرا، انجام زیروظایف در زمان کمتر معایب ← در شرایط بار کاری بالا و زنجیره وظایف طولانی، میانگین زمان اجراها را بالا می‌برد (بسته به اولویت زیروظایف درون آن پردازنده تصمیم به اجرایش گرفته می‌شود)

پروتکل Phase Modification اصرار بر اجرا شدن زیروظیفه‌ها به صورت تناوبی بر اساس دوره تناوب‌های وظایف پدرشان هر زیروظیفه فاز مربوط به خود را دارد که بر اساس رابطه تقدم تاخر زیروظیفه‌ها تعیین می‌شود معایب ← نیاز به ساعت مرکزی یا همگام دقیق، از بین رفتن رابطه تقدم و تاخر در مواقع طولانی شدن وظایف یا فاصله زمانی متغیر در اجراهای بعدی زیروظیفه اول افزایش زمان اجرای انتها-به-انتهای کلی وظیفه نیاز به ساعت همگام داریم، چون زیرکارها دارن با توجه به پریود مشخص واسه خودشون اجرا میشن و از همدیگه اطلاع ندارن اگه یه کاری بیشتر از زمان تخمینی که براش در نظر گرفته شده بود طول بکشه، دیگه رابطه تقدم تاخر رعایت نمیشه - اگه اولین کار یه زنجیره دیر شروع بشه (به خاطر اولویت توی اون پردازنده ایی که توش هست)، چون کارهای بعدی بر اساس پریود دارن شروع میشن، ممکنه زیرکار دوم زودتر از اولی شروع بشه و قید تقدم زیرکارهامون به هم بخوره! R. Belttati. End-to-End Scheduling to Meet Deadlines in Distributed Systems. PhD thesis University of Illinois at Urbana Champaign, 1994.

پروتکل Modified Phase Modification اصلاح شده پروتکل قبلی اضافه شدن سیگنال همگامی به پروتکل برای رفع نیاز به ساعت مرکزی ایجاد تاخیر میان اتمام کار زیروظیفه قبلی و ارسال سیگنال برای اجرای زیروظیفه بعدی در شرایط ایده‌آل (ساعت همگام، کران بالای معین انجام زیروظیفه و متناوب سخت بودن زیروظیفه اول زنجیره) ← MPM = PM نیاز به ساعت همگام داریم، چون زیرکارها دارن با توجه به پریود مشخص واسه خودشون اجرا میشن و از همدیگه اطلاع ندارن اگه یه کاری بیشتر از زمان تخمینی که براش در نظر گرفته شده بود طول بکشه، دیگه رابطه تقدم تاخر رعایت نمیشه - اگه اولین کار یه زنجیره دیر شروع بشه (به خاطر اولویت توی اون پردازنده ایی که توش هست)، چون کارهای بعدی بر اساس پریود دارن شروع میشن، ممکنه زیرکار دوم زودتر از اولی شروع بشه و قید تقدم زیرکارهامون به هم بخوره!

پروتکل Release Guard کنترل آماده به اجرا شدن یک زیروظیفه به منظور عدم تغییر فاصله میان نمونه‌های آن (کمتر نشدن از دوره تناوب) تخصیص متغیر gi,j به وظیفه Ti,j (زیروظیفه j از وظیفه i ام) به ازای j >1 pi,j دوره تناوب زیروظیفه و Idle point بیکار بودن پردازنده (نبودن وظیفه‌ای برای اجرا در پردازنده) بروزرسانی gi,j در زمان بیکاری پردازنده و رسیدن سیگنال همگامی زمان اجرای انتها-به-انتهای کمتر از MPM، ولی با jitter بیشتر از آن نیاز به ساعت همگام داریم، چون زیرکارها دارن با توجه به پریود مشخص واسه خودشون اجرا میشن و از همدیگه اطلاع ندارن اگه یه کاری بیشتر از زمان تخمینی که براش در نظر گرفته شده بود طول بکشه، دیگه رابطه تقدم تاخر رعایت نمیشه - اگه اولین کار یه زنجیره دیر شروع بشه (به خاطر اولویت توی اون پردازنده ایی که توش هست)، چون کارهای بعدی بر اساس پریود دارن شروع میشن، ممکنه زیرکار دوم زودتر از اولی شروع بشه و قید تقدم زیرکارهامون به هم بخوره! gi,j = 0 /* initialization */ If (idle point) gi,j = current_time else gi,j = current_time + pi,j Sun, Jun, and Jane Liu. "Synchronization protocols in distributed real-time systems." Distributed Computing Systems, 1996., Proceedings of the 16th International Conference on. IEEE, 1996.

منابع [1] T. L. Casavant and J. G. Kuhl, “Taxonomy of Scheduling in General-Purpose Distributed Computing Systems.,” IEEE Trans. Softw. Eng., vol. 14, no. 2, pp. 141– 154, 1988. [2] V. Subramonian, “Real-time Scheduling Review Main Topics for Discussion,” 2004. [3] J. Sun and J. Liu, “Synchronization protocols in distributed real-time systems,” Distrib. Comput. Syst. 1996., Proc. 16th Int. Conf., pp. 38–45, 1996. [4] A. Majumder, “Scheduling and Synchronization in Real Time Systems,” pp. 1–11. [5] Cse, “Real-Time Task Scheduling,” IIT Kharagpur. [6] A. Carzaniga and A. L. Wolf, “Scheduling Real-Time Tasks in Distributed Systems : A Survey,” System, pp. 1–13, 2002. [7] R. Jalili, “Distributed Process Scheduling (Handnotes).” [8] R. Bettati and J. W.-S. Liu, “End-to-end scheduling to meet deadlines in distributed systems,” in [1992] Proceedings of the 12th International Conference on Distributed Computing Systems, 1992, pp. 452–459. نیاز به ساعت همگام داریم، چون زیرکارها دارن با توجه به پریود مشخص واسه خودشون اجرا میشن و از همدیگه اطلاع ندارن اگه یه کاری بیشتر از زمان تخمینی که براش در نظر گرفته شده بود طول بکشه، دیگه رابطه تقدم تاخر رعایت نمیشه - اگه اولین کار یه زنجیره دیر شروع بشه (به خاطر اولویت توی اون پردازنده ایی که توش هست)، چون کارهای بعدی بر اساس پریود دارن شروع میشن، ممکنه زیرکار دوم زودتر از اولی شروع بشه و قید تقدم زیرکارهامون به هم بخوره!

منابع [9] J. Wang, “Distributed Process Scheduling,” pp. 1–16, 2003. [10] D. Liang, P. Ho, and B. Liu, “Scheduling in Distributed Systems,” pp. 1–9. [11] B. Sprunt, L. Sha, and J. Lehoczky, “Aperiodic task scheduling for Hard-Real-Time systems,” Real-Time Syst. Int. J. Time-Critical Comput. Syst., vol. 1, no. 1, pp. 27–60, 1989. نیاز به ساعت همگام داریم، چون زیرکارها دارن با توجه به پریود مشخص واسه خودشون اجرا میشن و از همدیگه اطلاع ندارن اگه یه کاری بیشتر از زمان تخمینی که براش در نظر گرفته شده بود طول بکشه، دیگه رابطه تقدم تاخر رعایت نمیشه - اگه اولین کار یه زنجیره دیر شروع بشه (به خاطر اولویت توی اون پردازنده ایی که توش هست)، چون کارهای بعدی بر اساس پریود دارن شروع میشن، ممکنه زیرکار دوم زودتر از اولی شروع بشه و قید تقدم زیرکارهامون به هم بخوره!