Поделиться через


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.

Входные данные

Microsoft.SqlServer.Management.Smo.AvailabilityGroup