36251

Процессы. Задачи синхронизации. Задача взаимного исключения, задача Производитель-потребитель, задача Читатели-писатели

Доклад

Информатика, кибернетика и программирование

На уровень долгосрочного планирования выносят действия редкие в системе, но требующие больших системных затрат. На уровень краткосрочного планирования выносятся частые и более короткие по длительности действия по управлению процессами.

Русский

2014-09-23

51 KB

20 чел.

PAGE  3

37.Процессы. Задачи синхронизации. Задача взаимного исключения, задача «Производитель-потребитель», задача «Читатели-писатели».

Процессы

При построении системы управления процессами в большинстве современных ОС принята двухуровневая схема. Это означает, что в системе различают два вида планировщиков процессов, которые выполняют соответственно функции долгосрочного и краткосрочного планирования по использованию центрального процессора для развития на нем определенного множества процессов.

На уровень долгосрочного планирования выносят действия редкие в системе, но требующие больших системных затрат. На уровень краткосрочного планирования выносятся частые и более короткие по длительности действия по управлению процессами.

На уровне долгосрочного планирования объектами управления являются не отдельные процессы, а некоторые их объединения, рассматриваемые как единое целое, объединенное единым функциональным назначением. Такие объекты в различных ОС называют по разному, например - задание, задача, работа, и т.п. Задача планировщика при этом - предоставить работе (задаче, заданию) некоторую виртуальную машину, имеющую в своем составе необходимые для выполнения работы компоненты (процессор, оперативную и внешнюю память, и т.п.).

На уровне краткосрочного планирования объектом управления являются процессы, которые выступают как потребители либо центрального процессора, если речь идет о внутренних процессах, либо других процессоров для внешних процессов. Необходимо отметить два важнейших свойства выполнения работ ОС на уровне краткосрочного планирования. Во-первых, причины, обусловливающие порождение и окончание процессов и отрабатываемые на этом уровне, являются внутренними. Другими словами, заявки или требования на порождение и уничтожение процессов поступают либо от процессов, управляемых на данном уровне, либо с уровня долгосрочного планирования. Во-вторых, особенностью стратегии распределения процессора на данном уровне, которую часто называют диспетчеризацией, является необходимость многократного распределения единственного процессора (за исключением многопроцессорных вычислительных систем) для каждого из планируемых процессов на интервалах их существования для достижения необходимого эффекта мультипрограммирования. Именно поэтому планирование распределения времени процессора в отношении каждого процесса называют краткосрочным.

Задачи синхронизации. Процессы могут выполняться параллельно до тех пор, пока не возникнет потребность в общении между ними. Для обеспечения такого рода взаимодействия необходимо специальным образом планировать и управлять ими в составе любой ОС. Специальные средства ОС устанавливают определенные ограничения на последовательность (очередность) выполнения взаимосвязанных параллельных процессов, обеспечения тем самым их синхронизацию и общение. В каждом конкретном случае синхронизация задается с помощью синхронизирующих правил, которые устанавливаются системой между процессами и определяют порядок их выполнения с целью обеспечения должного взаимодействия.

Ранее нами были определены основные отношения типа:

отношение предшествования,

отношение приоритетности,

отношение взаимного исключения.

Эти отношения и определяют существо синхронизирующих правил. Реализация синхронизирующих правил осуществляется с помощью механизмов (средств) синхронизации. Такие механизмы весьма многочисленны по способам реализации, отличаются степенью эффективности и областями использования в различных ОС и будут рассмотрены в последующих разделах.

Особенности каждого конкретного взаимодействия между двумя или более параллельными процессами определяются задачей синхронизации. Количество различных задач синхронизации неограниченно. Однако некоторые из них являются типичными. К ним относятся: взаимное исключение, производители-потребители, читатели-писатели, обедающие философы и т.д. Большинство задач в реальных ОС по согласованию параллельных процессов можно ре шить либо с помощью этих типовых задач, либо с помощью их модификаций.

Задача взаимного исключения. Это фундаментальная по своему назначению задача. Любая ОС, управляющая параллельными процессами, должна обеспечить тот или иной вариант реализации ее решения. Необходимо согласовать работу n>1 параллельных процессов при использовании некоторого критического ресурса таким образом, чтобы удовлетворить следующим требованиям:

