WikiDer > Синхронизация (информатика)
Эта статья нужны дополнительные цитаты для проверка. (Ноябрь 2014 г.) (Узнайте, как и когда удалить этот шаблон сообщения) |
В Информатика, синхронизация относится к одному из двух различных, но связанных понятий: синхронизация процессы, и синхронизация данные. Синхронизация процессов относится к идее, что несколько процессов должны объединиться или рукопожатие в определенный момент, чтобы достичь соглашения или совершить определенную последовательность действий. Синхронизация данных относится к идее сохранения нескольких копий набора данных в согласованности друг с другом или для поддержания целостность данных. Примитивы синхронизации процессов обычно используются для реализации синхронизации данных.
Необходимость синхронизации
Потребность в синхронизации возникает не только в многопроцессорных системах, но и в любых параллельных процессах; даже в однопроцессорных системах. Ниже перечислены некоторые из основных требований для синхронизации:
Вилки и соединения: Когда задание достигает точки развилки, оно разбивается на N подзадач, которые затем обслуживаются n задачами. После обслуживания каждое подзадание ожидает, пока все остальные подзадачи не будут обработаны. Затем они снова присоединяются и покидают систему. Таким образом, параллельное программирование требует синхронизации, поскольку все параллельные процессы ожидают выполнения нескольких других процессов.
Производитель-Потребитель: В отношениях производитель-потребитель процесс потребителя зависит от процесса производителя до тех пор, пока не будут произведены необходимые данные.
Исключительное использование ресурсов: Когда несколько процессов зависят от ресурса и им требуется доступ к нему одновременно, операционная система должна гарантировать, что только один процессор обращается к нему в данный момент времени. Это снижает параллелизм.
Синхронизация потоков или процессов
Синхронизация потоков определяется как механизм, который гарантирует, что два или более одновременных процессы или же потоки не выполнять одновременно какой-то конкретный сегмент программы, известный как критическая секция. Доступ процессов к критическому участку контролируется с помощью методов синхронизации. Когда один поток начинает выполнять критическая секция (сериализованный сегмент программы) другой поток должен дождаться завершения первого потока. Если правильные методы синхронизации[1] не применяются, это может вызвать состояние гонки где значения переменных могут быть непредсказуемыми и варьироваться в зависимости от времени переключатели контекста процессов или потоков.
Например, предположим, что есть три процесса, а именно 1, 2 и 3. Все три из них выполняются одновременно, и им необходимо совместно использовать общий ресурс (критический раздел), как показано на рисунке 1. Синхронизация должна использоваться здесь для избегать любых конфликтов при доступе к этому общему ресурсу. Следовательно, когда процессы 1 и 2 оба пытаются получить доступ к этому ресурсу, он должен быть назначен только одному процессу за раз. Если он назначен процессу 1, другой процесс (процесс 2) должен дождаться, пока процесс 1 освободит этот ресурс (как показано на рисунке 2).
Еще одно требование синхронизации, которое необходимо учитывать, - это порядок, в котором должны выполняться определенные процессы или потоки. Например, нельзя сесть в самолет до покупки билета. Точно так же нельзя проверить электронную почту до подтверждения соответствующих учетных данных (например, имени пользователя и пароля). Точно так же банкомат не будет предоставлять никаких услуг, пока не получит правильный PIN-код.
Помимо взаимного исключения, синхронизация также касается следующего:
- тупик, что происходит, когда многие процессы ожидают общий ресурс (критический раздел), который удерживается каким-то другим процессом. В этом случае процессы просто ждут и больше не выполняются;
- голодание, что происходит, когда процесс ожидает входа в критическую секцию, но другие процессы монополизируют критическую секцию, и первый процесс вынужден ждать неопределенное время;
- инверсия приоритета, который возникает, когда процесс с высоким приоритетом находится в критической секции и прерывается процессом со средним приоритетом. Это нарушение правил приоритета может произойти при определенных обстоятельствах и может привести к серьезным последствиям в системах реального времени;
- занято ожиданием, который происходит, когда процесс часто опрашивает, чтобы определить, есть ли у него доступ к критическому разделу. Этот частый опрос отнимает время обработки у других процессов.
Минимизация синхронизации
Одна из проблем при разработке алгоритма экзафакции - минимизировать или уменьшить синхронизацию. Синхронизация занимает больше времени, чем вычисления, особенно в распределенных вычислениях. Снижение синхронизации привлекало внимание компьютерных ученых на протяжении десятилетий. Принимая во внимание, что в последнее время это становится все более серьезной проблемой, поскольку разрыв между улучшением вычислений и задержкой увеличивается. Эксперименты показали, что (глобальные) коммуникации из-за синхронизации на распределенных компьютерах занимают доминирующую долю в разреженном итеративном решателе.[2] Эта проблема привлекает все большее внимание после появления нового эталонного показателя, High Performance Conjugate Gradient (HPCG),[3] для ранжирования 500 лучших суперкомпьютеров.
Классические проблемы синхронизации
Вот некоторые классические проблемы синхронизации:
- Проблема производителя и потребителя (также называемая проблемой ограниченного буфера);
- Проблема читателей и писателей;
- Проблема обедающих философов.
Эти задачи используются для тестирования почти каждой вновь предложенной схемы или примитива синхронизации.
Аппаратная синхронизация
Многие системы предоставляют аппаратную поддержку для критическая секция код.
Один процессор или однопроцессорная система может отключить прерывает выполняя текущий код без упреждение, что очень неэффективно на мультипроцессор системы.[4]«Ключевая способность, которая нам требуется для реализации синхронизации в многопроцессоре, - это набор аппаратных примитивов с возможностью атомарного чтения и изменения области памяти. Без такой возможности стоимость создания базовых примитивов синхронизации будет слишком высока и будет увеличиваться по мере того, как количество процессоров увеличивается. Существует ряд альтернативных формулировок основных аппаратных примитивов, каждый из которых обеспечивает возможность атомарного чтения и изменения местоположения, вместе с некоторым способом определить, выполнялись ли чтение и запись атомарно. Эти аппаратные примитивы являются основными строительными блоками, которые используются для создания широкого спектра операций синхронизации на уровне пользователя, включая такие вещи, как замки и барьеры. В общем, архитекторы не ожидают, что пользователи будут использовать базовые аппаратные примитивы, но вместо этого ожидают, что эти примитивы будут использоваться системными программистами для создания библиотеки синхронизации - процесса, который часто бывает сложным и запутанным ».[5] Многие современные аппаратные средства предоставляют специальные атомарные аппаратные инструкции либо испытать и установить слово памяти или сравнивать и менять местами содержимое двух слов памяти.
Стратегии синхронизации в языках программирования
В Ява, чтобы предотвратить вмешательство потоков и ошибки согласованности памяти, блоки кода упаковываются в синхронизированный (lock_object) разделы. Это заставляет любой поток получить указанный объект блокировки, прежде чем он сможет выполнить блок. Блокировка автоматически снимается, когда поток, который получил блокировку и затем выполняет блок, покидает блок или переходит в состояние ожидания внутри блока. Любые обновления переменных, сделанные потоком в синхронизированном блоке, становятся видимыми для других потоков, когда они аналогичным образом получают блокировку и выполняют блок.
Ява синхронизированный блоки, в дополнение к разрешению взаимного исключения и согласованности памяти, включают сигнализацию, то есть отправку событий от потоков, которые получили блокировку и выполняют блок кода, тем, которые ожидают блокировки в блоке. Это означает, что синхронизированные разделы Java сочетают в себе функции мьютексов и событий. Такой примитив известен как монитор синхронизации.
Любой объект может использоваться в качестве замка / монитора в Java. Объявляемый объект является объектом блокировки, когда весь метод отмечен значком синхронизированный.
В .NET Framework имеет примитивы синхронизации. «Синхронизация предназначена для совместной работы, требуя, чтобы каждый поток или процесс следовал механизму синхронизации перед доступом к защищенным ресурсам (критический раздел) для получения согласованных результатов». В .NET блокировка, сигнализация, упрощенные типы синхронизации, спин-ожидание и операции блокировки - это лишь некоторые из механизмов, связанных с синхронизацией.[6]
Реализация синхронизации
Spinlock
Другой эффективный способ реализации синхронизации - использование спин-блокировок. Перед доступом к любому общему ресурсу или фрагменту кода каждый процессор проверяет флаг. Если флаг сброшен, процессор устанавливает флаг и продолжает выполнение потока. Но если флаг установлен (заблокирован), потоки будут продолжать вращаться в цикле и проверять, установлен ли флаг или нет. Но спин-блокировки эффективны только в том случае, если флаг сброшен для более низких циклов, иначе это может привести к проблемам с производительностью, поскольку тратит много циклов процессора на ожидание.[7]
Барьеры
Барьеры просты в использовании и обеспечивают хорошую отзывчивость. Они основаны на концепции реализации циклов ожидания для обеспечения синхронизации. Рассмотрим три потока, работающих одновременно, начиная с барьера 1. По истечении времени t поток 1 достигает барьера 2, но ему все еще приходится ждать, пока потоки 2 и 3 достигнут барьера 2, поскольку он не имеет правильных данных. Как только все потоки достигают барьера 2, все они запускаются снова. По истечении времени t поток 1 достигает барьера 3, но ему придется снова ждать потоков 2 и 3 и правильных данных.
Таким образом, при барьерной синхронизации нескольких потоков всегда будет несколько потоков, которые в конечном итоге будут ждать других потоков, как в приведенном выше примере поток 1 продолжает ждать потоки 2 и 3. Это приводит к серьезному снижению производительности процесса.[8]
Функция ожидания синхронизации барьера для ith поток можно представить как:
(Wbarrier) i = f ((Tbarrier) i, (Rthread) i)
Где Wbarrier - это время ожидания потока, Tbarrier - это количество прибывших потоков, а Rthread - это скорость прибытия потоков.[9]
Эксперименты показывают, что 34% общего времени выполнения тратится на ожидание других более медленных потоков.[8]
Семафоры
Семафоры - это механизмы сигнализации, которые позволяют одному или нескольким потокам / процессорам обращаться к разделу. Семафор имеет флаг, с которым связано определенное фиксированное значение, и каждый раз, когда поток хочет получить доступ к секции, он уменьшает флаг. Аналогичным образом, когда поток покидает раздел, флаг увеличивается. Если флаг равен нулю, поток не может получить доступ к разделу и будет заблокирован, если он решит подождать.
Некоторые семафоры допускают только один поток или процесс в разделе кода. Такие семафоры называются двоичными семафорами и очень похожи на Mutex. Здесь, если значение семафора равно 1, потоку разрешен доступ, а если значение равно 0, доступ запрещен.[10]
Математические основы
Первоначально синхронизация была концепцией, основанной на процессах, посредством которой на объекте могла быть установлена блокировка. Его основное использование было в базах данных. Есть два типа (файла) замок; только для чтения и чтения-записи. Блокировки только для чтения могут быть получены многими процессами или потоками. Блокировки чтения-записи являются исключительными, так как они могут использоваться только одним процессом / потоком одновременно.
Хотя блокировки были получены для файловых баз данных, данные также распределяются в памяти между процессами и потоками. Иногда одновременно блокируется более одного объекта (или файла). Если они не заблокированы одновременно, они могут перекрываться, вызывая исключение взаимоблокировки.
Ява и Ада имеют только эксклюзивные блокировки, потому что они основаны на потоках и полагаются на сравнивать и менять местами инструкция процессора.
Абстрактная математическая основа примитивов синхронизации дается история моноид. Есть также много теоретических устройств более высокого уровня, таких как технологические расчеты и Сети Петри, который можно построить поверх исторического моноида.
Примеры синхронизации
Ниже приведены некоторые примеры синхронизации для разных платформ.[11]
Синхронизация в Windows
Windows обеспечивает:
- маски прерывания, которые защищают доступ к глобальным ресурсам (критический раздел) на однопроцессорных системах;
- спин-блокировки, которые предотвращают в многопроцессорных системах вытеснение потока спин-блокировки;
- диспетчеры, которые действуют как мьютексы, семафоры, События, и таймеры.
Синхронизация в Linux
Linux обеспечивает:
- семафоры;
- спин-блокировка;
- барьеры
- мьютекс
- читатель-писатель замки, для более длинного раздела кодов, к которым обращаются очень часто, но не очень часто.
- Чтение-копирование-обновление (RCU) [12]
Включение и отключение вытеснения ядра заменили спин-блокировки в однопроцессорных системах. До версии ядра 2.6, Linux отключено прерывание для реализации коротких критических секций. Начиная с версии 2.6 и новее, Linux полностью вытеснен.
Синхронизация в Solaris
Солярис обеспечивает:
- семафоры;
- переменные состояния;
- адаптивные мьютексы, двоичные семафоры, которые реализуются по-разному в зависимости от условий;
- читатель-писатель замки:
- турникеты, очередь потоков, ожидающих полученной блокировки.[13]
Синхронизация потоков
Pthreads не зависит от платформы API что обеспечивает:
- мьютексы;
- переменные состояния;
- читатели – писатели замки;
- спин-блокировки;
- барьеры.
Синхронизация данных
Совершенно другая (но связанная) концепция - это концепция синхронизация данных. Это относится к необходимости хранить несколько копий набора данных согласованными друг с другом или поддерживать целостность данных, Рисунок 3. Например, репликация базы данных используется для синхронизации нескольких копий данных с серверами баз данных, которые хранят данные в разных местах.
Примеры включают:
- Синхронизация файлов, например, синхронизация портативного MP3-плеера с настольным компьютером;
- Кластерные файловые системы, которые файловые системы которые поддерживают данные или индексы согласованным образом в целом вычислительный кластер;
- Согласованность кеша, поддерживая синхронизацию нескольких копий данных на нескольких тайники;
- RAID, где данные записываются с избыточностью на несколько дисков, так что потеря любого одного диска не приводит к потере данных;
- Репликация базы данных, где копии данных на база данных синхронизированы, несмотря на возможное большое географическое разделение;
- Ведение журнала, метод, используемый многими современными файловыми системами, чтобы гарантировать, что метаданные файлов обновляются на диске согласованным и непротиворечивым образом.
Проблемы при синхронизации данных
Некоторые из проблем, с которыми может столкнуться пользователь при синхронизации данных:
- сложность форматов данных;
- оперативность;
- безопасность данных;
- Качество данных;
- спектакль.
Сложность форматов данных
Форматы данных имеют тенденцию становиться более сложными со временем по мере роста и развития организации. Это приводит не только к созданию простых интерфейсов между двумя приложениями (исходным и целевым), но и к необходимости преобразовывать данные при их передаче в целевое приложение. ETL Инструменты (загрузка преобразования извлечения) могут быть полезны на этом этапе для управления сложностями формата данных.
В реальном времени
В системах реального времени клиенты хотят видеть текущий статус своего заказа в электронном магазине, текущий статус доставки посылки - отслеживание посылки в реальном времени -, текущий баланс на их счету и т. Д. Это показывает необходимость система реального времени, которая также обновляется, чтобы обеспечить бесперебойный производственный процесс в реальном времени, например, заказ материалов, когда на предприятии заканчиваются запасы, синхронизация заказов клиентов с производственным процессом и т. д. В реальной жизни существует так много примеры, когда обработка в реальном времени дает успешное и конкурентное преимущество.
Безопасность данных
Не существует фиксированных правил и политик для обеспечения безопасности данных. Это может варьироваться в зависимости от используемой вами системы. Несмотря на то, что безопасность поддерживается правильно в исходной системе, которая собирает данные, права безопасности и доступа к информации должны быть реализованы и в целевых системах, чтобы предотвратить любое возможное неправильное использование информации. Это серьезная проблема, особенно когда дело касается обработки секретной, конфиденциальной и личной информации. Поэтому из-за секретности и конфиденциальности передача данных и вся промежуточная информация должна быть зашифрована.
Качество данных
Качество данных - еще одно серьезное ограничение. Для лучшего управления и поддержания хорошего качества данных обычной практикой является хранение данных в одном месте и совместное использование с разными людьми и разными системами и / или приложениями из разных мест. Это помогает предотвратить несогласованность данных.
Спектакль
Процесс синхронизации данных состоит из пяти различных этапов:
- извлечение данных из исходной (или главной, или основной) системы;
- Передача данных;
- преобразование данных;
- загрузка данных в целевую систему.
- обновление данных
Каждый из этих шагов имеет решающее значение. В случае больших объемов данных необходимо тщательно спланировать и выполнить процесс синхронизации, чтобы избежать негативного влияния на производительность.
Смотрите также
- Будущее и обещания, механизмы синхронизации в чисто функциональных парадигмах
Рекомендации
- ^ Грамоли, В. (2015). Больше, чем вы когда-либо хотели знать о синхронизации: Synchrobench, измеряющий влияние синхронизации на параллельные алгоритмы (PDF). Материалы 20-го симпозиума ACM SIGPLAN по принципам и практике параллельного программирования. ACM. С. 1–10.
- ^ Шэнсинь, Чжу, Тунсян Гу и Синпин Лю (2014). «Минимизация синхронизации в разреженных итерационных решателях для распределенных суперкомпьютеров». Компьютеры и математика с приложениями. 67 (1): 199–209. Дои:10.1016 / j.camwa.2013.11.008.
- ^ «Тест HPCG».
- ^ Зильбершац, Авраам; Гань, Грег; Гэлвин, Питер Баер (11 июля 2008 г.). «Глава 6: Синхронизация процессов». Понятия операционной системы (Восьмое изд.). Джон Вили и сыновья. ISBN 978-0-470-12872-5.
- ^ Хеннесси, Джон Л .; Паттерсон, Дэвид А. (30 сентября 2011 г.). «Глава 5: Параллелизм на уровне потоков». Компьютерная архитектура: количественный подход (Пятое изд.). Морган Кауфманн. ISBN 978-0-123-83872-8.
- ^ «Примитивы синхронизации в .NET framework». MSDN, Сеть разработчиков Microsoft. Microsoft. Получено 23 ноября 2014.
- ^ Масса, Энтони (2003). Разработка встроенного программного обеспечения с ECos. Pearson Education Inc. ISBN 0-13-035473-2.
- ^ а б Мэн, Чен, Пан, Яо, Ву, Цзинлей, Тяньчжоу, Пинг, Цзюнь. Минхуэй (2014). «Спекулятивный механизм барьерной синхронизации». Международная конференция IEEE 2014 г. по высокопроизводительным вычислениям и коммуникациям (HPCC), 6-й Международный симпозиум IEEE 2014 г. по безопасности и защите киберпространства (CSS) и 11-я Международная конференция IEEE 2014 г. по встроенному программному обеспечению и системам (ICESS).CS1 maint: несколько имен: список авторов (связь)
- ^ Рахман, Мохаммед Махмудур (2012). «Синхронизация процессов в многопроцессорных и многоядерных процессорах». 2012 Международная конференция по информатике, электронике и зрению (ICIEV). С. 554–559. Дои:10.1109 / ICIEV.2012.6317471. ISBN 978-1-4673-1154-0.
- ^ Ли, Яо, Цин, Кэролайн (2003). Концепции реального времени для встроенных систем. Книги CMP. ISBN 978-1578201242.
- ^ Зильбершац, Авраам; Гань, Грег; Галвин, Питер Баер (7 декабря 2012 г.). «Глава 5: Синхронизация процессов». Понятия операционной системы (Девятое изд.). Джон Вили и сыновья. ISBN 978-1-118-06333-0.
- ^ «Что такое RCU, по сути? [LWN.net]». lwn.net.
- ^ Мауро, Джим. «Турникеты и наследование приоритета - SunWorld - август 1999». sunsite.uakom.sk.
- Шнайдер, Фред Б. (1997). О параллельном программировании. Springer-Verlag New York, Inc. ISBN 978-0-387-94942-0.
внешняя ссылка
- Анатомия методов синхронизации Linux в IBM developerWorks
- Маленькая книга семафоров, Аллен Б. Дауни
- Необходимость синхронизации процессов