Опубликован: 29.07.2008 | Уровень: специалист | Доступ: платный
Лекция 6:

Перенос базы данных на другие системы

< Лекция 5 || Лекция 6: 12 || Лекция 7 >
Аннотация: В данной лекции приводятся материалы по переносу базы данных на другие системы, в частности, рассматривается применение методики резервного копирования и восстановления для перемещения данных отсоединение, копирование обратное присоединение базы данных для перемещения данных, а также принципы планирования заданий по автоматическому перемещению данных между серверами

Итак, у вас появилась необходимость разместить данные в нескольких местах. Возможно, распределение данных необходимо для повышения производительности или обеспечения аварийного восстановления. А может, у вас есть корпоративный центр, которому необходимо распределить данные по региональным или локальным офисам. Существует много причин для перемещения данных.

Определяя, какие из данных подлежат распределению, следует учитывать следующие факторы:

  • Допустимая задержка поступления данных.Как часто изменяются данные? Насколько часто эти изменения необходимо загружать на получатели?
  • Редактирование. Кому необходим допуск к изменению данных? Нужно ли объединять модификации?
  • Общий доступ к данным.Вам нужно пересылать только сегмент данных или всю базу данных?
  • Безопасность.Уязвимы ли ваши данные?

В лекциях 4-5 мы научились использовать T-SQL для резервного копирования и восстановления баз данных. В данной лекции будет рассмотрено четыре метода переноса данных SQL Server 2005, в том числе, резервное копирование с последующим восстановлением. Каждый метод имеет свои сильные и слабые стороны, и каждый подходит для переноса определенного типа данных. Вот эти четыре метода:

  • Резервное копирование и восстановление
  • Отсоединение и присоединение
  • Репликация
  • Службы интеграции SQL Server (SSIS)

Чтобы использовать некоторые из этих методов, нужно запустить мастер; о мастерах также рассказывается в соответствующих разделах. Службы SSIS и агент SQL Server также можно использовать для планирования и автоматизации выбранного вами метода; об этой методике рассказывает последний раздел данной лекции.

При описании этих методов термин "целевой сервер" мы будем использовать для обозначения системы, на которую перемещаются данные. Термин "сервер-источник" используется для обозначения системы, которая является источником перемещаемых данных. Во всех примерах в этой лекции в качестве исходной используется база данных Adventure Works, которая выполняется на экземпляре SQL Server по умолчанию. Конечным сервером будет именованный экземпляр "target" на том же сервере. Мы будем использовать различные целевые серверы, чтобы проиллюстрировать возможные варианты переноса данных в соответствии с различными требованиями.

Как конвертировать базу данных из SQL Server 2000 в SQL Server 2005

Для обновления базы данных посредством копирования на сервер с установленным пакетом SQL Server 2005 можно воспользоваться одним из следующих методов:

  • Резервное копирование и восстановление
  • Отсоединение и присоединение
  • Мастер копирования базы данных

Прежде чем вступить на путь обновления, запустите средство Microsoft SQL Server 2005 Upgrade Advisor и ознакомьтесь с рекомендациями SQL Server 2005 Upgrade Handbook. Оба этих ресурса доступны для бесплатной загрузки на сайте www.microsoft.com/sql.

Использование резервного копирования и восстановления для переноса данных

Как? Использовать резервное копирование и восстановление в качестве метода переноса данных. Конечно! Одно из главных преимуществ использования резервного копирования заключается в том, что оно оказывает минимальное влияние на работу системы. Резервное копирование - это рутинная операция, которая позволяет продолжать ведение бизнеса во время ее выполнения. Существует три типа резервных копий, которые можно использовать, каждая из них может подойти в какой-либо ситуации. Эти три типа - полная резервная копия, разностная резервная копия базы данных и резервная копия журнала транзакций. Подробная информация о каждом из этих типов и об их использовании приводится в лекциях 4-5.

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

При восстановлении базы данных следует иметь в виду несколько параметров. Во-первых, нужно знать, какой вид восстановления вы собираетесь выполнить. Если вы используете разностные резервные копии и резервные копии журнала транзакций, то придется восстанавливать фрагменты в определенной последовательности. Используйте параметр NO RECOVERY, чтобы сообщить SQL Server, что есть еще фрагменты, которые нужно восстановить. Используйте параметр RECOVERY, чтобы сообщить SQL Server, что вы закончили восстановление данных до желательной точки.

Давайте рассмотрим два доступных варианта переноса данных при помощи резервного копирования/восстановления. В первом варианте используется только полная резервная копия базы данных. Во втором варианте полная резервная копия базы данных используется вместе с разностной резервной копией и резервной копией журнала транзакций.

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

Существует два способа настроить резервное копирование. Вы можете написать сценарии сами или воспользоваться SQL Server Management Studio. Мы продемонстрируем обе методики.

