340 likes | 501 Views
Operatsioonisüsteemid. Операционные системы. Virumaa Kolledž TTÜ Lektor Larissa Joonas 2012 6. Ummikud. Взаимоблокировки. Ressursid. Ресурсы. Ressursside näidised. Примеры ресурсов Printerid Принтеры Strimmerid Ленточные накопители Tableid andmebaasis Таблица в базе данных
E N D
Operatsioonisüsteemid. Операционные системы Virumaa Kolledž TTÜ Lektor Larissa Joonas 2012 6.
Ummikud. Взаимоблокировки
Ressursid. Ресурсы Ressursside näidised.Примеры ресурсов Printerid Принтеры Strimmerid Ленточные накопители Tableid andmebaasis Таблица в базе данных Protsess sai kätte ressurss A ja küsib ressurss B.Процесс получил ресурс A и запрашивает ресурс B Samal ajal teine protsess sai kätte ressursi B ja küsib ressursi A. В то же самое время другой процесс получил ресурс B и запрашивает ресурс A Mõlemad protsessid on blokeeritud. Оба процесса блокируются
Ressursid. Ресурсы (1) Ummik võib tekkida juhul kui: Взаимоблокировки происходят, если … Protsessid saavad kätte eksklusiivse juurdepääsu seadmetele. Процессы получают эксклюзивный доступ к устройствам Me pöördume nende seadmete poole kui ressursidele. Мы обращаемся к этим устройствам, как к ресурсам Ressursid, mida on võimalik välja laadida.Выгружаемые ресурсы Можно безболезненно забирать у владеющего им процесса Ressurssid, mida ei ole võimalik välja laadida. Невыгружаемые ресурсы Нельзя забрать, не уничтожив результата вычислений Ei ole võimalik välja võtta, kui tulemus ei ole hävitatud
Ressursid. Ресурсы (2) Sündmuste järjestus, mis on vajalik ressursside kasutamiseks. Последовательность событий, необходимых для использования ресурса Ressurssi taotlemine. Запрос ресурса Ressurssi kasutamine. Использование ресурса Ressurssi vabastamine. Возврат ресурса Kui ressurss on kinni, peab protsess ootama.Процесс вынужден ждать, если ресурс недоступен Automaatselt blokeerub. Автоматически блокируется Annab tagasi vea koodi Возвращает код ошибки
Sissejuhatus. Введение Formaalne definitsion.Формальное определение : Protsesside grupp on ummikus, kui iga protsess grupis ootab sündmust, mis võimaldaks kutsuda ainult teist protsessi samast grupist. Группа процессов находится в тупиковой ситуации, если каждый процесс из группы ожидает события, которое может вызвать только другой процесс из той же группы
Sissejuhatus. Введение (1) Tavaliselt on vaja vabastada kinnitatud ressurss. Обычно необходимо освободить ресурс, который занят Mitte ükski protsess ei saa... Ни один из процессов не может … Olla käivitatud.Быть запущен Vabastada ressurssi.Освободить ресурс Taastuma. Возобновиться
Neli tingimusi ummiku ilmumistЧетыре условия взаимоблокировки Mõlemapoolne väljaheitmise tingimus Условие взаимного исключения Iga ressurss on igal momendil antud kas ühele kindlale protsessile või on vaba. Каждый ресурс в данный момент или отдан ровно одному процессу, или доступен 1
Neli tingimusi ummiku ilmumistЧетыре условия взаимоблокировки(1) Kinni pidamise ja ootamise tingimus Условие удержания и ожидания Protsessid, mis hoiavad enne saadud ressursse, saavad küsida uusi ressursse. Процессы, в данный момент удерживающие полученные ранее ресурсы, могут запрашивать новые ресурсы 2
Neli tingimusi ummiku ilmumist(2)Четыре условия взаимоблокировки Sundusliku väljalaadimise puudumise tingimus. Условие отсутствия принудительной выгрузки ресурса Ei ole võimalik võtta ära enne saatud ressurssid protsessidest. Protsess peab and välja ressurss vabatahtlikult У процесса нельзя принудительным образом забрать полученные ранее ресурсы. Процесс, владеющий ими, должен сам освободить ресурсы 3
Neli tingimusi ummiku ilmumist(2)Четыре условия взаимоблокировки Tsükkli ootamise tingimus Условие циклического ожидания Tsükkli järjestik 2. või rohkem protsessidest, kui iga protsess ootab järgmise protsessi ressurssi vabastamist. Круговая последовательность из 2-х или более процессов, каждый из которых ждет доступа к ресурсу, удерживаемому следующим членом последовательности 4
Ummiku modellerimine.Моделирование взаимоблокировок (1) Ressursi-allokatsiooni graaf Графы распределения ресурсов Ressurss M kasutab protsess A. ресурс M занят процессом A Protsess B küsib või ootab ressurssi. процесс B запрашивает или ожидает ресурс N Protsessid A ja B on ummikus процессы A и B взаимоблокированы M M N M A B A A B N
Ummiku modellerimine.Моделирование взаимоблокировок (2) Ummikutega töötluse strateegia: Стратегии взаимодействия со взаимоблокировками: Probleemi ignoreerimine Проигнорировать проблему Leidmine ja ennistamine Обнаружение и восстановление
Ummiku modellerimine.Моделирование взаимоблокировок(3) Ummikutega töötluse strateegia: Стратегии взаимодействия со взаимоблокировками: Ummikute dünaamiline vältimine (avoidance) Динамическое избежание тупиковых ситуаций Аккуратное распределение ресурсов Ummikute ära hoidimine (prevention) Предотвращение Püüab garanteerida, et vähemalt üks eelpool mainitud 4-stingimusest ei teki Структурное опровержение одного из 4 условий, необходимых для взаимоблокировки
Ummikute tekkimine. Возникновение взаимоблокировок Ummiku modellerimine.Моделирование взаимоблокировок (3) A B C A B C M N P
Ummiku modellerimine.Моделирование взаимоблокировок (4) Ummikute ära hoidimine. Предотвращение взаимоблокировок A B C M N P
Jaanalinnu algorütm.Страусовый алгоритм Teesklema, et probleeme ei eksisteeri. Притвориться, что проблема не существует
Jaanalinnu algorütm.Страусовый алгоритм (2) Arukas, kui Разумна, если Ummikuid tekkivad harva. Взаимоблокировки случаются редко Vältimise maksumus on kõrge. Стоимость предотвращения очень высока UNIX ja Windows kasutavad seda algporütmi.UNIX и Windows используют этот алгоритм Valik mugavuse ja korrektsuse vahel Выбор между удобством корректностью
Ummiku leidmine, kui saame ühe ressurssi igast tüüpist. Обнаружение взаимоблокировки при наличии одного ресурса каждого типа (1) Ressurssi graaf. Граф ресурсов A M B N O C P D E R F S
Ummiku leidmine, kui saame ühe ressurssi igast tüüpist. Обнаружение взаимоблокировки при наличии одного ресурса каждого типа(2) Maatriksid. Матрицы Mitmed ressussid igast tüüpist. Несколько ресурсов каждого типа
Ummikust väljaumine.Выход из взаимоблокировки(1) Ennistamine sundusliku väljalaadimise abil Восстановление при помощи принудительной выгрузки ресурса Võtta ära teise protsessi ressurssi. Забрать ресурс у другого процесса Sõltub ressurssi tüübist Зависит от типа ресурса Ennistamine tagastamise abil Восстановление через откат Perioodilised kontroll punktid. Периодические контрольные точки Kasutama salvestatus seisundit. Использовать сохраненное состояние Protsessi ümberkäivitamine. Перезапустить процесс
Ummikust väljamine.Выход из взаимоблокировки(2) Ennistamine peale protsessi hävitamist. Восстановление путем уничтожения процесса Karm ja kergem variant Грубейший, но и простейший способ выхода Hävitama üht protsessi ummiku tsüklist. Уничтожить один из процессов из цикла взаимоблокировки Valida protsessi, mis on võimalik ümberkäivitada algusest ilma kaotuseta. Выбрать процесс, который можно перезапустить с самого начала без потери
Ohutud ja ohtlikud seisundid.Безопасные и небезопасные состояния (1) Näitab, et a on ohutu. Демонстрация того, что состояние (a) безопасно Vaba 1 Vaba 5 Vaba 0 Vaba 7 Vaba 3 (a) (b) (c) (d) (e)
Ohutud ja ohtlikud seisundid.Безопасные и небезопасные состояния(2) Vaba 2 Vaba 0 Vaba 4 Vaba 3 (a) (b) (c) (d) Näitab, et seisund b ei ole ohutu. Демонстрация того, что b небезопасно
Pankuri algorütm ühe ressurssi tüübile.Алгоритм банкира для одного вида ресурсов Kolm seisundid ressurssi jaotamisele. Три состояния распределения ресурсов (a) (b) (c) Vaba 3 vaba 2 vaba 1 • ohutu • безопасное • Ohutu • безопасное • Mitte ohutu • небезопасное
Ummikute ära hoidimine. Mõlemapoolne väljaheitmise tingimuse atakk. Предотвращение взаимоблокировок.Атака условия взаимного исключения Mõned seadmed, nagu printer, saavad kasutada cash-faili. Некоторые устройства, например, принтер, могут использовать подкачку Printeri ressurssi kasutab ainult printeri deemon. Ресурсы принтера использует только демон принтера On võimalik eemaldada ummik printerile. Можно исключить такую взаимоблокировку для принтера
Mõlemapoolne väljaheitmise tingimuse atakk. Атака условия взаимного исключения Mitte kõik seadmed kasutavad cash-i. Не все устройства используют подкачку Printsiipid Принципы: Ärge andke ressursse, kui see ei ole vajalik. Избегайте выделения ресурса, если это не является необходимостью Resurssile peab pretendeerima nii vähe protsesse, kui vähegi võimalik. На ресурс должно претендовать как можно меньше процессов
Kinni pidamise ja ootamis tingimuse atakk.Атака условия удержания и ожидания Välja nõudma ressursside taotlemist enne protsessi starti Требовать от процессов запроса ресурсов до старта Protsess ei ole kohustatud ootama vajalike asju. Процесс никогда не должен ждать того, что ему нужно
Kinni pidamise ja ootamis tingimuse atakk.Атака условия удержания и ожидания (2) • Probleeme. Проблемы: Mõnikord protsess enne starti ei tea, kui palju ja missugused ressurssie on vaja. До старта может быть неизвестно, сколько и каких ресурсов необходимо Raske kasutada ressursse optimaalselt. Ресурсы не могут быть использованы оптимально • Variandid. Вaрианты: Protsess peab vabastama kõik kasutatavad ressursid. Процесс должен освободить все используемые им ресурсы Taotlema kõiki vajalike ressursse. Запрашивает сразу все необходимое
Sundusliku väljalaadimise puudumise tingimuse atakkАтака условия отсутствия принудительной выгрузки ресурса Mitte kindel tingimus. Ненадежное условие Printeri eemaldamine.Изъятие принтера
Tsükkli ootamise tingimuse atakk. Атака условия циклического ожидания (1) Nummerdatud ressurssid. Пронумерованные ресурсы Graaf.
Kahefaaside blokeeringДвухфазовое блокирование Esimene faas. Первая фаза Protsess katsub blokeerida kõik vajalikud kirjendid ühe kaupa. Процесс пытается заблокировать все требуемые записи по одной за раз Kui mingisugune kirjend on blokeeritud, kõik blokeeringud vabastuvad ja algab 1. faas Если какая-то запись заблокирована, то все блокировки освобождаются и 1 фаза начинается заново Kui 1. faas läks edukalt, 2. faas algab. Если первая фаза прошла успешно, то начинается вторая фаза Uuendamine. Обновление Blookeringute vabastamine.Освобождение блокировок Ei ole samasugune nagui üheaegne ressurssi taotlemise metood. Не имеет общего с методом одновременного запроса всех ресурсов Algorütm töötab, kui programmerija vaatas üle varem tehtud 1. faasi haldamise. Алгоритм работает, если программист предусмотрел обработку первой фазы Программа может быть остановлена и перезапущена
Ummikud ilma ressursita. Тупики без ресурсов Võimalik, kui kaks protsessid koostöötavad Возможно при взаимодействии двух процессов Igasugune ootab kuni teine täidab oma ülesanne. Каждый ждет, пока другой выполнит какую-то задачу Võib juhtuda semafooriga.Может случиться с семафорами Igasugune protsess tahab kasutada down()kahe semafooriga (mutexja teine) Каждый процесс хочет совершитьdown()на двух семафорах (mutexи другой) Kui järjekord on ebaõige, juhtub ummik. Если последовательность неправильна, то происходит блокировка
NälgimineГолодание Ressurside jaotamise algorütm. Алгоритм распределения ресурсов Võib anda lühemale ülesannele Может быть дано самой короткой задаче Töötab hästi süsteemis koos paljude väiksete ülessannetega. Хорошо работает в системе со множеством маленьких задач Võib lasta surra nälga suurel ülessandel Может дать умереть с голоду большой задаче Lahendamine. Решение: Esimene tuli - esimene on teenindatud. Первым пришел – первым обслужен