одновременно внутри критической области должно находиться не более одного процесса

критические области не должны иметь приоритеты в отношении друг друга

остановка какого-либо процесса вне его критической области не должна влиять на дальнейшую работу процессов по использованию критического ресурса

решение о вхождении процессов в их критические области при одинаковом времени поступления запросов на такое вхождение и равноприоритетности процессов не откладывается на неопределенный срок, а является конечным во времени

относительные скорости развития процессов неизвестны и произвольны

любой процесс может переходить в любое состояние, отличное от активного, вне пределов своей критической области

освобождение критического ресурса и выход из критической области должны быть произведены процессом, использующим критический ресурс, за конечное время

Задача "Производитель-потребитель". Имеется большое число вариантов постановки и решения такой задачи в рамках конкретных ОС. Наиболее простой случай, когда взаимодействуют два процесса с жестко распределенными между ними функциями. Один процесс вырабатывает сообщения, предназначенные для восприятия и обработки другим процессом. Процесс, вырабатывающий сообщения, называют производителем, а воспринимающий сообщения — потребителем. Процессы взаимодействуют через некоторую обобщенную область памяти, которая по смыслу является критическим ресурсом. В эту область процесс-производитель должен помещать очередное сообщение (в простейшем случае предполагается, что область способна хранить только одно сообщение и сообщения фиксированной длины), а процесс-потребитель должен считывать очередное сообщение. Необходимо согласовать работы двух процессов при одностороннем (в простейшем случае) обмене сообщениями по мере развития процессов таким образом, чтобы удовлетворить следующим требованиям:

выполнять требования задачи взаимного исключения по отношению к критическому ресурсу — обобщенной памяти для хранения сообщения

учитывать состояние обобщенной области памяти, характеризующей возможность или невозможность посылки (принятия) очередного сообщения

Попытка процесса-производителя поместить очередное сообщение в область, из которой не было считано предыдущее сообщение процессом-потребителем, должна быть блокирована. Процесс-производитель должен быть либо оповещен о невозможности помещения сообщения, либо переведен в состояние ожидания возможности поместить очередное сообщение через некоторое время в область памяти, по мере ее освобождения. Аналогично должна быть блокирована попытка процесса-потребителя считать сообщение из области в ситуации, когда процесс-производитель не поместил туда очередного сообщения. Возможны также несколько вариантов реакции на данную ситуацию — сообщение о невозможности считывания либо перевод процесса-потребителя в состояние ожидания поступления очередного сообщения. Если используется вариант с ожиданиями изменения состояния обобщенной области для хранения сообщения, необходимо обеспечить перевод ожидающих процессов в состояние готовности всякий раз, когда изменится состояние области. Либо процесс-производитель поместит очередное сообщение в область. Оно теперь может быть считано ожидающим процессом-потребителем. Либо процесс-потребитель считал очередное сообщение из области и обеспечил возможность ожидающему процессу-производителю послать очередное сообщение.

Множественность постановки задачи “производитель-потребитель” определяется тем, что число как процессов-потребителей, так и процессов-производителей может быть большим одного. Каждый из таких процессов может устанавливать не только одностороннюю, но и двустороннюю связь через одну и ту же обобщенную область или другие области. Области могут хранить не одно, а большее количество сообщений.

Задача "Читатели-писатели". Эта задача также имеет много вариантов. Наиболее характерная область использования этой задачи — при построении файловых систем ОС. В отношении некоторой области памяти, являющейся по смыслу критическим ресурсом для параллельных процессов, работающих с ней, выделяется два типа процессов.

Первый тип — процессы-читатели. Они считывают одновременно информацию из области, если это допускается при работе с конкретным устройством памяти.

Второй тип — процессы-писатели. Они записывают информацию в область и могут делать это, только исключая как друг друга, так и процессы-читатели, т. е. запись должна удовлетворяться на основе решения задачи взаимного исключения. Имеются различные варианты взаимодействия между процессами-писателями и процессами-читателями. Наиболее широко распространены следующие. Устанавливается приоритетность в использовании критического ресурса процессам-читателям. Если хотя бы один процесс-читатель пользуется ресурсом, то он закрыт для использования всем процессам-писателям и доступен для использования всем процессам-читателям. Во втором варианте, наоборот, больший приоритет у процессов-писателей. При появлении запроса от процесса-писателя необходимо закрыть ресурс для использования всем процессам-читателям, которые выдадут запрос позже него.