Примечание. Имейте в виду, что в среде SQL Server Management Studio можно воспользоваться кнопкой Script (Сценарий), чтобы сгенерировать сценарий для дальнейшего использования.
Создаем резервную копию при помощи SQL Server Management Studio
  1. В меню Start (Пуск) выберите All Programs,. Microsoft SQL Server 2005, SQL Server Management Studio (Все программы, Microsoft SQL Server 2005, Среда SQL Server Management Studio).
  2. В панели Object Explorer (Обозреватель объектов) щелкните правой кнопкой мыши на базе данных, резервную копию которой нужно создать. В контекстном меню выберите команды Tasks, Back Up (Задачи, Создать резервную копию). При этом откроется следующее диалоговое окно:
  3. В этом диалоговом окне выберите Backup Type (Тип резервной копии) Full (Полная). Здесь можно также задать свойства Backup Set (Резервного набора данных). Дополнительную информацию по этим настройкам и их использованию см. в Электронной документации по SQL Server 2005.

    Укажите свойства в разделе Destination (Назначение), нажав кнопку Add (Добавить). При этом откроется следующее диалоговое окно:


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

    Предупреждение. Будьте особенно осторожны, если используете для резервной копии путь в формате UNC. Это может снизить производительность резервного копирования, а в SQL Server 2000 возможно также снижение общей производительности сервера. Обязательно протестируйте влияние резервного копирования на производительность, прежде чем реализуете его в производственных условиях.
    Примечание. Теперь можно нажать кнопку Script (Сценарий) в диалоговом окне Back Up Database (Резервное копирование базы данных) и получить сгенерированный сценарий в окне New Query (Новый запрос). Следующий сценарий был создан в нашем примере; его также можно найти в файлах примеров под именем FullBackupScript.sql.
    BACKUP DATABASE [AdventureWorks] TO DISK =
    N'C:\Program Files\Microsoft SQL Server\
    MSSQL.1\MSSQL\Backup\AdvWorks20060301.bak'
    WITH NOFORMAT, NOINIT, SKIP, NOREWIND, NOUNLOAD, STATS = 10
    GO
  4. Указав путь, нажмите кнопку ОК. Затем нажмите кнопку ОК в диалоговом окне Backup Database (Резервное копирование базы данных). При этом в указанном файле будет создана резервная копия базы данных
  5. Далее нужно выполнить восстановление базы данных. В панели Object Explorer сервера-адресата щелкните правой кнопкой мыши папку базы данных и выберите из контекстного меню пункт Restore Database (Восстановить базу данных). При этом откроется следующее диалоговое окно:
  6. Укажите имя базы данных в диалоговом окне Restore Database (Восстановление базы данных).
  7. Затем выберите источник, как показано ниже. Для нашего примера выберите From Device (С устройства). Задайте путь к резервной копии, щелкнув кнопку построителя выражений и настройки свойств в диалоговом окне. Из раскрывающегося списка Backup Media (Носитель резервной копии) выберите File (Файл). Нажмите кнопку Add (Добавить) и укажите путь к файлу, в который была записана резервная копия. После того, как все действия будут выполнены, нажмите кнопку OK.

  8. Затем выберите набор резервных данных для восстановления, установив флажок в столбце Restore (Восстановить) рядом с созданным вами набором (в данном случае, файлом).
  9. Теперь выберите в панели Select A Page (Выбор страницы) диалогового окна Restore Database (Восстановление базы данных) страницу Options (Параметры), как показано ниже. Здесь нужно будет задать параметры восстановления. Если планируется перезаписывать базы данных на целевом сервере на регулярной основе, то следует установить флажок Overwrite The Existing Database (Перезаписать существующую базу данных).
  10. Далее, нужно указать пути к файлам базы данных на целевом сервере. Если вы не установили флажок Overwrite The Existing Database (Перезаписать существующую базу данных), то нужно создать новое имя файла в разделе Restore The Database Files As (Восстановить файлы базы данных как), нажав кнопку построителя выражений. (Если вы создаете копию базы данных, убедитесь в том, что дали базе данных новое имя на странице General (Общие) диалогового окна Restore Database (Восстановление базы данных).
  11. В завершение выберите первый вариант, RESTORE WITH RECOVERY, в секции Recovery State (Состояние восстановления). Этот параметр используется при полных восстановлениях базы данных, поскольку позволяет приступить к ее использованию сразу после восстановления. Другие варианты используются в тех случаях, когда при восстановлении используются дополнительные файлы резервных копий.
    Примечание. В этот момент можно нажать кнопку Script (Сценарий), чтобы сгенерировать сценарий процесса восстановления, который возвратит следующий код SQL. Этот код можно найти в файлах примеров под именем FullRestoreScript.sql.
    RESTORE DATABASE [AdventureWorks2]
     FROM DISK = N'C:\Program Files\Microsoft SQL Server\
     MSSQL.1\MSSQL\Backup\AdvWorks20060301.bak'
     WITH FILE = 1,
     MOVE N'AdventureWorks_Data' TO N'C:\Program Files\Microsoft SQL
     Server\
     MSSQL.1\MSSQL\Data\AdventureWorks_Data2.mdf',
     MOVE N'AdventureWorks_Log' TO N'C:\Program Files\Microsoft SQL
     Server\
     MSSQL.1\MSSQL\Data\AdventureWorks_Log2.ldf',
     NOUNLOAD, REPLACE, STATS = 10
  12. Для завершения восстановления базы данных нажмите кнопку ОК.
< Лекция 5 || Лекция 6: 12 || Лекция 7 >
Марат Уздемиров
Марат Уздемиров
Ярослав Малащенко
Ярослав Малащенко
Динара Абдрахманова
Динара Абдрахманова
Казахстан
Volker Grote
Volker Grote
Германия, Bremen