КАТЕГОРИИ: Архитектура-(3434)Астрономия-(809)Биология-(7483)Биотехнологии-(1457)Военное дело-(14632)Высокие технологии-(1363)География-(913)Геология-(1438)Государство-(451)Демография-(1065)Дом-(47672)Журналистика и СМИ-(912)Изобретательство-(14524)Иностранные языки-(4268)Информатика-(17799)Искусство-(1338)История-(13644)Компьютеры-(11121)Косметика-(55)Кулинария-(373)Культура-(8427)Лингвистика-(374)Литература-(1642)Маркетинг-(23702)Математика-(16968)Машиностроение-(1700)Медицина-(12668)Менеджмент-(24684)Механика-(15423)Науковедение-(506)Образование-(11852)Охрана труда-(3308)Педагогика-(5571)Полиграфия-(1312)Политика-(7869)Право-(5454)Приборостроение-(1369)Программирование-(2801)Производство-(97182)Промышленность-(8706)Психология-(18388)Религия-(3217)Связь-(10668)Сельское хозяйство-(299)Социология-(6455)Спорт-(42831)Строительство-(4793)Торговля-(5050)Транспорт-(2929)Туризм-(1568)Физика-(3942)Философия-(17015)Финансы-(26596)Химия-(22929)Экология-(12095)Экономика-(9961)Электроника-(8441)Электротехника-(4623)Энергетика-(12629)Юриспруденция-(1492)Ядерная техника-(1748) |
Обнаружение и устранение взаимоблокировок
Пренебрежением проблемой в целом (страусовый алгоритм) Методы борьбы с взаимоблокировками Четыре стратегии избегания взаимоблокировок: 1. Пренебрежением проблемой в целом (вдруг пронесет). 2. Обнаружение и устранение (взаимоблокировка происходит, но оперативно ликвидируется). 3. Динамическое избежание тупиков. 4. Предотвращение четырех условий, необходимых для взаимоблокировок.
Если вероятность взаимоблокировки очень мала, то ею легче пренебречь, т.к. код исключения может очень усложнить ОС и привести к большим ошибкам. Также многие взаимоблокировки тяжело обнаружить. Этот алгоритм используется как в UNIX, так и в Windows. Поэтому (и не только) на серверах часто устанавливают автоматическую перезагрузку (раз в сутки, как правило ночью), если возникнет взаимоблокировка, то после перезагрузки ее не будет.
Система не пытается предотвратить взаимоблокировку, а пытается обнаружить ее и устранить.
Обнаружение взаимоблокировки при наличии одного ресурса каждого типа Под одним ресурсом каждого типа, подразумевается один принтер, один сканер и один плоттер и т.д. Рассмотрим систему из 7-ми процессов и 6-ти ресурсов. Обнаружение взаимоблокировки при наличии одного ресурса каждого типа
Визуально хорошо видна взаимоблокировка, но нам нужно чтобы ОС сама определяла взаимоблокировку. Для этого нужен алгоритм. Рассмотрим один из алгоритмов. Для каждого узла N в графе выполняется пять шагов. 1. Задаются начальные условия: L-пустой список, все ребра не маркированы. 2. Текущий узел добавляем вконец списка L и проверяем количество появления узла в списке. Если он встречается два раза, значит цикл и взаимоблокировка. 3. Для заданного узла смотрим, выходит ли из него хотя бы одно немаркированное ребро. Если да, то переходим к шагу 4, если нет, то переходим к шагу 5. 4. Выбираем новое немаркированное исходящее ребро и маркируем его. И переходим по нему к новому узлу и возвращаемся к шагу 3. 5. Зашли в тупик. Удаляем последний узел из списка и возвращаемся к предыдущему узлу. Возвращаемся к шагу 3. Если это первоначальный узел, значит, циклов нет, и алгоритм завершается. Алгоритм обнаружения взаимоблокировок
Для нашего случая тупик обнаруживается в списке L=[B,T,E,V,G,U,D,T]
Обнаружение взаимоблокировки при наличии нескольких ресурсов каждого типа Рассмотрим систему. m - число классов ресурсов (например: принтеры это один класс) n - количество процессов P(n) - процессы E - вектор существующих ресурсов E(i) - количество ресурсов класса i A - вектор доступных (свободных) ресурсов A(i) - количество доступных ресурсов класса i С - матрица текущего распределения (какому процессу, какие ресурсы принадлежат) R - матрица запросов (какой процесс, какой ресурс запросил)
C(ij) - количество экземпляров ресурса j, которое занимает процесс P(i). R(ij) - количество экземпляров ресурса j, которое хочет получить процесс P(i). Общее количество ресурсов равно сумме занятых и свободных ресурсов
Рассмотрим алгоритм поиска тупиков. Алгоритм поиска тупиков при наличии нескольких ресурсов каждого типа
Если остаются не маркированные процессы, значит, есть тупик. Рассмотрим работу алгоритма на реальном примере.
Используем алгоритм: 1. Третий процесс может получить желаемые ресурсы, т.к. R (2 1 0 0) = A (2 1 0 0) 2. Третий процесс освобождает ресурсы. Прибавляем их к A. А = (2 1 0 0) + (0 1 2 0) =(2 2 2 0). Маркируем процесс. 3. Может выполняться процесс 2. По окончании А=(4 2 2 1). 4. Теперь может работать первый процесс. Тупиков не обнаружено. Если рассмотреть пример, когда второму процессу требуются ресурсы (1 0 3 0), то два процесса окажутся в тупике.
Когда можно искать тупики: · Когда запрашивается очередной ресурс (очень загружает систему) · Через какой то промежуток времени (в интерактивных системах пользователь это ощутит) · Когда загрузка процессора слишком велика
Выход из взаимоблокировки Восстановление при помощи принудительной выгрузки ресурса Как правило, требует ручного вмешательства (например: принтер).
Восстановление через откат Состояние процессов записывается в контрольных точках, и в случае тупика можно сделать откат процесса на более раннее состояние, после чего он продолжит работу снова с этой точки. С принтером опять будут проблемы.
Восстановление путем уничтожения процесса Самый простой способ. Но с принтером опять будут проблемы.
В реальных системах они не годятся.
Дата добавления: 2014-01-06; Просмотров: 836; Нарушение авторских прав?; Мы поможем в написании вашей работы! Нам важно ваше мнение! Был ли полезен опубликованный материал? Да | Нет |