Задача "Обедающие философы". Хотя и название, и формулировка задачи носят некоторый абстрактный характер, такая задача синхронизации также имеет место при построении систем распределения ресурсов в составе ОС. В рамках этой задачи формулируются требования на синхронизацию работы процессов, которые совместно используют пересекающиеся группы ресурсов.

Пример. Пусть имеются три параллельных процесса X, Y, Z и три ресурса: Р1—устройство ввода с перфокарт; Р2—печатающее устройство, РЗ — накопитель на МД. Особенность развития процессов такова, что для пребывания процесса Х в активном состоянии ему требуется выделить одновременно ресурсы P1 и P2, для пребывания процесса Y в активном состоянии ему требуется выделить одновременно ресурсы P2 и РЗ, для пребывания процесса Z в активном состоянии ему требуется выделить одновременно ресурсы РЗ и P1.

Скорости развития процессов произвольны. Переходы из активного в другие состояния происходят в непредсказуемые моменты. Необходимо обеспечить максимально параллельное и правильное развитие процессов. Синхронизация в данном случае заключается в определенном упорядочении действий процессов по захвату ресурсов во избежание возможных блокировок одними процессами других. В данном случае возможны две опасности: возникновение тупиковой ситуации при распределении ресурсов и возникновение ситуации “голодания” в отношении некоторого процесса при распределении ресурса.

Для пояснения обратимся к формулировке задачи, изложенной в терминологии, предложенной впервые Э.Дейкстрой. За круглым столом расставлены стулья, каждый из которых занимает определенный философ (в первой формулировке Э. Дейкстры число философов равнялось пяти). В центре стола—большое блюдо спагетти, а на столе лежат пять вилок — каждая между двумя соседними тарелками. Каждый философ находится только в двух состояниях — либо он размышляет, либо ест спагетти. Начать думать после еды философу ничто не мешает. Но чтобы начать есть, необходимо выполнить ряд условий. Предполагается, что любой философ, прежде чем начать есть, должен положить из общего блюда спагетти себе в тарелку. Для этого он одновременно должен держать в левой и правой руках по вилке, набрать спагетти в тарелку с их помощью и, не выпуская вилок из рук, начать есть (для простоты здесь вопросы гигиены не рассматриваются). Закончив еду, философ кладет вилки слева и справа от своей тарелки и опять начинает размышлять до тех пор, пока снова проголодается.

Нетрудно заметить, что вилки в данной “столовой ситуации” выступают в качестве пересекающихся ресурсов. Неприятная ситуация может возникнуть в случае, когда философы одновременно проголодаются и одновременно попытаются взять, например, свою левую вилку. В данном случае возникает тупиковая ситуация, так как никто из них не может, по условию начать есть, не имея второй вилки. Однако, вторая вилка может появиться для любого философа только от соседа справа, который в свою очередь ждет появления для себя вилки от своего соседа справа и одновременно не хочет положить свою левую вилку на стол и т. д. Вторая неприятная ситуация (голодание) может возникнуть уже в отношении не всех, а только одного процесса. В обществе философов такая ситуация возникает в случае заговора двух соседей слева и справа против философа, в отношении которого строятся козни. Каждый раз, когда последний желает утолить голод, заговорщики, опережая его, поочередно забирают вилки то слева, то справа от него. Такие согласованные действия злоумышленников приводят жертву к вынужденному голоданию, так как он никогда не может воспользоваться обеими вилками.

Помимо представленных существует много задач с экзотическими названиями и содержанием, но имеющих, тем не менее, совершенно определенную практическую значимость при управлении процессами и распределении ресурсов.

Множественность задач синхронизации объясняет большой набор средств синхронизации, с помощью которых эти задачи решаются. 


 

А также другие работы, которые могут Вас заинтересовать

39778. Первые преобразования большевиков 53.5 KB
  II съезд Советов в отсутствие правых эсеров меньшевиков представителей других социалистических партий они покинули заседание протестуя против свержения Временного правительства принял Декрет о мире выход России из войны Декрет о земле ликвидация помещичьего землевладения передача земли крестьянам на уравнительных началах Декрет о власти установление власти Советов образование Совета Народных Комиссаров во главе с В. Исполнительным органом власти стал ВЦИК в который были избраны большевики и левые эсеры. Наконец триумфальное...
