Руководство. Перенос из виртуальной машины Azure или локального сервера PostgreSQL в База данных Azure для PostgreSQL с помощью службы миграции
В этой статье описано, как перенести виртуальную машину Azure или локальный сервер PostgreSQL на гибкий сервер База данных Azure для PostgreSQL с помощью службы миграции с помощью портал Azure и Azure CLI.
Служба миграции в База данных Azure для PostgreSQL — это полностью управляемая служба, интегрированная в портал Azure и Azure CLI. Он предназначен для упрощения перехода на гибкий сервер База данных Azure для PostgreSQL.
- Необходимые компоненты
- Выполнение миграции
- Отслеживайте ход миграции.
- Проверка миграции при завершении
Необходимые компоненты
Чтобы начать миграцию, вам потребуется следующее:
Перед началом миграции с помощью службы миграции База данных Azure для PostgreSQL важно выполнить следующие предварительные требования, специально предназначенные для сценариев автономной миграции.
- Проверка исходной версии
- Настройка целевой установки
- Настройка настройки сети
- Включение расширений
- Проверка параметров сервера
- Проверка пользователей и ролей
- Отключение высокой доступности (надежность) и реплик чтения в целевом объекте
Проверка исходной версии
Исходная версия сервера PostgreSQL должна быть 9.5 или более поздней.
Если исходная версия PostgreSQL меньше 9.5, перед началом миграции обновите ее до версии 9.5 или более поздней.
Настройка целевой установки
Перед началом миграции необходимо настроить База данных Azure для PostgreSQL в Azure.
Номер SKU, выбранный для База данных Azure для PostgreSQL, должен соответствовать спецификациям исходной базы данных, чтобы обеспечить совместимость и достаточную производительность.
При миграции между версиями PostgreSQL (основными или дополнительными) убедитесь в совместимости между базой данных и приложением, просматривая заметки о выпуске для потенциальных критических изменений.
Настройка настройки сети
Настройка сети имеет решающее значение для правильной работы службы миграции. Убедитесь, что исходный сервер PostgreSQL может взаимодействовать с целевым сервером База данных Azure для PostgreSQL. Следующие конфигурации сети необходимы для успешной миграции.
Дополнительные сведения о настройке сети см . в руководстве по сети для службы миграции.
- Дополнительные рекомендации по работе с сетями:
pg_hba.conf Configuration: чтобы упростить подключение между исходными и целевыми экземплярами PostgreSQL, необходимо проверить и потенциально изменить файл pg_hba.conf. Этот файл включает проверку подлинности клиента и должен быть настроен, чтобы разрешить целевому PostgreSQL подключаться к источнику. Для изменения файла pg_hba.conf обычно требуется перезапуск исходного экземпляра PostgreSQL.
Файл pg_hba.conf находится в каталоге данных установки PostgreSQL. Этот файл следует проверить и настроить, является ли исходная база данных локальным сервером PostgreSQL или сервером PostgreSQL, размещенным на виртуальной машине Azure.
Включение расширений
Чтобы обеспечить успешную миграцию с помощью службы миграции в База данных Azure для PostgreSQL, может потребоваться проверить расширения для исходного экземпляра PostgreSQL. Расширения предоставляют функциональные возможности и функции, которые могут потребоваться для приложения. Перед началом процесса миграции проверьте расширения в исходном экземпляре PostgreSQL.
В целевом экземпляре База данных Azure для PostgreSQL — гибкий сервер включите поддерживаемые расширения, которые определены в исходном экземпляре PostgreSQL.
Дополнительные сведения см. в разделе "Расширения" в База данных Azure для PostgreSQL.
Примечание.
При внесении изменений в shared_preload_libraries
параметр требуется перезапуск.
Проверка параметров сервера
Эти параметры не переносятся автоматически в целевую среду и должны быть настроены вручную.
Сопоставлять значения параметров сервера из исходной базы данных PostgreSQL с База данных Azure для PostgreSQL путем доступа к разделу "Параметры сервера" в портал Azure и вручную обновив значения соответствующим образом.
Сохраните изменения параметров и перезапустите База данных Azure для PostgreSQL, чтобы применить новую конфигурацию при необходимости.
Проверка пользователей и ролей
При миграции в База данных Azure для PostgreSQL важно решить проблему миграции пользователей и ролей отдельно, так как им требуется ручное вмешательство:
Миграция пользователей и ролей вручную. Пользователи и связанные с ними роли должны быть перенесены вручную в База данных Azure для PostgreSQL. Чтобы упростить этот процесс, можно использовать
pg_dumpall
служебную программу с флагом--globals-only
для экспорта глобальных объектов, таких как роли и учетные записи пользователей. Выполните следующую команду, заменив<<username>>
фактическое имя пользователя и<<filename>>
требуемое имя выходного файла:pg_dumpall --globals-only -U <<username>> -f <<filename>>.sql
Ограничение на роли суперпользователя: База данных Azure для PostgreSQL не поддерживает роли суперпользователя. Таким образом, перед миграцией пользователям с привилегиями суперпользователя должны быть удалены эти привилегии. Убедитесь, что разрешения и роли настроены соответствующим образом.
Выполнив следующие действия, вы можете убедиться, что учетные записи пользователей и роли правильно перенесены в База данных Azure для PostgreSQL без возникновения проблем, связанных с ограничениями суперпользователя.
Отключение высокой доступности (надежность) и реплик чтения в целевом объекте
Отключение высокого уровня доступности (надежности) и чтение реплик в целевой среде является важным. Эти функции должны быть включены только после завершения миграции.
Следуя этим рекомендациям, вы можете обеспечить плавный процесс миграции без добавленных переменных, представленных высокой доступностью и репликами чтения. После завершения миграции и стабильной базы данных вы можете включить эти функции для повышения доступности и масштабируемости среды базы данных в Azure.
Выполнение миграции
Вы можете перенести с помощью портал Azure или Azure CLI.
В этой статье описано, как использовать портал Azure для переноса базы данных PostgreSQL с виртуальной машины Azure или локального сервера PostgreSQL на База данных Azure для PostgreSQL. Портал Azure позволяет выполнять различные задачи, включая миграцию базы данных. Следуя инструкциям, описанным в этом руководстве, вы можете легко перенести базу данных в Azure и воспользоваться ее мощными функциями и масштабируемостью.
Настройка задачи миграции
Служба миграции поставляется с простым интерфейсом мастера на основе портал Azure.
Откройте веб-браузер и перейдите на портал. Введите свои учетные данные для входа. Панель мониторинга службы является представлением по умолчанию.
Перейдите к базе данных Azure для гибкого сервера PostgreSQL.
На вкладке "Обзор" гибкого сервера в меню слева прокрутите страницу вниз до миграции и выберите ее.
Нажмите кнопку "Создать", чтобы перейти на гибкий сервер из локальных или виртуальных машин Azure.
Примечание.
При первом использовании службы миграции появится пустая сетка с запросом на начало первой миграции.
Если миграция на гибкий целевой объект сервера уже создана, сетка теперь содержит сведения о попытке миграции.
Нажмите кнопку "Создать", чтобы перейти к серии вкладок на основе мастера, чтобы выполнить миграцию.
Настройка
Пользователь должен предоставить несколько сведений, связанных с миграцией, например имя миграции, тип исходного сервера, параметр и режим.
Имя миграции — это уникальный идентификатор для каждой операции миграции в этот целевой объект в рамках Гибкого сервера. Это поле принимает только буквенно-цифровые символы и не принимает специальные символы, кроме дефиса (-). Имя не может начинаться с дефиса и должно быть уникальным для целевого сервера. Две операции миграции в один и тот же целевой объект в рамках Гибкого сервера не могут иметь одинаковые имена.
Тип исходного сервера. В зависимости от источника PostgreSQL можно выбрать База данных Azure для PostgreSQL отдельный сервер, виртуальную машину Azure или локальную среду.
Параметр миграции— позволяет выполнять проверки перед активацией миграции. Вы можете выбрать любой из следующих параметров.
- Проверка. Проверяет готовность сервера и базы данных к миграции в целевой объект.
- Миграция — пропускает проверки и запускает миграцию.
- Проверка и миграция— выполняет проверку перед активацией миграции. Если нет сбоев проверки, миграция активируется.
Выбор параметра проверки или проверки и миграции всегда является хорошей практикой для выполнения проверок предварительной миграции.
Чтобы узнать больше о проверке премиграции, посетите предварительную проверку.
- Режим миграции позволяет выбрать режим миграции. Автономный — это параметр по умолчанию.
Нажмите кнопку "Далее: подключиться к источнику ".
Сервер среды выполнения
Сервер среды выполнения миграции — это специализированная функция в службе миграции в База данных Azure для PostgreSQL, предназначенная для работы в качестве промежуточного сервера во время миграции. Это отдельный База данных Azure для PostgreSQL — гибкий экземпляр сервера, который не является целевым сервером, но используется для упрощения миграции баз данных из исходной среды, доступной только через частную сеть.
Дополнительные сведения о сервере среды выполнения см. на сервере среды выполнения миграции.
Подключение к источнику
Вкладка "Подключиться к источнику " предлагает предоставить сведения, связанные с источником, выбранным на вкладке "Настройка", который является источником баз данных.
- Имя сервера— укажите имя узла или IP-адрес исходного экземпляра PostgreSQL.
- Порт — номер порта исходного сервера
- Имя входа администратора сервера — имя пользователя исходного сервера PostgreSQL
- Пароль — пароль исходного сервера PostgreSQL
- Режим SSL. Поддерживаемые значения предпочтительны и обязательны. Если SSL на исходном сервере PostgreSQL имеет значение OFF, используйте SSLMODE=prefer. Если ssl на исходном сервере включен, используйте SSLMODE=require. Значения SSL можно определить в файле postgresql.conf.
- Проверка подключения— выполняет проверку подключения между целевым объектом и источником. После успешного подключения пользователи смогут перейти к следующему шагу. им необходимо определить сетевые проблемы между целевым объектом и источником и проверить имя пользователя или пароль для источника. Установка тестового подключения занимает несколько минут.
После успешного тестового подключения нажмите кнопку "Далее: выбрать целевой объект миграции".
Выбор целевого объекта миграции
На вкладке "Выбор целевого объекта миграции" отображаются метаданные для целевого объекта гибкого сервера, например имя подписки, группа ресурсов, имя сервера, расположение и версия PostgreSQL.
- Имя администратора — имя администратора целевого сервера PostgreSQL
- Пароль — пароль целевого сервера PostgreSQL
- Настраиваемое полное доменное имя или IP-адрес (необязательно): настраиваемое полное доменное имя/IP-адрес является необязательным и может использоваться, если целевой объект находится за пользовательским DNS-сервером или имеет пользовательские пространства имен DNS, что делает его доступным только через определенные полные доменные имена или IP-адреса. Например, это может включать такие записи, как
flexibleserver.example.com
198.1.0.2
, или полное доменное имя PostgreSQL, напримерflexibleserver.postgres.database.azure.com
, если пользовательский DNS-сервер содержит зонуpostgres.database.azure.com
DNS или пересылает запросы для этой зоны168.63.129.16
, где полное доменное имя разрешается в общедоступной или частной зоне DNS Azure. - Проверка подключения — выполняет тест подключения между целевым объектом и источником. После успешного подключения пользователи смогут продолжить следующий шаг. В противном случае необходимо определить сетевые проблемы между целевым объектом и источником и проверить имя пользователя или пароль целевого объекта. Проверка подключения занимает несколько минут, чтобы установить соединение между целевым объектом и источником
После успешного тестового подключения нажмите кнопку Next: Select Database(s) for Migration (Выбор баз данных) для миграции
Выбор баз данных для миграции
На вкладке "Выбранная база данных для миграции" можно выбрать список пользовательских баз данных для миграции с исходного сервера PostgreSQL.
После выбора баз данных нажмите кнопку "Далее: сводка".
Итоги
На вкладке "Сводка " приведены все сведения о источнике и целевом объекте для создания проверки или миграции. Просмотрите сведения и нажмите кнопку "Начать проверку и миграцию".
Отслеживайте ход миграции.
После нажатия кнопки "Начать проверку и миграцию " появится уведомление через несколько секунд, чтобы сказать, что проверка или создание миграции успешно выполнено. Вы автоматически перенаправляетесь на страницу миграции гибкого сервера. Запись находится в состоянии InProgress и подстатке PerformingPreRequisiteSteps. Рабочий процесс занимает 2–3 минуты, чтобы настроить инфраструктуру миграции и проверить сетевые подключения.
Сетка, отображающая миграцию, содержит следующие столбцы: имя, состояние, режим миграции, тип миграции, исходный сервер, тип исходного сервера, базы данных, **Длительность и время начала. Записи отображаются в порядке убывания времени начала с последней записью в верхней части. С помощью кнопки обновления можно обновить состояние выполнения проверки или миграции.
Сведения о переносе
Выберите имя миграции в сетке, чтобы просмотреть связанные сведения.
На вкладке "Настройка" мы выбрали параметр миграции в качестве проверки и миграции. В этом сценарии проверки выполняются сначала перед началом миграции. После завершения субстрата PerformingPrequisiteSteps рабочий процесс переходит в подложку проверки в ходе выполнения.
Если проверка имеет ошибки, миграция переходит в состояние сбоя .
Если проверка завершена без ошибок, начинается миграция, и рабочий процесс переходит в подстаток миграции данных.
Сведения о проверке доступны на уровне экземпляра и базы данных.
- Проверка на уровне экземпляра
- Содержит проверку, связанную с проверкой подключения, исходной версией, т. е. версией >PostgreSQL = 9.5 и проверкой параметров сервера, включенной ли расширения в параметрах сервера База данных Azure для PostgreSQL гибкого сервера.
- Проверка на уровне базы данных
- Он содержит проверку отдельных баз данных, связанных с расширениями и параметрами сортировки в База данных Azure для PostgreSQL, гибким сервером.
Вы можете увидеть проверку и состояние миграции на странице сведений о миграции.
Некоторые возможные состояния миграции:
Состояния миграции
State | Description |
---|---|
InProgress | Выполняется настройка инфраструктуры миграции или выполняется фактическая миграция данных. |
Отменено | Миграция отменена или удалена. |
Неудачно | Миграция завершилась ошибкой. |
Сбой проверки | Проверка завершилась ошибкой. |
Успешно | Миграция прошла успешно и завершена. |
WaitingForUserAction | Применимо только для миграции через Интернет. Ожидание действия пользователя для выполнения переключение. |
Подсостояния миграции
Подсостояние | Description |
---|---|
PerformingPreRequisiteSteps | Настройка инфраструктуры выполняется для миграции данных. |
Проверка в процессе выполнения | Проверка выполняется. |
MigratingData | Выполняется миграция данных. |
CompletingMigration | Миграция находится на заключительных этапах завершения. |
Завершено | Миграция завершена. |
Неудачно | Сбой миграции. |
Подстатки проверки
Подсостояние | Description |
---|---|
Неудачно | Сбой проверки. |
Успешно | Проверка выполнена успешно. |
Предупреждения | Проверка отображается в предупреждении. |
Отмена миграции с помощью портала
Вы можете отменить все текущие проверки или миграции. Рабочий процесс должен находиться в состоянии InProgress, чтобы быть отмененным. Невозможно отменить проверку или миграцию в состоянии "Успешно " или "Сбой ".
- Отмена проверки останавливает дальнейшие действия проверки, а проверка переходит в состояние "Отменено ".
- Отмена миграции останавливает дальнейшие действия миграции на целевом сервере и переходит в состояние "Отменено ". Действие отмены возвращает все изменения, внесенные службой миграции на целевом сервере.
Проверка миграции при завершении
После завершения баз данных необходимо вручную проверить данные между источником и целевым объектом и убедиться, что все объекты в целевой базе данных успешно созданы.
После миграции можно выполнить следующие задачи:
Проверьте данные на гибком сервере и убедитесь, что это точную копию исходного экземпляра.
После проверки включите параметр высокой доступности на гибком сервере по мере необходимости.
Измените номер SKU гибкого сервера в соответствии с потребностями приложения. Для этого изменения требуется перезапуск сервера базы данных.
При изменении параметров сервера из значений по умолчанию в исходном экземпляре скопируйте эти значения параметров сервера на гибком сервере.
Скопируйте другие параметры сервера, такие как теги, оповещения и правила брандмауэра (если применимо), из исходного экземпляра на гибкий сервер.
Внесите изменения в приложение, чтобы указать строка подключения на гибкий сервер.
Внимательно отслеживайте производительность базы данных, чтобы узнать, требуется ли настройка производительности.