Main | Contact | Blog | Documentation

PowerShell Framework

The project dedicated to empowering your PowerShell scripting.

Logging to: SQL

Back to: Logging

Setting up logging

Installation

This logging provider requires an installation step: It uses/depends upon the PowerShell module dbatools.

To provide this module, you can run the following line:

Install-PSFLoggingProvider -Name sql

Start Logging

This command will configure the logging:

$paramSetPSFLoggingProvider = @{
    Name         = 'sql'
    InstanceName = 'MyTask'
    SqlServer    = 'server.fqdn.com'
    Database     = 'LoggingDB'
    Table        = 'Logs'
    Enabled      = $true
    Wait         = $true
}
Set-PSFLoggingProvider @paramSetPSFLoggingProvider

Note: The logging provider will try to create database and table if needed.

Logging with credentials

The previous example would use windows authentication as the current user. If you want to use explicit credentials - SQL or Windows - offer them as a credential object:

$paramSetPSFLoggingProvider = @{
    Name         = 'sql'
    InstanceName = 'MyTask'
    SqlServer    = 'Server = server.fqdn.com;'
    Database     = 'LoggingDB'
    Table        = 'Logs'
    Credential   = $cred
    Enabled      = $true
    Wait         = $true
}
Set-PSFLoggingProvider @paramSetPSFLoggingProvider

Reusing an existing session

The following shows how you can reuse a custom session:

$connection = Connect-DbaInstance -SqlInstance computername\instance # Add whatever other authentication and options
$paramSetPSFLoggingProvider = @{
    Name         = 'sql'
    InstanceName = 'MyTask'
    SqlServer    = $connection
    Database     = 'LoggingDB'
    Table        = 'Logs'
    Enabled      = $true
    Wait         = $true
}
Set-PSFLoggingProvider @paramSetPSFLoggingProvider

WARNING: It is not possible to use one session in parallel in different runspaces. If you also use the session in another runspace, concurrent use will cause errors, risking the loss of logs and failure of script!

Generating Messages

You can write messages using the Write-PSFMessage cmdlet, which functionally replaces Write-Verbose, Write-Host, Write-Warning, Write-Debug or Write-Log:

# Verbose
Write-PSFMessage -Message "Test Message"

# Host
Write-PSFMessage -Level Host -Message "Message visible to the user"

# Debug
Write-PSFMessage -Level Debug -Message "Very well hidden message"

# Warning
Write-PSFMessage -Level Warning -Message "Warning Message"

You can also add tags for better filtering:

Write-PSFMessage -Message "Tagged Message" -Tag special, custom, whatever

Specify the target you are working against to better track actions relating to that specific target:

Write-PSFMessage -Message "Doing something" -Target $ComputerName

For more details on how to generate messages, see the dedicated documentation page

Logging Provider Documentation

For more detailed docs, see the full documentation for the sql logging provider

Back to: Logging