39779. Гражданская война в России 1918 1922 63 KB
  Гражданская война – всегда тяжелейшая социальная катастрофа достаточно напомнить что в годы Гражданской войны в США американцы потеряли убитыми больше чем в годы Второй мировой войны. В полотно Гражданской войны вплетены и различные религиозные национальные культурные противоречия и образы доведенные иногда до кульминации эмоциональным накалом того времени. Гражданская война была и результатом нерешенных проблем ускоренной российской модернизации начала XX века и мирового катаклизма в лице Первой мировой войны и духовного голода...
39780. Индустриализация и коллективизация в СССР 73.5 KB
  Индустриализация и коллективизация в СССР Курс на форсированную индустриализацию В аграрной стране средства можно найти внутри страны перекачивая их в тяжелую промышленность из легкой промышленности и сельского хозяйства. на XV съезде ВКПБ возобладал курс на форсирование индустриализации: за десять лет пробежать расстояние в 50 100 лет на которые отстал СССР от передовых стран Запада. Ценой неимоверных усилий СССР обогнал некоторые крупнейший государства мира.
39781. СССР и международные отношения накануне Второй мировой войны 45.5 KB
  СССР и международные отношения накануне Второй мировой войны Мировой кризис и угроза фашизма в Европе Мировой экономический кризис 19291933 гг. Внешняя политика СССР в 1933 – 1939 гг. В то время как Япония и Германия вышли из Лиги Наций СССР в 1934 г.
39782. СССР в годы Великой Отечественной войны 130 KB
  СССР в годы Великой Отечественной войны Боеспособность вооруженных сил Германии и СССР накануне войны К войне против Советского Союз Германия готовилась тщательно всесторонне и длительное время. Располагая материальными и людскими ресурсами оккупированных стран Германия более чем вдвое превзошла СССР по военноэкономическому потенциалу и смогла гораздо быстрее оснастить свою армию новейшим вооружением. К началу 40х годов началась непосредственная подготовка к нападению на СССР занявшая целый год.
39783. Советский Союз в 1946 – 1953 гг 87 KB
  Победа СССР в Великой Отечественной войне способствовала росту в стране демократических настроений укреплению надежд на либерализацию внутриполитического курса. В первые послевоенные годы происходили некоторые изменения в политической системе СССР. Совнарком СССР был преобразован в Совет Министров СССР что сопровождалось резким увеличением количества министерств и ведомств. Были проведены новые выборы в Верховный совет СССР.
39784. Советский Союз в середине 1950-х – середине 1960-х гг. Период «оттепели» 95.5 KB
  Главой правительства формально стал Маленков который возглавил Совет Министров СССР. Президиум Верховного Совета СССР постановил провести в стране широкую амнистию которая однако не затронула политзаключенных как предлагал первоначально министр внутренних дел. Одновременно началась реорганизация силовых ведомств ограничивались права Особого совещания при МВД ГУЛАГ переходил в ведение Минюста СССР. Маленков выступил на сессии Верховного Совета СССР с предложениями экономических реформ.
39785. Советский Союз в середине 1960-х – середине 1980-х гг. Период «застоя» 83.5 KB
  Брежнев занял пост Председателя Президиума Верховного Совета СССР что значительно увеличило его полномочия как главы государства. провозглашала также и создание в СССР развитого социалистического общества. Согласно новой установке победе коммунизма в СССР должен был предшествовать длительный исторический этап его хронологические рамки не устанавливались который и определялся как период развитого социализма. в СССР происходит фактическая консервация политической системы.
39786. СССР в годы «перестройки» (1985 – 1991 гг.) 76 KB
  Переломным этапом политического развития СССР в годы перестройки стала XIX партийная конференция КПСС проходившая летом 1988 г. На основании решений конференции Верховный Совет СССР принял в декабре 1988 г. закон согласно которому в стране учреждался новый орган высшей власти Съезд народных депутатов СССР из числа которых учреждался постоянно действующий парламент – Верховный Совет СССР.