Понятие блокировок. Основные типы блокировок
Блокировка - это механизм, используемый для управления одновременным доступом к общему ресурсу. Блокирование происходит, когда один сеанс удерживает ресурс, запрашиваемый другим сеансом. В результате запрашивающий сеанс будет заблокирован - он "повиснет" до тех пор, пока удерживающий сеанс не завершит работу с ресурсом. Оптимистическое блокирование (optimistic locking) - стратегия блокирования набора данных, при которой раздел, содержащий изменяемую запись, блокируется только на время внесения изменений в запись программой (пользовательским процессом), но не пользователем. Пессимистическое блокирование (pessimistic locking) - стратегия блокирования набора данных, при которой раздел, содержащий изменяемую запись, блокируется на все время внесения изменений в запись пользователем и не доступна для редактирования другим пользователям. Особенность механизма блокировок Oracle - блокировки данных не хранятся как отдельный ресурс, а содержатся непосредственно в блоках данных. Это позволяет избежать таких проблем, как эскалация блокировок. Ниже перечислены пять основных классов блокировок в Oracle. Первые три - общие (используются во всех базах данных Oracle), а две остальные — только в OPS (Oracle Parallel Server - параллельный сервер).
SQL Server поддерживает три основных типа блокировок:
Блокировки могут устанавливаться на трех уровнях:
Взаимоблокировки Возможна ситуация, когда две транзакции блокируют друг друга так, что продолжение работы не возможно без принудительного завершения одной из транзакций. Пример: create table T(i number, j number, s_i varchar(100), s_j varchar(100));
Как правило, для разрешения подобной ситуации монитор транзакций выбирает одну из транзакций для принудительного завершения. Репликация данных. Виды репликации Репликация (replication) — механизм синхронизации содержимого нескольких копий объекта (например, содержимого БД). Репликация — это процесс, под которым понимается копирование данных из одного источника на множество других и наоборот. При репликации изменения, сделанные в одной копии объекта, могут быть распространены в другие копии. Виды репликации Репликация может быть синхронной или асинхронной, как описано ниже. Синхронная репликация В случае синхронной репликации, если данная реплика (копия данных) обновляется, все другие реплики того же фрагмента данных также должны быть обновлены в одной и той же транзакции. Логически это означает, что существует лишь одна версия данных. В большинстве СУБД синхронная репликация реализуется с помощью триггерных процедур (возможно, скрытых и управляемых системой). Недостаток: синхронная репликация создаёт дополнительную нагрузку при выполнении всех транзакций, в которых обновляются какие-либо реплики (также могут возникать проблемы, связанные с доступностью данных).
Популярное: Как вы ведете себя при стрессе?: Вы можете самостоятельно управлять стрессом! Каждый из нас имеет право и возможность уменьшить его воздействие на нас... Почему человек чувствует себя несчастным?: Для начала определим, что такое несчастье. Несчастьем мы будем считать психологическое состояние... Почему люди поддаются рекламе?: Только не надо искать ответы в качестве или количестве рекламы... ©2015-2024 megaobuchalka.ru Все материалы представленные на сайте исключительно с целью ознакомления читателями и не преследуют коммерческих целей или нарушение авторских прав. (1349)
|
Почему 1285321 студент выбрали МегаОбучалку... Система поиска информации Мобильная версия сайта Удобная навигация Нет шокирующей рекламы |