How to Enable Minidumps on Windows using PowerShell

The practice of debugging and troubleshooting computer systems often calls for specialized tools and scripts. One such method, crucial to many IT experts, is the utilization of minidump files. These files offer a snapshot of active memory when a computer crashes, providing invaluable data for post-crash analysis. This article examines a PowerShell script designed to automate the enabling of minidumps on Windows systems.

Background

For IT professionals and Managed Service Providers (MSPs), the ability to capture and analyze crash data is vital. Doing so helps them understand why a system crashed and prevent future occurrences. Minidump files, in particular, provide just enough data without consuming extensive disk space, making them a preferred choice for many experts. However, manually setting up minidump generation can be tedious, which is where automation comes in. By using scripts such as the one we’re delving into, professionals can efficiently set up their systems to generate minidumps when required.

The Script

<#
.SYNOPSIS
    Turn on mini dumps if they are off, if other dumps are already enabled do not change the configuration.
.DESCRIPTION
    Turn on mini dumps if they are off, if other dumps are already enabled do not change the configuration.
    This will enable the creation of the pagefile, but set to automatically manage by Windows.
    Reboot might be needed.
.OUTPUTS
    None
.NOTES
    Minimum OS Architecture Supported: Windows 10, Windows Server 2016
    Release Notes:
    Initial Release
By using this script, you indicate your acceptance of the following legal terms as well as our Terms of Use at https://www.ninjaone.com/terms-of-use.
    Ownership Rights: NinjaOne owns and will continue to own all right, title, and interest in and to the script (including the copyright). NinjaOne is giving you a limited license to use the script in accordance with these legal terms. 
    Use Limitation: You may only use the script for your legitimate personal or internal business purposes, and you may not share the script with another party. 
    Republication Prohibition: Under no circumstances are you permitted to re-publish the script in any script library or website belonging to or under the control of any other software provider. 
    Warranty Disclaimer: The script is provided “as is” and “as available”, without warranty of any kind. NinjaOne makes no promise or guarantee that the script will be free from defects or that it will meet your specific needs or expectations. 
    Assumption of Risk: Your use of the script is at your own risk. You acknowledge that there are certain inherent risks in using the script, and you understand and assume each of those risks. 
    Waiver and Release: You will not hold NinjaOne responsible for any adverse or unintended consequences resulting from your use of the script, and you waive any legal or equitable rights or remedies you may have against NinjaOne relating to your use of the script. 
    EULA: If you are a NinjaOne customer, your use of the script is subject to the End User License Agreement applicable to you (EULA).
#>
[CmdletBinding()]
param ()

begin {
    function Set-ItemProp {
        param (
            $Path,
            $Name,
            $Value,
            [ValidateSet("DWord", "QWord", "String", "ExpandedString", "Binary", "MultiString", "Unknown")]
            $PropertyType = "DWord"
        )
        # Do not output errors and continue
        $ErrorActionPreference = [System.Management.Automation.ActionPreference]::SilentlyContinue
        if (-not $(Test-Path -Path $Path)) {
            # Check if path does not exist and create the path
            New-Item -Path $Path -Force | Out-Null
        }
        if ((Get-ItemProperty -Path $Path -Name $Name)) {
            # Update property and print out what it was changed from and changed to
            $CurrentValue = Get-ItemProperty -Path $Path -Name $Name
            try {
                Set-ItemProperty -Path $Path -Name $Name -Value $Value -Force -Confirm:$false -ErrorAction Stop | Out-Null
            }
            catch {
                Write-Error $_
            }
            Write-Host "$Path$Name changed from $CurrentValue to $(Get-ItemProperty -Path $Path -Name $Name)"
        }
        else {
            # Create property with value
            try {
                New-ItemProperty -Path $Path -Name $Name -Value $Value -PropertyType $PropertyType -Force -Confirm:$false -ErrorAction Stop | Out-Null
            }
            catch {
                Write-Error $_
            }
            Write-Host "Set $Path$Name to $(Get-ItemProperty -Path $Path -Name $Name)"
        }
        $ErrorActionPreference = [System.Management.Automation.ActionPreference]::Continue
    }
    function Test-IsElevated {
        $id = [System.Security.Principal.WindowsIdentity]::GetCurrent()
        $p = New-Object System.Security.Principal.WindowsPrincipal($id)
        $p.IsInRole([System.Security.Principal.WindowsBuiltInRole]::Administrator)
    }
}
process {
    if (-not (Test-IsElevated)) {
        Write-Error -Message "Access Denied. Please run with Administrator privileges."
        exit 1
    }

    # Reference: https://learn.microsoft.com/en-US/troubleshoot/windows-server/performance/memory-dump-file-options
    $Path = "HKLM:SystemCurrentControlSetControlCrashControl"
    $Name = "CrashDumpEnabled"
    $CurrentValue = Get-ItemPropertyValue -Path $Path -Name $Name -ErrorAction SilentlyContinue
    $Value = 3

    # If CrashDumpEnabled is set to 0 or doesn't exist then enable mini crash dump
    if ($CurrentValue -eq 0 -and $null -ne $CurrentValue) {
        $PageFile = Get-ItemPropertyValue -Path "HKLM:SYSTEMCurrentControlSetControlSession ManagerMemory Management" -Name PagingFiles -ErrorAction SilentlyContinue
        if (-not $PageFile) {
            # If the pagefile was not setup, create the registry entry needed to create the pagefile
            try {
                # Enable automatic page management file if disabled to allow mini dump to function
                Set-ItemProp -Path "HKLM:SYSTEMCurrentControlSetControlSession ManagerMemory Management" -Name PagingFiles -Value "?:pagefile.sys" -PropertyType MultiString
            }
            catch {
                Write-Error "Could not create pagefile."
                exit 1
            }
        }
        Set-ItemProp -Path $Path -Name $Name -Value 3
        Write-Host "Reboot might be needed to enable mini crash dump."
    }
    else {
        Write-Host "Crash dumps are already enabled."
    }
    exit 0
}
end {}

 

