-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgbargsley_DemoCode_SQLSaturdayDallas.ps1
98 lines (66 loc) · 3.18 KB
/
gbargsley_DemoCode_SQLSaturdayDallas.ps1
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
# Don't run everything, thanks @alexandair!
clear
break
# Load dbatools module
Import-Module dbatools -force
# Quick overview of commands
Start-Process https://dbatools.io/commands
# Set connection variables
$SQLServers = "localhost\dev2016", "localhost\prd2016", "localhost\dev2017", "localhost\prd2017"
$singleServer = "localhost\dev2016"
$devServers = "localhost\dev2016", "localhost\dev2017"
$prdServers = "localhost\prd2016", "localhost\prd2017"
$CmsInstance = 'localhost\sql2017'
$ComputerName = 'DESKTOP-EBH9MR8'
$dev2016 = "localhost\dev2016"
$prd2016 = "localhost\prd2016"
$prd2017 = "localhost\prd2017"
$sql2016 = "localhost\sql2016"
$sql2017 = "localhost\sql2017"
# Get connections from Registered Servers (CMS)
$RegisteredServers = Get-DbaRegisteredServer -SqlInstance $CmsInstance
$RegisteredServers | Select-Object ServerName | Out-GridView
# Max Memory Setting
Test-DbaMaxMemory -SqlInstance $SQLServers | Out-GridView
Set-DbaMaxMemory -SqlInstance $SQLServers -MaxMB 1024
Test-DbaMaxMemory -SqlInstance $SQLServers | Out-GridView
# sp_configure settings
Get-DbaSpConfigure -SqlInstance $singleServer | Out-GridView
$sourceConfig = Get-DbaSpConfigure -SqlInstance $dev2016
$destConfig = Get-DbaSpConfigure -SqlInstance $prd2016
Compare-Object -ReferenceObject $sourceConfig -DifferenceObject $destConfig -Property DisplayName, RunningValue -PassThru | Sort-Object DisplayName | Select-Object DisplayName, RunningValue, ServerName | Out-GridView
# TempDB Configuration
Test-DbaTempDbConfiguration -SqlInstance $dev2016 | Select-Object SqlInstance, Rule, Recommended, CurrentSetting, IsBestPractice | Out-GridView
# Startup Parameters
Get-DbaStartupParameter -SqlInstance $dev2016
Set-DbaStartupParameter -SqlInstance $dev2016 -TraceFlags 3226 -Confirm:$false
# DBA Orphan Files
$SQLServers | Find-DbaOrphanedFile | Out-GridView
# DBA Orphan User
Get-DbaOrphanUser -SqlInstance $prd2017 | Out-GridView
Repair-DbaOrphanUser -SqlInstance $prd2017
# You can use the same JSON the website uses to check the status of your own environment
$SQLServers | Get-DbaSqlBuildReference | Out-GridView
$SQLServers | Test-DbaSqlBuild -MaxBehind 2CU | Out-GridView
Start-Process https://sqlcollaborative.github.io/builds
# SQL Agent Jobs
Get-DbaAgentJob -SqlInstance $dev2016 | Out-GridView
Get-DbaAgentJob -SqlInstance $dev2016 | Export-DbaScript -Path C:\temp\jobs.sql
Start-Process C:\Temp\jobs.sql
Find-DbaAgentJob -SqlInstance $SQLServers -JobName dbatools_magic | Out-GridView
# Support Tools
Install-DbaMaintenanceSolution -SqlInstance $SQLServers -Database DBA -CleanupTime 72 -BackupLocation C:\Temp -InstallJobs -ReplaceExisting | Out-GridView
Install-DbaWhoIsActive -SqlInstance $SQLServers -Database DBA | Out-GridView
Install-DbaFirstResponderKit -SqlInstance $SQLServers -Database DBA | Out-GridView
# You've probably heard about how easy migrations can be with dbatools. Here's an example
$startDbaMigrationSplat = @{
Source = $sql2016
Destination = $sql2017
BackupRestore = $true
NetworkShare = 'C:\temp\backups'
NoSaRename = $true
WithReplace = $true
SetSourceReadOnly = $true
Verbose = $true
}
Start-DbaMigration @startDbaMigrationSplat #| Select * | Out-GridView