Add-SqlAvailabilityDatabase
Добавляет базы данных-источник в группу доступности или присоединяет базы данных-получателей к группе доступности.
Синтаксис
ByPath (по умолчанию)
Add-SqlAvailabilityDatabase
[[-Path] <String[]>]
-Database <String[]>
[-Script]
[-WhatIf]
[-Confirm]
[<CommonParameters>]
ByObject
Add-SqlAvailabilityDatabase
[-InputObject] <AvailabilityGroup[]>
-Database <String[]>
[-Script]
[-WhatIf]
[-Confirm]
[<CommonParameters>]
Описание
Командлет Add-SqlAvailabilityDatabase добавляет базы данных-источник в группу доступности или присоединяет базы данных-получатели к группе доступности. Параметр InputObject или Path указывает группу доступности. База данных может принадлежать только одной группе доступности.
Чтобы добавить базы данных в группу доступности, выполните этот командлет на экземпляре сервера, на котором размещена первичная реплика. Укажите одну или несколько локальных баз данных пользователей.
Чтобы присоединить базу данных-получатель к группе доступности, вручную подготовьте базу данных-получатель на экземпляре сервера, на котором размещена вторичная реплика. Затем запустите этот командлет на экземпляре сервера, на котором размещена вторичная реплика.
Примеры
Пример 1. Добавление базы данных в группу доступности
PS C:\>Add-SqlAvailabilityDatabase -Path "SQLSERVER:\SQL\PrimaryServer\InstanceName\AvailabilityGroups\MainAG" -Database "Database16"
Эта команда добавляет базу данных Database16 в группу доступности MainAG. Выполните эту команду на экземпляре сервера-источника группы доступности. Эта команда не подготавливает базы данных-получатели к синхронизации данных.
Пример 2. Присоединение базы данных к группе доступности
PS C:\>Add-SqlAvailabilityDatabase -Path "SQLSERVER:\SQL\SecondaryServer\InstanceName\AvailabilityGroups\MainAG" -Database "Database16"
Эта команда присоединяет базу данных-получатель с именем Database16 к группе доступности MainAG на одном из экземпляров сервера, на котором размещена вторичная реплика.
Пример 3. Добавление базы данных и присоединение базы данных-получателя к группе доступности
PS C:\> $DatabaseBackupFile = "\\share\backups\Database16.bak"
PS C:\> $LogBackupFile = "\\share\backups\Database16.trn"
PS C:\> $AGPrimaryPath = "SQLSERVER:\SQL\PrimaryServer\InstanceName\AvailabilityGroups\MainAG"
PS C:\> $MyAGSecondaryPath = "SQLSERVER:\SQL\SecondaryServer\InstanceName\AvailabilityGroups\MainAG"
PS C:\> Backup-SqlDatabase -Database "Database16" -BackupFile $DatabaseBackupFile -ServerInstance "PrimaryServer\InstanceName"
PS C:\> Backup-SqlDatabase -Database "Database16" -BackupFile $LogBackupFile -ServerInstance "PrimaryServer\InstanceName" -BackupAction Log
PS C:\> Restore-SqlDatabase -Database "Database16" -BackupFile $DatabaseBackupFile -ServerInstance "SecondaryServer\InstanceName" -NoRecovery
PS C:\> Restore-SqlDatabase -Database "Database16" -BackupFile $LogBackupFile -ServerInstance "SecondaryServer\InstanceName" -RestoreAction Log -NoRecovery
PS C:\> Add-SqlAvailabilityDatabase -Path $AGPrimaryPath -Database 'Database16'
PS C:\> Add-SqlAvailabilityDatabase -Path $AGSecondaryPath -Database "Database16"
В этом примере выполняется подготовка базы данных-получателя из базы данных на экземпляре сервера, на котором размещена первичная реплика группы доступности. Она добавляет базу данных в группу доступности в качестве базы данных-источника. Наконец, она присоединяет базу данных-получатель к группе доступности.
Первые четыре команды хранят пути в переменных для последующего использования в примере. Команды назначают значения переменным $DatabaseBackupFile, $LogBackupFile, $AGPrimaryPath и $AGSecondaryPath.
Пятая команда создает резервную копию базы данных с именем Database16, которая находится на сервере-источнике в расположении в $DatabaseBackupFile.
Шестая команда создает резервную копию файла журнала для Database16 на основном сервере в расположение в $LogBackupFile.
Седьмая команда восстанавливает резервную копию базы данных для Database16 на сервере-получателе.
Восьмая команда восстанавливает файл журнала для Database16 на сервере-получателе.
Девятая команда добавляет базу данных в группу доступности на сервере-источнике.
Последняя команда присоединяет базу данных-получатель для этой реплики к группе доступности. Если у вас несколько вторичных реплик, восстановите и присоедините базу данных-получатель для каждой из них.
Пример 4. Создание скрипта для добавления базы данных в группу доступности
PS C:\>Add-SqlAvailabilityDatabase -Path "SQLSERVER:\SQL\PrimaryServer\InstanceName\AvailabilityGroups\MainAG" -Database "Database16" -Script
Эта команда создает скрипт Transact-SQL, который добавляет базу данных Database16 в группу доступности MainAG.
Параметры
-Confirm
Запрашивает подтверждение перед запуском cmdlet.
Свойства параметра
| Тип: | SwitchParameter |
| Default value: | False |
| Поддерживаются подстановочные знаки: | False |
| DontShow: | False |
| Aliases: | cf |
Наборы параметров
(All)
| Position: | Named |
| Обязательно: | False |
| Значение из конвейера: | False |
| Значение из конвейера по имени свойства: | False |
| Значение из оставшихся аргументов: | False |
-Database
Задает массив пользовательских баз данных. Этот командлет добавляет или присоединяет базы данных, указанные этим параметром, в группу доступности. Указанные базы данных должны находиться в локальном экземпляре SQL Server.
Свойства параметра
| Тип: | String[] |
| Default value: | None |
| Поддерживаются подстановочные знаки: | False |
| DontShow: | False |
Наборы параметров
(All)
| Position: | Named |
| Обязательно: | True |
| Значение из конвейера: | True |
| Значение из конвейера по имени свойства: | True |
| Значение из оставшихся аргументов: | False |
-InputObject
Указывает группу доступности в качестве объекта AvailabilityGroup , в которую этот командлет добавляет или присоединяет базы данных.
Свойства параметра
| Тип: | AvailabilityGroup[] |
| Default value: | None |
| Поддерживаются подстановочные знаки: | False |
| DontShow: | False |
Наборы параметров
ByObject
| Position: | 2 |
| Обязательно: | True |
| Значение из конвейера: | True |
| Значение из конвейера по имени свойства: | False |
| Значение из оставшихся аргументов: | False |
-Path
Указывает путь группы доступности, в которую этот командлет добавляет или присоединяет базы данных. Если этот параметр не указан, этот командлет использует текущее рабочее расположение.
Свойства параметра
| Тип: | String[] |
| Default value: | None |
| Поддерживаются подстановочные знаки: | False |
| DontShow: | False |
Наборы параметров
ByPath
| Position: | 2 |
| Обязательно: | False |
| Значение из конвейера: | False |
| Значение из конвейера по имени свойства: | False |
| Значение из оставшихся аргументов: | False |
-Script
Указывает, что этот командлет возвращает скрипт Transact-SQL, выполняющий задачу, выполняемую этим командлетом.
Свойства параметра
| Тип: | SwitchParameter |
| Default value: | None |
| Поддерживаются подстановочные знаки: | False |
| DontShow: | False |
Наборы параметров
(All)
| Position: | Named |
| Обязательно: | False |
| Значение из конвейера: | False |
| Значение из конвейера по имени свойства: | False |
| Значение из оставшихся аргументов: | False |
-WhatIf
Показывает, что произойдет, если командлет будет запущен. Командлет не запускается.
Свойства параметра
| Тип: | SwitchParameter |
| Default value: | False |
| Поддерживаются подстановочные знаки: | False |
| DontShow: | False |
| Aliases: | wi |
Наборы параметров
(All)
| Position: | Named |
| Обязательно: | False |
| Значение из конвейера: | False |
| Значение из конвейера по имени свойства: | False |
| Значение из оставшихся аргументов: | False |
CommonParameters
Этот командлет поддерживает общие параметры: -Debug, -ErrorAction, -ErrorVariable, -InformationAction, -InformationVariable, -OutBuffer, -OutVariable, -PipelineVariable, -ProgressAction, -Verbose, -WarningAction и -WarningVariable. Дополнительные сведения см. в разделе about_CommonParameters.