الگوریتم بانکدار
الگوریتم بانکدار یک الگوریتم تخصیص منابع و اجتناب از بنبست است که توسط ادسخر دیسترا توسعه یافته که امنیت آن به وسیله شبیهسازی تخصیص بیشترین مقدار ممکن از تمام منابع آزمایش شده به طوری که یک s-state ایجاد میکند تا برای همه فرایندهای در حال انتظار تمام شرایط بنبست را قبل از تصمیمگیری و اجازه تخصیص منبع بررسی کند.
این الگوریتم در طراحی فرایند در سیستم عامل THE توسعه یافته و در اصل (به هلندی) در EWD108 شرح داده شده.[1]
الگوریتم
الگوریتم بانکدار هر زمان که یک فرایند درخواست منبع کند توسط سیستم عامل اجرا میشود.[2] الگوریتم به وسیله انکار یا تعویق درخواست از بنبست جلوگیری میکند. این در صورتی است که اگر تعیین شود که پذیرش درخواست میتواند سیستم را به حالت نا امن ببرد. (حالتی که بنبست میتواند رخ دهد). هنگامی که یک فرایند جدید وارد یک سیستم میشود باید حداکثر تعداد درخواستی از هر یک از منابع را اعلام کند که «نباید از تعداد کل منابع در سیستم تجاوز کند». همچنین هنگامی که یک فرایند همه منابع درخواستی را تحویل میگیرد باید آنها را پس از اتمام عملیاتش، بازگرداند.
منابع
الگوریتم بانکدار برای انجام کار نیاز به دانستن سه چیز دارد:
- هر فرایند چه مقدار از هر نوع منبع را درخواست کردهاست.
- هر فرایند چه مقدار از هر نوع منبع را در اختیار دارد.
- چه تعدادی از هر منبع موجود است.
منابع تنها در صورتی ممکن است اختصاص یابند که شرایط زیر وجود داشته باشد:
- 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