الگوریتم بانکدار
برای تأییدپذیری کامل این مقاله به منابع بیشتری نیاز است. (فوریه ۲۰۱۳) |
الگوریتم بانکدار یک الگوریتم تخصیص منابع و اجتناب از بنبست است که توسط ادسخر دیسترا توسعه یافته که امنیت آن به وسیله شبیهسازی تخصیص بیشترین مقدار ممکن از تمام منابع آزمایش شده به طوری که یک s-state ایجاد میکند تا برای همه فرایندهای در حال انتظار تمام شرایط بنبست را قبل از تصمیمگیری و اجازه تخصیص منبع بررسی کند.
این الگوریتم در طراحی فرایند در سیستم عامل THE توسعه یافته و در اصل (به هلندی) در EWD108 شرح داده شده.[۱]
الگوریتم
ویرایشالگوریتم بانکدار هر زمان که یک فرایند درخواست منبع کند توسط سیستم عامل اجرا میشود.[۲] الگوریتم به وسیله انکار یا تعویق درخواست از بنبست جلوگیری میکند. این در صورتی است که اگر تعیین شود که پذیرش درخواست میتواند سیستم را به حالت نا امن ببرد. (حالتی که بنبست میتواند رخ دهد). هنگامی که یک فرایند جدید وارد یک سیستم میشود باید حداکثر تعداد درخواستی از هر یک از منابع را اعلام کند که «نباید از تعداد کل منابع در سیستم تجاوز کند». همچنین هنگامی که یک فرایند همه منابع درخواستی را تحویل میگیرد باید آنها را پس از اتمام عملیاتش، بازگرداند.
منابع
ویرایشالگوریتم بانکدار برای انجام کار نیاز به دانستن سه چیز دارد:
- هر فرایند چه مقدار از هر نوع منبع را درخواست کردهاست.
- هر فرایند چه مقدار از هر نوع منبع را در اختیار دارد.
- چه تعدادی از هر منبع موجود است.
منابع تنها در صورتی ممکن است اختصاص یابند که شرایط زیر وجود داشته باشد:
- Claim ≤ Resource: تعداد درخواستهای یک فرایند از یک منبع، کوچکترمساوی تعداد کل آن منبع باشد.
- request ≤ available: تعداد نیازهای یک فرایند به یک منبع، کوچکترمساوی تعداد موجود از آن منبع باشد. (نیاز = درخواستها - تخصیص یافتهها)
برخی از منابعی که در سیستمهای واقعی دنبال میشوند حافظه، سمافورها و رابط دسترسی هستند. نام الگوریتم بانکدار برگرفته از این حقیقت است که این الگوریتم میتواند در سیستم بانکی مورد استفاده قرار گیرد تا تضمین کند که بانک همه منابع خورد را از دست نمیدهد. چون بانک هیچگاه پول را به نحوی تخصیص نمیدهد که نتواند نیازهای بقیه مشتریها را برطرف نکند. با الگوریتم بانکدار بانک تضمین میکند که زمانی که مشتریها پول درخواست میکنند بانک هیچگاه به حالت ناامن نمیرود. اگر درخواست مشتری باعث نشود که بانک حالت امن را ترک کند، مبلغ اختصاص میابد در غیر اینصورت مشتری باید صبر کند تا زمانی که مشتریهای دیگر سپرده کافی قرار دهند.
ساختمان دادههای اولیه برای پیادهسازی الگوریتم بانکدار:
n را شماره فرایند و m را شماره منابع موجود قرار دهید. حال به این ساختمان دادهها نیاز است:
- Resources(بردار منابع کل): یک بردار به طول m که نشان دهنده تعداد کل منابع موجود از هر نوع منبع است.
- Available(بردار موجودی): یک بردار به طول m که نشان دهنده تعداد منابع موجود از هر نوع منبع است. اگر Available[j] = k باشد یعنی k تا از منبع نوع Rj موجود است.
- Claim (کل درخواستها): یک ماتریس n×m که حداکثر نیاز هر فرایند را به انواع منابع نشان میدهد. اگر Max[i,j] = k باشد آنگاه فرایند Pi حداکثر به k تا از منبع نوع Rj نیاز دارد.
- Allocation(تخصیص یافته): یک ماتریس n×m که تعداد منابع از هر نوع را که به هر فرایند اختصاص یافتهاست نشان میدهد. اگر Allocation[i,j] = k یعنی فرایند Pi در حال حاضر k تا از هر منبع نوع Rj را در اختیار دارد.
- Need (نیاز): یک ماتریس n×m که نیاز هر فرایند به هر منبع را نشان میدهد. اگر Need[i,j] = k یعنی Pi به k تا از منبع نوع Rj نیاز دارد.
توجه: Need = Claim- Allocation
مثال
ویرایشبا فرض اینکه سیستم دارای چهار نوع منبع A,B،C,D باشد. این مثال نشان میدهد منابع چگونه اختصاص مییابند. توجه که این مثال مشان میدهد سیستم یک لحظه قبل از درخواست جدید در چه حالتی است.
تعداد کل منابع در سیستم(Resource):
R1 R2 R3 ۶ ۳ ۹
بردار موجودی(Available):
(تعداد به کاررفتن هر منبع در کل فرایندها - تعداد کل آن منبع = موجودی آن منبع)
R1 R2 R3 ۱ ۱ ۰
ماتریس منابع تخصیص یافته (Allocation) :
R1 R2 R3 P1 1 0 0 P2 6 1 2 P3 2 1 1 P4 0 0 2
ماتریس کل درخواست ها(Claim) :
R1 R2 R3 P1 3 2 2 P2 6 1 3 P3 3 1 4 P4 4 2 2
ماتریس منابع مورد نیاز فرایندها برای اتمام (Need):
(کل درخواست - تخصیص یافته =نیاز)
R1 R2 R3 P1 2 2 2 P2 0 0 1 P3 1 0 3 P4 4 2 0
حالات امن و ناامن
ویرایش- زمانی یک حالت را امن گوییم که حداقل یک ترتیب از فرایندها وجود دارد که تمام فرایندها میتوانند تا کامل شدن اجرا شوند. از آنجایی که سیستم نمیتواند بداند یک فرایند کی به پایان میرسد یا چه تعداد منابع درخواست خواهد شد، پس سیستم فرض میکند همه فرایندها تلاش میکنند که حداکثر منابع را در اختیار داشته باشند تا زودتر به پایان برسند. از آنجایی که سیستم بهطور ویژه اهمیت نمیدهد که اجرای هر فرایند چقدر طول میکشد پس این یک فرض معقول در اکثر موارد است. همچنین اگر یک فرایند بدون دستیابی به حداکثر منابع پایان یابد فقط اجرا را روی سیستم سادهتر کردهاست. حالت امن در نظر گرفته شده که تصمیم بگیرد فرایند به صف آماده برود. حالت امن ایمنی را تضمین میکند.
طبیعی است که حالتی که امن نباشد، حالت ناامن است.
مثال حالت امن
ویرایشمیتوانیم با نشان دادن اینکه هر فرایند حداکثر منابع مورد نیاز را دریافت و به پایان میرسد حالت امن را در مثال قبل نشان دهیم.
- فرایند p1 برای کامل شدن به <۲ ۲ ۲> واحد به ترتیب از R1,R2,R3 نیاز دارد. اما این تعداد از منابع از تعداد بردار موجودی بیشتر است. پس درخواست رد میشود.
- فرایند p2 برای کامل شدن به <۱ ۰ ۰> نیاز دارد. منابع موجود است. پس اختصاص داده میشود و بردار موجودی به حالت زیر در میآید:
- [<available : <0 1 1> - <0 0 1> = <۰ ۱ ۰]
- فرایند p2 تمام منابع درخواستی اش را در اختیار دارد پس تا تمام شدن اجرا میشود و بعد از آن منابعش را آزاد میکند و منابع آزاد شده به بردار موجودی اضافه میشود.
- [<available: <0 1 0>+<6 1 3>= <۶ ۲ ۳]
- ماتریس درخواستهای کل (Claim) به صورت زیر تغییر میکند :
R1 R2 R3 P1 3 2 2 P2 0 0 0 P3 3 1 4 P4 4 2 2
ᗛ پس از اتمام هر فرایند، باید دوباره از اولین ردیف، نیازمندیها بررسی شود
ویرایش- فرایند p1 برای کامل شدن به <۲ ۲ ۲> نیاز دارد. منابع موجود است. پس اختصاص داده میشود فرایند کامل شده و منابعش را آزاد میکند:
- [<available: <6 2 3>-<2 2 2> + <3 2 2>= <۷۲۳]
- ماتریس درخواستهای کل :
R1 R2 R3 P1 0 0 0 P2 0 0 0 P3 3 1 4 P4 4 2 2
- فرایند p3 برای کامل شدن به <۳ ۰ ۱> نیاز دارد. منابع موجود است. پس اختصاص داده میشود فرایند کامل شده و منابعش را آزاد میکند:
- [<available: <7 2 3>-<1 0 3> + <3 1 4>= <۹ ۳ ۴]
- ماتریس درخواستهای کل :
R1 R2 R3 P1 0 0 0 P2 0 0 0 P3 0 0 0 P4 4 2 2
- فرایند p4 برای کامل شدن به <۰ ۲ ۴> نیاز دارد. منابع موجود است. پس اختصاص داده میشود فرایند کامل شده و منابعش را آزاد میکند:
- [<available : <9 3 4> - <4 2 0> + <4 2 2> = <۹ ۳ ۶]
R1 R2 R3 P1 0 0 0 P2 0 0 0 P3 0 0 0 P4 0 0 0
ᗛبدیهی است که پس از پایان فرایندها، آخرین مقدار بردار موجودی باید با مقدار کل منابع برابر باشد
ویرایشᗛبنابراین ما «ترتیبی» از اجرای فرایندها یافتیم، که از آن، حالت امن نتیجه گرفته میشود
ویرایشمثال برای حالت ناامن
ویرایشدر مثال قبل فرض کنید مقادیر تخصیص یافته فرایند p2 از <۲ ۱ ۶> به <۱ ۱ ۵> و فرایند p1 از <۰ ۰ ۱> به <۱ ۰ ۲> تغییر حالت دهند. با این تغییر ماتریس نیازها هم تغییر خواهد کرد. یعنی:
ماتریس تخصیص یافتهها :
R1 R2 R3 P1 2 0 1 P2 5 1 1 P3 2 1 1 P4 0 0 2
ماتریس نیازها :
R1 R2 R3 P1 1 2 1 P2 1 0 1 P3 1 0 3 P4 4 2 0
بردار موجودی :
R1 R2 R3 ۱ ۱ ۰
- همانگونه که مشاهده میشود تمامی فرایندها به حداقل یک واحد از منبع R1 نیازمندند؛ اما بردار موجودی R1 صفر است. پس این حالت از تخصیص، حالت نا امن است.
منابع
ویرایش- ↑ Dijkstra، Edsger W. Een algorithme ter voorkoming van de dodelijke omarming (EWD-108). E٫W٫ Dijkstra Archive. Center for American History, دانشگاه تگزاس در آستین. (original; transcription) (in Dutch; An algorithm for the prevention of the deadly embrace)
- ↑ Bic, Lubomir F.; Shaw, Alan C. (2003). Operating System Principles. Prentice Hall. ISBN 0-13-026611-6.[پیوند مرده]
مطالعه بیشتر
ویرایش- "Operating System Concepts" by Silberschatz, Galvin, and Gagne (pages 259-261 of the 7th edition)
- Dijkstra، Edsger W. The mathematics behind the Banker’s Algorithm (EWD-623). E٫W٫ Dijkstra Archive. Center for American History, دانشگاه تگزاس در آستین. (original; transcription) (1977), published as pages 308–312 of Edsger W. Dijkstra, Selected Writings on Computing: A Personal Perspective, Springer-Verlag, 1982. ISBN 0-387-90652-5
پیوند به بیرون
ویرایش- Deadlock Recovery, Avoidance and Prevention بایگانیشده در ۳۱ اوت ۲۰۱۰ توسط Wayback Machine