4

У меня есть база данных, работающая на SQL Server 2005. База данных составляет 20 ГБ, а файл LDF - 35 ГБ! Сейчас у меня мало места на диске и я хочу сжать файл журнала.

Как я могу это сделать и как я могу остановить это снова?

2 ответа2

3

Ну, в основном, ваши файлы журнала SQL Server должны регулярно создаваться резервные копии - каждые пару часов или дней. Когда вы сделаете это, они уменьшатся.

Теперь, в вашем случае, вы можете сделать две вещи:

  • переключите "модель восстановления" вашей базы данных на "простую". Это означает следующее: вы сможете восстановить базу данных до последней полной или разностной резервной копии данных, но с тех пор ничего - у вас будет меньше журналов, хотя

  • использование

    BACKUP LOG (yourDB) WITH TRUNCATE_ONLY 
    

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

2

Резюме: Если вы оказались в такой ситуации, вы, вероятно, захотите вариант 1 ниже. Пропустите там, чтобы решить проблему, или читайте дальше для более подробного объяснения.


База данных в Microsoft SQL Server имеет различные "режимы восстановления", в которых она может быть настроена:

  1. Просто. В простом режиме восстановления вы можете создавать как полные, так и разностные резервные копии базы данных. Полная резервная копия содержит всю базу данных в определенный момент времени, а дифференциальная резервная копия содержит все, что изменилось со времени последней полной резервной копии.

    План резервного копирования для такой базы данных может быть «Полное резервное копирование каждое воскресенье плюс ежедневное разностное резервное копирование». Это сохраняет разностные резервные копии относительно небольшими, поскольку они содержат только данные, измененные с предыдущего воскресенья. В случае сбоя вы теряете данные не более чем за 1 день.

  2. Полный. Вы по-прежнему можете делать как полное, так и дифференциальное резервное копирование, но вы также должны периодически создавать резервные копии журнала транзакций. В то время как разностные резервные копии содержат изменения базы данных со времени последней полной резервной копии, резервные копии журнала содержат только данные с момента последнего резервного копирования журнала, поэтому резервные копии журнала должны быть небольшими и быстрыми.

    План резервного копирования для базы данных полного восстановления может быть «еженедельное полное резервное копирование, ежедневное разностное резервное копирование и резервное копирование журнала транзакций каждые 5 минут». Это означает, что вы никогда не потеряете более 5 минут данных. При восстановлении такой базы данных вы должны восстановить последнюю разностную резервную копию, а затем применить каждую резервную копию журнала, созданную с этого момента.

  3. Массовая регистрация. Это что-то вроде «режима полного восстановления, кроме случаев, когда я говорю иначе».

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

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

Для получения дополнительной информации о том, как работает журнал транзакций, пожалуйста, прочитайте отличные статьи Пола Рэндала:

Теперь, в ситуации, когда вы попадаете в огромный журнал транзакций, есть два реальных варианта:

Вариант 1: перейти на простую модель восстановления

Вам, вероятно, не нужно делать резервные копии журналов (поскольку вы не делаете это сейчас), поэтому вы можете просто переключиться на простую модель восстановления:

ALTER DATABASE [MyDatabase] SET RECOVERY SIMPLE

Это пометит все в журнале транзакций как усеченное, поэтому файл журнала не станет больше. Как только вы это сделаете, чтобы сжать физический файл журнала:

DBCC SHRINKFILE N'MyDatabase.ldf'

Это означает, что файл журнала будет обрезаться автоматически после каждой транзакции. Поэтому его размер не вырастет из-под контроля. Вероятно, вам вообще не придется управлять журналом транзакций; однако вы теряете возможность восстанавливать базу данных после последней полной или дифференциальной резервной копии.

Вариант 2: начать делать резервные копии журнала транзакций

Если вам действительно нужно полное восстановление, то вы должны начать делать резервные копии журнала транзакций.

Во-первых, чтобы выйти из плохой ситуации, вы хотите укоротить весь журнал, а затем сжать его:

BACKUP LOG [MyDatabase] WITH TRUNCATE_ONLY
GO
DBCC SHRINKFILE N'MyDatabase.ldf'
GO

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

BACKUP LOG [MyDatabase] TO DISK = N'C:\Backups\MyDatabase_Log_Backup1.bak' WITH INIT

Примечание

DBCC SHRINKFILE не предназначен для регулярного использования:

  • Файлы журналов вырастут до стабильного размера в зависимости от активности базы данных и того, как часто вы делаете резервные копии журналов.
  • Сжатие файлов данных полностью фрагментирует ваши индексы.

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

Всё ещё ищете ответ? Посмотрите другие вопросы с метками .