From a9850f2a0d145c15a2a19d23bf20ff670fce17fa Mon Sep 17 00:00:00 2001 From: dlenkov <95083555+dlenkov@users.noreply.github.com> Date: Tue, 26 Apr 2022 20:51:50 +0300 Subject: [PATCH] SqlAgDatabase: Fixes Issue #1743 (#1744) - Changes to SqlAGDatabase - Added StatementTimeout optional parameter with default value of 600 seconds (10 mins) to SqlAGDatabase to fix Issue#1743 Users will be able to specify the backup and restore timeout with it. --- CHANGELOG.md | 4 +++ .../DSC_SqlAGDatabase/DSC_SqlAGDatabase.psm1 | 27 ++++++++++++++----- .../DSC_SqlAGDatabase.schema.mof | 1 + .../en-US/about_SqlAGDatabase.help.txt | 5 +++- .../1-AddDatabaseToAvailabilityGroup.ps1 | 2 +- ...atchDefinedDatabaseInAvailabilityGroup.ps1 | 2 +- 6 files changed, 32 insertions(+), 9 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index a9dfddb72..97a207c3f 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -5,6 +5,10 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 ## [Unreleased] +- Changes to SqlAGDatabase + - Added StatementTimeout optional parameter with default value of 600 seconds (10 mins) to SqlAGDatabase to fix Issue#1743 + Users will be able to specify the backup and restore timeout with it. + ### Removed - The deprecated DSC resource SqlDatabaseOwner have been removed _(and replaced_ diff --git a/source/DSCResources/DSC_SqlAGDatabase/DSC_SqlAGDatabase.psm1 b/source/DSCResources/DSC_SqlAGDatabase/DSC_SqlAGDatabase.psm1 index eb14fbd16..f80c98202 100644 --- a/source/DSCResources/DSC_SqlAGDatabase/DSC_SqlAGDatabase.psm1 +++ b/source/DSCResources/DSC_SqlAGDatabase/DSC_SqlAGDatabase.psm1 @@ -153,6 +153,9 @@ function Get-TargetResource .PARAMETER ProcessOnlyOnActiveNode Specifies that the resource will only determine if a change is needed if the target node is the active host of the SQL Server Instance. Not used in Set-TargetResource. + + .PARAMETER StatementTimeout + Set the query StatementTimeout in seconds. Default 600 seconds (10mins). #> function Set-TargetResource { @@ -198,13 +201,18 @@ function Set-TargetResource [Parameter()] [System.Boolean] - $ProcessOnlyOnActiveNode + $ProcessOnlyOnActiveNode, + + [Parameter()] + [ValidateNotNull()] + [System.Int32] + $StatementTimeout = 600 ) Import-SQLPSModule # Connect to the defined instance - $serverObject = Connect-SQL -ServerName $ServerName -InstanceName $InstanceName + $serverObject = Connect-SQL -ServerName $ServerName -InstanceName $InstanceName -StatementTimeout $StatementTimeout # Get the Availability Group $availabilityGroup = $serverObject.AvailabilityGroups[$AvailabilityGroupName] @@ -576,7 +584,6 @@ function Set-TargetResource $restoreLogQueryStringBuilder.AppendLine() | Out-Null $restoreLogQueryStringBuilder.Append('REVERT') | Out-Null } - $restoreLogQueryString = $restoreLogQueryStringBuilder.ToString() } @@ -592,8 +599,8 @@ function Set-TargetResource if ( $availabilityGroupReplica.SeedingMode -eq 'MANUAL') { # Restore the database - Invoke-Query -ServerName $currentAvailabilityGroupReplicaServerObject.NetName -InstanceName $currentAvailabilityGroupReplicaServerObject.ServiceName -Database master -Query $restoreDatabaseQueryString -StatementTimeout 0 - Invoke-Query -ServerName $currentAvailabilityGroupReplicaServerObject.NetName -InstanceName $currentAvailabilityGroupReplicaServerObject.ServiceName -Database master -Query $restoreLogQueryString -StatementTimeout 0 + Invoke-Query -ServerName $currentAvailabilityGroupReplicaServerObject.NetName -InstanceName $currentAvailabilityGroupReplicaServerObject.ServiceName -Database master -Query $restoreDatabaseQueryString -StatementTimeout $StatementTimeout + Invoke-Query -ServerName $currentAvailabilityGroupReplicaServerObject.NetName -InstanceName $currentAvailabilityGroupReplicaServerObject.ServiceName -Database master -Query $restoreLogQueryString -StatementTimeout $StatementTimeout } # Add the database to the Availability Group @@ -714,6 +721,9 @@ function Set-TargetResource .PARAMETER ProcessOnlyOnActiveNode Specifies that the resource will only determine if a change is needed if the target node is the active host of the SQL Server Instance. + + .PARAMETER StatementTimeout + Set the query StatementTimeout in seconds. Default 600 seconds (10mins). #> function Test-TargetResource { @@ -760,7 +770,12 @@ function Test-TargetResource [Parameter()] [System.Boolean] - $ProcessOnlyOnActiveNode + $ProcessOnlyOnActiveNode, + + [Parameter()] + [ValidateNotNull()] + [System.Int32] + $StatementTimeout = 600 ) $configurationInDesiredState = $true diff --git a/source/DSCResources/DSC_SqlAGDatabase/DSC_SqlAGDatabase.schema.mof b/source/DSCResources/DSC_SqlAGDatabase/DSC_SqlAGDatabase.schema.mof index 79a7c400b..5af6c9c55 100644 --- a/source/DSCResources/DSC_SqlAGDatabase/DSC_SqlAGDatabase.schema.mof +++ b/source/DSCResources/DSC_SqlAGDatabase/DSC_SqlAGDatabase.schema.mof @@ -11,5 +11,6 @@ class DSC_SqlAGDatabase : OMI_BaseResource [Write, Description("If set to `$true`, this ensures the database owner of the database on the primary replica is the owner of the database on all secondary replicas. This requires the database owner is available as a login on all replicas and that the **PsDscRunAsCredential** has _impersonate any login_, _control server_, _impersonate login_, or _control login_ permissions. If set to `$false`, the owner of the database will be the username specified in **PsDscRunAsCredential**. The default is `$false`.")] Boolean MatchDatabaseOwner; [Write, Description("If set to `$true`, this adds the restore option `WITH REPLACE`. If set to `$false`, existing databases and files will block the restore and throw error. The default is `$false`.")] Boolean ReplaceExisting; [Write, Description("Specifies that the resource will only determine if a change is needed if the target node is the active host of the _SQL Server_ instance.")] Boolean ProcessOnlyOnActiveNode; + [Write, Description("Set the query timeout in seconds for the backup and restore operations. The default is 600 seconds (10mins).")] SInt32 StatementTimeout; [Read, Description("Returns if the current node is actively hosting the _SQL Server_ instance.")] Boolean IsActiveNode; }; diff --git a/source/DSCResources/DSC_SqlAGDatabase/en-US/about_SqlAGDatabase.help.txt b/source/DSCResources/DSC_SqlAGDatabase/en-US/about_SqlAGDatabase.help.txt index 214e0e88c..901f5c996 100644 --- a/source/DSCResources/DSC_SqlAGDatabase/en-US/about_SqlAGDatabase.help.txt +++ b/source/DSCResources/DSC_SqlAGDatabase/en-US/about_SqlAGDatabase.help.txt @@ -48,4 +48,7 @@ PARAMETER MatchDatabaseOwner The default is '$false'. .PARAMETER ProcessOnlyOnActiveNode - Specifies that the resource will only determine if a change is needed if the target node is the active host of the SQL Server Instance. + Specifies that the resource will only determine if a change is needed if the target node is the active host of the SQL Server Instance. + +.PARAMETER StatementTimeout + Set the query StatementTimeout in seconds. Default 600 seconds (10mins). diff --git a/source/Examples/Resources/SqlAGDatabase/1-AddDatabaseToAvailabilityGroup.ps1 b/source/Examples/Resources/SqlAGDatabase/1-AddDatabaseToAvailabilityGroup.ps1 index 518b8dd60..eb24b1ed4 100644 --- a/source/Examples/Resources/SqlAGDatabase/1-AddDatabaseToAvailabilityGroup.ps1 +++ b/source/Examples/Resources/SqlAGDatabase/1-AddDatabaseToAvailabilityGroup.ps1 @@ -1,7 +1,7 @@ <# .DESCRIPTION This example shows how to ensure that the databases 'DB*' and 'AdventureWorks' - are members in the Availability Group 'TestAG'. + are members of the Availability Group 'TestAG'. In the event this is applied to a Failover Cluster Instance (FCI), the ProcessOnlyOnActiveNode property will tell the Test-TargetResource function diff --git a/source/Examples/Resources/SqlAGDatabase/3-MatchDefinedDatabaseInAvailabilityGroup.ps1 b/source/Examples/Resources/SqlAGDatabase/3-MatchDefinedDatabaseInAvailabilityGroup.ps1 index 0e316bbec..f39aae417 100644 --- a/source/Examples/Resources/SqlAGDatabase/3-MatchDefinedDatabaseInAvailabilityGroup.ps1 +++ b/source/Examples/Resources/SqlAGDatabase/3-MatchDefinedDatabaseInAvailabilityGroup.ps1 @@ -1,7 +1,7 @@ <# .DESCRIPTION This example shows how to ensure that the databases 'DB*' and 'AdventureWorks' - 'are the only members of the Availability Group 'TestAG'. + are the only members of the Availability Group 'TestAG'. #> Configuration Example