استعصاء

الاستعصاء أو المأزق (بالإنجليزية: deadlock) هو حالة تطرأ في مجال الحوسبة المتوازية. تقع حالة الاستعصاء عندما تصل مهمتين متنافستين إلى حالة انتظار كل منهما للأخرى من أجل تحرير مورد تطلبه. المهام التي تصل لهذه الحالة تقع في مأزق نهائيا.

مثال

مثال حي عن حالة استعصاء نجم عن تنافس مهمتين في طلب قفلين بترتيب مختلف. فإذا كان لدينا اقصاء متبادل (M1 وM2) والمهمتين تاليتين :

مهمة أ :
  الحصول على M1
  الحصول على M2
  عمل في حاجة لقفلين
  تحرير M2
  تحرير M1
مهمة  ب:
  الحصول على M2
  الحصول على M1
  عمل في حاجة لقفلين
  تحرير M1
  تحرير M2

الاستعصاء هنا ممكن، حيث إذا كانت عملية التنفيذ تسير كما يلي :

  1. المهمة أ يحصل على M1.
  2. المهمة ب يحصل على M2.
  3. المهمة أ تنتظر للحصول على M2 (المملوك لـ المهمة ب).
  4. المهمة ب تنتظر للحصول على M1 (المملوك لـ المهمة أ).

في هذه الحالة، المهمتين أ وب في حالة استعصاء.

تفادي الاستعصاء

يمكن تدارك حالة الاستعصاء إذا عرفت بعض المعطيات مسبقا. لكل طلب احتكار لمورد، يقوم النظام بمراقبة إذا ما كان ممكنا الوقوع في حالة مريبة يمكن أن تتحول إلى مأزق. فلا يقبل النظام إلا الطلبات التي لا تشكل خطرا. وحتى يتمكن من أخذ القرار عن إذا ما كان الطلب سيؤدي لحالة مريبة أو لا، يجب أن يعرف النظام في كل وقت عدد ونوع الموارد الموجودة المتوفرة أو المحجوزة. خوارزمية المصرفي هي احدى الخوارزميات الكلاسيكية للتوقع المبكر لحالة الاستعصاء. الخوارزمية بحاجة لمعرفة مسبقة لحدود استعمال الموارد. بالنسبة للعديد من الأنظمة يستحيل توقع الاستعصاء قبل كل طلب ما يجعل تفادي الاستعصاء أمرا شبه مستحيل.

خوارزميات انتظار/موت وجريح/انتظار (بالإنجليزية: Wait/Die - Wound/Wait) هي طرق أخرى للتفادي التي تستعمل تقنية كسر التناظر. تأخذ الخورزميتان بعين الاعتبار عمر كل مهمة وتفصل بين مهمة مسنة (م) ومهمة فتية (ف).

يمكن تحديد عمر المهمة باستعمال الختم الزمني (بالإنجليزية: timestamp) عند استحداث المهمة. التواريخ الصغيرة هي للمهام المسنة والتواريخ الكبيرة هي للفتية.

انتظار/موت جرح/انتظار
م بحاجة لمورد يحتكره ف م ينتظر ف يموت
ف بحاجة لمورد يحتكره م ف يموت ف ينتظر

من المهم الأخذ بعين الاعتبار أنه يمكن أن تكون مهمة في حالة مريبة دون أن يؤدي ذلك بالضرورة لحالة استعصاء. مفهوم الحالة المريبة أو لا هو مرجع لاحتمال وقوع النظام في حالة استعصاء أو لا. مثلا إذا طلبت مهمة احتكار مورد أ وينجم عن ذلك حالة مريبة ولكن يحرر مرد آخر ب لتفادي الانتظار المتبادل، فإن الحالة المريبة لا تؤدي إلى حالة استعصاء.

الوقاية

إحدى الطرق تنص على اكتساب الإقصاء المتبادل بنفس الترتيب. في الواقع، إذا احتاجت عدة خيوط لاكتساب عدة قيود لتنفيذ أعمالها وتم ذلك بترتيب مختلف فممكن وقوعها في مأزق (راجع المثال السابق).

من المفيد أيضا الاهتمام بأولوية المهام. فمثلا، إذا طلبت مهمة بأولوية عليا قفلا مشتركا مع مهمة ذات أولوية دنيا، هنا يمكن الوقوع أيضا في حالة استعصاء. الحل لمثل هذه الحالة هو اقتصار استعمال القيود فقط على المهام بنفس مستوى الأولية.

مراجع

ca:Abraçada mortal cs:Deadlock da:Deadlock de:Deadlock Deadlock]] es:Bloqueo mutuo fa:بن‌بست (علوم رایانه) fr:Interblocage he:קיפאון (מדעי המחשב) hu:Holtpont it:Deadlock ja:デッドロック ko:교착 상태 lt:Rakinimo aklavietė pl:Zakleszczenie pt:Deadlock ru:Взаимная блокировка simple:Deadlock sv:Baklås (datavetenskap) uk:Взаємне блокування vi:Deadlock zh:死锁