Access 300+ scripts in the NinjaOne Dojo

Get Access

Detailed Breakdown

The PowerShell script in focus begins by checking if the system has administrator privileges. This is crucial because changes to the system registry, as intended by this script, require such permissions.

The main registry path of interest is HKLM:SystemCurrentControlSetControlCrashControl. Within this path, there’s a specific registry key, CrashDumpEnabled, that governs the state of crash dump generation.

If this key is set to 0 or doesn’t exist, it indicates that crash dumps are not enabled. The script will then take steps to turn on minidump creation. Additionally, the script checks for the presence of a pagefile and establishes one if missing since it’s a prerequisite for creating minidumps.

Potential Use Cases

Consider an IT professional, Bob, working in a mid-sized organization. Following several unexplained system crashes, Bob is under pressure to figure out the root cause. Instead of going machine by machine, Bob deploys this script across all computers in the organization. This proactive approach ensures that the next time a crash occurs, Bob will have a minidump file ready for analysis. Good job, Bob!

Alternative Approach

Traditionally, enabling minidump generation involves navigating multiple Windows menus or manually editing the registry—both time-consuming and error-prone tasks. This script stands out by automating the process, thus reducing the chance of human error and ensuring a consistent setup across multiple machines.

FAQs

  • What are the prerequisites for using this script?
    The script supports Windows 10 and Windows Server 2016 or newer.
  • Is a restart necessary after running the script?
    A reboot might be needed to finalize the enabling of mini-crash dumps.
  • What if my system already has crash dumps enabled?
    The script will recognize this and refrain from making changes.

Implications

Enabling minidump generation is a double-edged sword. While it offers valuable data for debugging, it might contain sensitive information. IT professionals should consider encrypting these files or ensuring they’re stored in secure locations.

Recommendations

  • Always test the script in a controlled environment before deploying.
  • Regularly review and clear minidump files to save disk space and maintain privacy.

Final Thoughts

Incorporating automated solutions, such as the script discussed, simplifies IT management tasks. Platforms like NinjaOne further augment this by offering centralized control and a suite of tools tailored to IT professionals’ needs, ensuring systems remain optimized and secure.

Next Steps

Building an efficient and effective IT team requires a centralized solution that acts as your core service deliver tool. NinjaOne enables IT teams to monitor, manage, secure, and support all their devices, wherever they are, without the need for complex on-premises infrastructure.

Learn more about NinjaOne Remote Script Deployment, check out a live tour, or start your free trial of the NinjaOne platform.

Categories:

You might also like

Leveraging PowerShell to Enable or Disable System Restore on Windows Systems

Securing SSH Access by Disabling PermitEmptyPasswords with a Bash Script 

Identifying and Managing Orphaned User Accounts in Windows Using PowerShell

Adding or Overriding Device Antivirus Information with macOS Bash Script 

IT Guide: Customizing Antivirus Overrides with a Bash Script in Linux 

Adding and Managing Antivirus Overrides with PowerShell 

×

See NinjaOne in action!

By submitting this form, I accept NinjaOne's privacy policy.

NinjaOne Terms & Conditions

By clicking the “I Accept” button below, you indicate your acceptance of the following legal terms as well as our Terms of Use:

  • Ownership Rights: NinjaOne owns and will continue to own all right, title, and interest in and to the script (including the copyright). NinjaOne is giving you a limited license to use the script in accordance with these legal terms.
  • Use Limitation: You may only use the script for your legitimate personal or internal business purposes, and you may not share the script with another party.
  • Republication Prohibition: Under no circumstances are you permitted to re-publish the script in any script library belonging to or under the control of any other software provider.
  • Warranty Disclaimer: The script is provided “as is” and “as available”, without warranty of any kind. NinjaOne makes no promise or guarantee that the script will be free from defects or that it will meet your specific needs or expectations.
  • Assumption of Risk: Your use of the script is at your own risk. You acknowledge that there are certain inherent risks in using the script, and you understand and assume each of those risks.
  • Waiver and Release: You will not hold NinjaOne responsible for any adverse or unintended consequences resulting from your use of the script, and you waive any legal or equitable rights or remedies you may have against NinjaOne relating to your use of the script.
  • EULA: If you are a NinjaOne customer, your use of the script is subject to the End User License Agreement applicable to you (EULA).