Понятно,
что для восстановления последнего согласованного состояния базы данных после
жесткого сбоя журнала изменений базы данных явно недостаточно. Основой восстановления
в этом случае являются журнал и архивная копия базы данных.
Восстановление
начинается с обратного копирования базы данных из архивной копии. Затем для
всех закончившихся транзакций выполняется redo, то есть операции повторно выполняются
в прямом порядке.
Более точно,
происходит следующее:
по журналу в прямом
направлении выполняются все операции;
для транзакций, которые
не закончились к моменту сбоя, выполняется откат.
На самом
деле, поскольку жесткий сбой не сопровождается утратой буферов оперативной памяти,
можно восстановить базу данных до такого уровня, чтобы можно было продолжить
даже выполнение незакончившихся транзакций. Но обычно это не делается, потому
что восстановление после жесткого сбоя — это достаточно длительный процесс.
Хотя к ведению
журнала предъявляются особые требования по части надежности, в принципе возможна
и его утрата. Тогда единственным способом восстановления базы данных является
возврат к архивной копии. Конечно, в этом случае не удастся получить последнее
согласованное состояние базы данных, но это лучше, чем ничего.
Последний
вопрос, который мы коротко рассмотрим, относится к производству архивных копий
базы данных. Самый простой способ — архивировать базу данных при переполнении
журнала. В журнале вводится так называемая «желтая зона», при достижении
которой образование новых транзакций временно блокируется. Когда все транзакции
закончатся и, следовательно, база данных придет в согласованное состояние, можно
производить ее архивацию, после чего начинать заполнять журнал заново.
Можно выполнять
архивацию базы данных реже, чем переполняется журнал. При переполнении журнала
и окончании всех начатых транзакций можно архивировать сам журнал. Поскольку
такой архивированный журнал, по сути дела, требуется только для воссоздания
архивной копии базы данных, журнальная информация при архивации может быть существенно
сжата.
Знаете ли Вы, что такое "Большой Взрыв"? Согласно рупору релятивистской идеологии Википедии "Большой взрыв (англ. Big Bang) - это космологическая модель, описывающая раннее развитие Вселенной, а именно - начало расширения Вселенной, перед которым Вселенная находилась в сингулярном состоянии. Обычно сейчас автоматически сочетают теорию Большого взрыва и модель горячей Вселенной, но эти концепции независимы и исторически существовало также представление о холодной начальной Вселенной вблизи Большого взрыва. Именно сочетание теории Большого взрыва с теорией горячей Вселенной, подкрепляемое существованием реликтового излучения..." В этой тираде количество нонсенсов (бессмыслиц) больше, чем количество предложений, иначе просто трудно запутать сознание обывателя до такой степени, чтобы он поверил в эту ахинею. На самом деле взорваться что-либо может только в уже имеющемся пространстве. Без этого никакого взрыва в принципе быть не может, так как "взрыв" - понятие, применимое только внутри уже имеющегося пространства. А раз так, то есть, если пространство вселенной уже было до БВ, то БВ не может быть началом Вселенной в принципе. Это во-первых. Во-вторых, Вселенная - это не обычный конечный объект с границами, это сама бесконечность во времени и пространстве. У нее нет начала и конца, а также пространственных границ уже по ее определению: она есть всё (потому и называется Вселенной). В третьих, фраза "представление о холодной начальной Вселенной вблизи Большого взрыва" тоже есть сплошной нонсенс. Что могло быть "вблизи Большого взрыва", если самой Вселенной там еще не было? Подробнее читайте в FAQ по эфирной физике.