Announcing dbachecks – Configurable PowerShell Validation For Your SQL Instances
For the last couple of months members of the dbatools team have been working on a new PowerShell module called dbachecks. This open source PowerShell module will enable you to validate your SQL Instances. Today it is released for you all to start to use 🙂
Validate Your SQL Instances?
What do I mean by validate your SQL Instances? You want to know if your SQL Instances are (still) set up in the way that you want them to be or that you have not missed any configurations when setting them up. With dbachecks you can use any or all of the 80 checks to ensure one or many SQL Instances are as you want them to be. Using Pester, dbachecks will validate your SQL Instance(s) against default settings or ones that you configure yourself.
Installation
Installation is via the PowerShell Gallery. You will need to open PowerShell on a machine connected to the internet and run
Install-Module dbachecks
If you are not running your process as admin or you only want (or are able) to install for your own user account you will need to
Install-Module -Scope CurrentUser
This will also install the PSFramework module used for configuration (and other things beneath the hood) and the latest version (4.2.0 – released on Sunday!) of Pester
Once you have installed the module you can see the commands available by running
Get-Command -Module dbachecks
To be able to use these (and any PowerShell) commands, your first step should always be Get-Help
Get-Help Send-DbcMailMessage
80 Checks
At the time of release, dbachecks has 80 checks. You can see all of the checks by running
Get-DbcCheck
(Note this has nothing to do with DBCC CheckDb!) Here is the output of
Get-DbcCheck | Select Group, UniqueTag |
so you can see the current checks
Group | UniqueTag —|— Agent | AgentServiceAccount Agent | DbaOperator Agent | FailsafeOperator Agent | DatabaseMailProfile Agent | FailedJob Database | DatabaseCollation Database | SuspectPage Database | TestLastBackup Database | TestLastBackupVerifyOnly Database | ValidDatabaseOwner Database | InvalidDatabaseOwner Database | LastGoodCheckDb Database | IdentityUsage Database | RecoveryModel Database | DuplicateIndex Database | UnusedIndex Database | DisabledIndex Database | DatabaseGrowthEvent Database | PageVerify Database | AutoClose Database | AutoShrink Database | LastFullBackup Database | LastDiffBackup Database | LastLogBackup Database | VirtualLogFile Database | LogfileCount Database | LogfileSize Database | FileGroupBalanced Database | AutoCreateStatistics Database | AutoUpdateStatistics Database | AutoUpdateStatisticsAsynchronously Database | DatafileAutoGrowthType Database | Trustworthy Database | OrphanedUser Database | PseudoSimple Database | AdHocWorkloads Domain | DomainName Domain | OrganizationalUnit HADR | ClusterHealth HADR | ClusterServerHealth HADR HADR | System.Object[] Instance | SqlEngineServiceAccount Instance | SqlBrowserServiceAccount Instance | TempDbConfiguration Instance | AdHocWorkload Instance | BackupPathAccess Instance | DAC Instance | NetworkLatency Instance | LinkedServerConnection Instance | MaxMemory Instance | OrphanedFile Instance | ServerNameMatch Instance | MemoryDump Instance | SupportedBuild Instance | SaRenamed Instance | DefaultBackupCompression Instance | XESessionStopped Instance | XESessionRunning Instance | XESessionRunningAllowed Instance | OLEAutomation Instance | WhoIsActiveInstalled LogShipping | LogShippingPrimary LogShipping | LogShippingSecondary Server | PowerPlan Server | InstanceConnection Server | SPN Server | DiskCapacity Server | PingComputer MaintenancePlan | SystemFull MaintenancePlan | UserFull MaintenancePlan | UserDiff MaintenancePlan | UserLog MaintenancePlan | CommandLog MaintenancePlan | SystemIntegrityCheck MaintenancePlan | UserIntegrityCheck MaintenancePlan | UserIndexOptimize MaintenancePlan | OutputFileCleanup MaintenancePlan | DeleteBackupHistory MaintenancePlan | PurgeJobHistory
108 Configurations
One of the things I have been talking about in my presentation “Green is Good Red is Bad” is configuring Pester checks so that you do not have to keep writing new tests for the same thing but with different values.
For example, a different user for a database owner. The code to write the test for the database owner is the same but the value might be different for different applications, environments, clients, teams, domains etc. I gave a couple of different methods for achieving this.
With dbachecks we have made this much simpler enabling you to set configuration items at run-time or for your session and enabling you to export and import them so you can create different configs for different use cases
There are 108 configuration items at present. You can see the current configuration by running
Get-DbcConfig
which will show you the name of the config, the value it is currently set and the description
You can see all of the configs and their descriptions here
Name | Description
—|—
agent.databasemailprofile | Name of the Database Mail Profile in SQL Agent
agent.dbaoperatoremail | Email address of the DBA Operator in SQL Agent
agent.dbaoperatorname | Name of the DBA Operator in SQL Agent
agent.failsafeoperator | Email address of the DBA Operator in SQL Agent
app.checkrepos | Where Pester tests/checks are stored
app.computername | List of Windows Servers that Windows-based tests will run against
app.localapp | Persisted files live here
app.maildirectory | Files for mail are stored here
app.sqlcredential | The universal SQL credential if Trusted/Windows Authentication is not used
app.sqlinstance | List of SQL Server instances that SQL-based tests will run against
app.wincredential | The universal Windows if default Windows Authentication is not used
command.invokedbccheck.excludecheck | Invoke-DbcCheck: The checks that should be skipped by default.
domain.domaincontroller | The domain controller to process your requests
domain.name | The Active Directory domain that your server is a part of
domain.organizationalunit | The OU that your server should be a part of
mail.failurethreshhold | Number of errors that must be present to generate an email report
mail.from | Email address the email reports should come from
mail.smtpserver | Store the name of the smtp server to send email reports
mail.subject | Subject line of the email report
mail.to | Email address to send the report to
policy.backup.datadir | Destination server data directory
policy.backup.defaultbackupcompreesion | Default Backup Compression check should be enabled $true or disabled $false
policy.backup.diffmaxhours | Maxmimum number of hours before Diff Backups are considered outdated
policy.backup.fullmaxdays | Maxmimum number of days before Full Backups are considered outdated
policy.backup.logdir | Destination server log directory
policy.backup.logmaxminutes | Maxmimum number of minutes before Log Backups are considered outdated
policy.backup.newdbgraceperiod | The number of hours a newly created database is allowed to not have backups
policy.backup.testserver | Destination server for backuptests
policy.build.warningwindow | The number of months prior to a build being unsupported that you want warning about
policy.connection.authscheme | Auth requirement (Kerberos, NTLM, etc)
policy.connection.pingcount | Number of times to ping a server to establish average response time
policy.connection.pingmaxms | Maximum response time in ms
policy.dacallowed | DAC should be allowed $true or disallowed $false
policy.database.autoclose | Auto Close should be allowed $true or dissalowed $false
policy.database.autocreatestatistics | Auto Create Statistics should be enabled $true or disabled $false
policy.database.autoshrink | Auto Shrink should be allowed $true or dissalowed $false
policy.database.autoupdatestatistics | Auto Update Statistics should be enabled $true or disabled $false
policy.database.autoupdatestatisticsasynchronously | Auto Update Statistics Asynchronously should be enabled $true or disabled $false
policy.database.filebalancetolerance | Percentage for Tolerance for checking for balanced files in a filegroups
policy.database.filegrowthexcludedb | Databases to exclude from the file growth check
policy.database.filegrowthtype | Growth Type should be ‘kb’ or ‘percent’
policy.database.filegrowthvalue | The auto growth value (in kb) should be equal or higher than this value. Example: A value of 65535 means at least 64MB.
policy.database.logfilecount | The number of Log files expected on a database
policy.database.logfilesizecomparison | How to compare data and log file size, options are maximum or average
policy.database.logfilesizepercentage | Maximum percentage of Data file Size that logfile is allowed to be.
policy.database.maxvlf | Max virtual log files
policy.dbcc.maxdays | Maxmimum number of days before DBCC CHECKDB is considered outdated
policy.diskspace.percentfree | Percent disk free
policy.dump.maxcount | Maximum number of expected dumps
policy.hadr.tcpport | The TCPPort for the HADR check
policy.identity.usagepercent | Maxmimum percentage of max of identity column
policy.invaliddbowner.excludedb | Databases to exclude from invalid dbowner checks
policy.invaliddbowner.name | The database owner account should not be this user
policy.network.latencymaxms | Max network latency average
policy.ola.commandlogenabled | Ola’s CommandLog Cleanup should be enabled $true or disabled $false
policy.ola.commandlogscheduled | Ola’s CommandLog Cleanup should be scheduled $true or disabled $false
policy.ola.database | The database where Ola’s maintenance solution is installed
policy.ola.deletebackuphistoryenabled | Ola’s Delete Backup History should be enabled $true or disabled $false
policy.ola.deletebackuphistoryscheduled | Ola’s Delete Backup History should be scheduled $true or disabled $false
policy.ola.installed | Checks to see if Ola Hallengren solution is installed
policy.ola.outputfilecleanupenabled | Ola’s Output File Cleanup should be enabled $true or disabled $false
policy.ola.outputfilecleanupscheduled | Ola’s Output File Cleanup should be scheduled $true or disabled $false
policy.ola.purgejobhistoryenabled | Ola’s Purge Job History should be enabled $true or disabled $false
policy.ola.purgejobhistoryscheduled | Ola’s Purge Job History should be scheduled $true or disabled $false
policy.ola.systemfullenabled | Ola’s Full System Database Backup should be enabled $true or disabled $false
policy.ola.systemfullretention | Ola’s Full System Database Backup retention number of hours
policy.ola.systemfullscheduled | Ola’s Full System Database Backup should be scheduled $true or disabled $false
policy.ola.systemintegritycheckenabled | Ola’s System Database Integrity should be enabled $true or disabled $false
policy.ola.systemintegritycheckscheduled | Ola’s System Database Integrity should be scheduled $true or disabled $false
policy.ola.userdiffenabled | Ola’s Diff User Database Backup should be enabled $true or disabled $false
policy.ola.userdiffretention | Ola’s Diff User Database Backup retention number of hours
policy.ola.userdiffscheduled | Ola’s Diff User Database Backup should be scheduled $true or disabled $false
policy.ola.userfullenabled | Ola’s Full User Database Backup should be enabled $true or disabled $false
policy.ola.userfullretention | Ola’s Full User Database Backup retention number of hours
policy.ola.userfullscheduled | Ola’s Full User Database Backup should be scheduled $true or disabled $false
policy.ola.userindexoptimizeenabled | Ola’s User Index Optimization should be enabled $true or disabled $false
policy.ola.userindexoptimizescheduled | Ola’s User Index Optimization should be scheduled $true or disabled $false
policy.ola.userintegritycheckenabled | Ola’s User Database Integrity should be enabled $true or disabled $false
policy.ola.userintegritycheckscheduled | Ola’s User Database Integrity should be scheduled $true or disabled $false
policy.ola.userlogenabled | Ola’s Log User Database Backup should be enabled $true or disabled $false
policy.ola.userlogretention | Ola’s Log User Database Backup retention number of hours
policy.ola.userlogscheduled | Ola’s Log User Database Backup should be scheduled $true or disabled $false
policy.oleautomation | OLE Automation should be enabled $true or disabled $false
policy.pageverify | Page verify option should be set to this value
policy.recoverymodel.excludedb | Databases to exclude from standard recovery model check
policy.recoverymodel.type | Standard recovery model
policy.storage.backuppath | Enables tests to check if servers have access to centralized backup location
policy.validdbowner.excludedb | Databases to exclude from valid dbowner checks
policy.validdbowner.name | The database owner account should be this user
policy.whoisactive.database | Which database should contain the sp_WhoIsActive stored procedure
policy.xevent.requiredrunningsession | List of XE Sessions that should be running.
policy.xevent.requiredstoppedsession | List of XE Sessions that should not be running.
policy.xevent.validrunningsession | List of XE Sessions that can be be running.
skip.backup.testing | Don’t run Test-DbaLastBackup by default (it’s not read-only)
skip.connection.ping | Skip the ping check for connectivity
skip.connection.remoting | Skip PowerShell remoting check for connectivity
skip.database.filegrowthdisabled | Skip validation of datafiles which have growth value equal to zero.
skip.database.logfilecounttest | Skip the logfilecount test
skip.datafilegrowthdisabled | Skip validation of datafiles which have growth value equal to zero.
skip.dbcc.datapuritycheck | Skip data purity check in last good dbcc command
skip.diffbackuptest | Skip the Differential backup test
skip.logfilecounttest | Skip the logfilecount test
skip.logshiptesting | Skip the logshipping test
skip.tempdb1118 | Don’t run test for Trace Flag 1118
skip.tempdbfilecount | Don’t run test for Temp Database File Count
skip.tempdbfilegrowthpercent | Don’t run test for Temp Database File Growth in Percent
skip.tempdbfilesizemax | Don’t run test for Temp Database Files Max Size
skip.tempdbfilesonc | Don’t run test for Temp Database Files on C
Running A Check
You can quickly run a single check by calling Invoke-DbcCheck.
Invoke-DbcCheck -SqlInstance localhost -Check FailedJob
Excellent, my agent jobs have not failed 🙂
Invoke-DbcCheck -SqlInstance localhost -Check LastGoodCheckDb
Thats good, all of my databases have had a successful DBCC CHECKDB within the last 7 days.
Setting a Configuration
To save me from having to specify the instance I want to run my tests against I can set the app.sqlinstance config to the instances I want to check.
Set-DbcConfig -Name app.sqlinstance -Value localhost, ‘localhost\PROD1’
Then whenever I call Invoke-DbcCheck it will run against those instances for the SQL checks
So now if I run
Invoke-DbcCheck -Check LastDiffBackup
I can see that I dont have a diff backup for the databases on both instances. Better stop writing this and deal with that !!
The configurations are stored in the registry but you can export them and then import them for re-use easily. I have written another blog post about that.
The Show Parameter
Getting the results of the tests on the screen is cool but if you are running a lot of tests against a lot of instances then you might find that you have 3 failed tests out of 15000! This will mean a lot of scrolling through green text looking for the red text and you may find that your PowerShell buffer doesnt hold all of your test results leaving you very frustrated.
dbachecks supports the Pester Show parameter enabling you to filter the output of the results to the screen. The available values are Summary, None, Fails, Inconclusive, Passed, Pending and Skipped
in my opinion by far the most useful one is Fails as this will show you only the failed tests with the context to enable you to see which tests have failed
Invoke-DbcCheck -Check Agent -Show Fails
If we check all of the checks tagged as Agent we can easily see that most passed but The Job That Fails (surprisingly) failed. All of the other tests that were run for the agent service, operators, failsafe operator, database mail and all other agent jobs all passed in the example below
Test Results are for other People as well
It is all very well and good being able to run tests and get the results on our screen. It will be very useful for people to be able to validate a new SQL instance for example or run a morning check or the first step of an incident response. But test results are also useful for other people so we need to be able to share them
We have created a Power Bi Dashboard that comes with the dbachecks module to enable easy sharing of the test results. You can also send the results via email using Send-DbcMailMessage. we have an open issue for putting them into a database that we would love you to help resolve.
To get the results into PowerBi you can run
Invoke-DbcCheck -AllChecks -Show Fails -PassThru | Update-DbcPowerBiDataSource -Environment Production |
This will run all of the dbachecks using your configuration for your Production environment, output only the failed tests to the screen and save the results in your windows\temp\dbachecks folder with a suffix of Production
If you then used a different configuration for your development environment and ran
Invoke-DbcCheck -AllChecks -Show Fails -PassThru | Update-DbcPowerBiDataSource -Environment Development |
it will run all of the dbachecks using your configuration for your Development environment, output only the failed tests to the screen and save the results in your windows\temp\dbachecks folder with a suffix of Development and you would end up with two files in the folder
You can then simply run
Start-DbcPowerBi
and as long as you have the (free) Powerbi Desktop then you will see this. You will need to refresh the data to get your test results
Of course it is Powerbi so you can publish this report. Here it is so that you can click around and see what it looks like
It’s Open Source – We Want Your Ideas, Issues, New Code
dbachecks is open-source available on GitHub for anyone to contribute
We would love you to contribute. Please open issues for new tests, enhancements, bugs. Please fork the repository and add code to improve the module. please give feedback to make this module even more useful
You can also come in the SQL Server Community Slack and join the dbachecks channel and get advice, make comments or just join in the conversation
Further Reading
There are many more introduction blog posts covering different areas at
Thank You
I want to say thank you to all of the people who have enabled dbachecks to get this far. These wonderful people have used their own time to ensure that you have a useful tool available to you for free
Chrissy Lemaire @cl
Fred Weinmann @FredWeinmann
Cláudio Silva @ClaudioESSilva
Stuart Moore @napalmgram
Shawn Melton @wsmelton
Garry Bargsley @gbargsley
Stephen Bennett @staggerlee011
Sander Stad @SQLStad
Jess Pomfret @jpomfret
Jason Squires @js0505
Shane O’Neill @SOZDBA
Tony Wilhelm @TonyWSQL
and all of the other people who have contributed in the dbachecks Slack channel
Comments