PowerShell Commands

Write-EventLog

Write-EventLog [-LogName*] <String> [-Source*] <String> [-EventId*] <Int32> [[-EntryType] {Error | Information |FailureAudit | SuccessAudit | Warning}] [-Message*] <String> [-Category <Int16>] [-ComputerName <String>] [-RawData<Byte[]>] [<CommonParameters>]

The Write-EventLog cmdlet writes an event to an event log.

To write an event to an event log, the event log must exist on the computer and the source must be registered for the event log.

The cmdlets that contain the EventLog noun (the EventLog cmdlets) work only on classic event logs. To get events from logs that use the Windows Event Log technology in Windows Vista and later versions of the Windows operating system, use the Get-WinEvent cmdlet.

Parameters

-Category <Int16>

  • Default value is None
  • Accepts pipeline input False

Specifies a task category for the event. Enter an integer that is associated with the strings in the category message file for the event log.

-ComputerName <String>

  • Default value is None
  • Accepts pipeline input False

Specifies a remote computer. The default is the local computer.

Type the NetBIOS name, an IP address, or a fully qualified domain name of a remote computer.

This parameter does not rely on Windows PowerShell remoting. You can use the ComputerName parameter of the Get-EventLog cmdlet even if your computer is not configured to run remote commands.

-EntryType <EventLogEntryType>

  • Default value is None
  • Accepts pipeline input False

Specifies the entry type of the event. The acceptable values for this parameter are: Error, Warning, Information, SuccessAudit, and FailureAudit. The default value is Information.

For a description of the values, see System.Diagnostics.EventLogEntryTypehttp://go.microsoft.com/fwlink/?LinkId=143599 (http://go.microsoft.com/fwlink/?LinkId=143599) in the Microsoft Developer Network (MSDN) library.

-EventId <Int32>

  • This value is required
  • Default value is None
  • Accepts pipeline input False

Specifies the event identifier. This parameter is required. The maximum value for the EventId parameter is 65535.

-LogName <String>

  • This value is required
  • Default value is None
  • Accepts pipeline input False

Specifies the name of the log to which the event is written. Enter the log name. The log name is the value of the Log property, not the LogDisplayName . Wildcard characters are not permitted. This parameter is required.

-Message <String>

  • This value is required
  • Default value is None
  • Accepts pipeline input False

Specifies the event message. This parameter is required.

-RawData <Byte[]>

  • Default value is None
  • Accepts pipeline input False

Specifies the binary data that is associated with the event, in bytes.

-Source <String>

  • This value is required
  • Default value is None
  • Accepts pipeline input False

Specifies the event source, which is typically the name of the application that is writing the event to the log.

<CommonParameters>

This cmdlet supports the common parameters: Verbose, Debug,ErrorAction, ErrorVariable, WarningAction, WarningVariable,OutBuffer, PipelineVariable, and OutVariable.

Inputs
None
You cannot pipe input to this cmdlet.
Outputs
System.Diagnostics.EventLogEntry
This cmdlet returns objects that represents the events in the logs.
Examples
  1. Write an event to the Application event log:
    PS C:\> Write-EventLog -LogName "Application" -Source "MyApp" -EventID 3001 -EntryType Information -Message "MyApp added a user-requested feature to the display." -Category 1 -RawData 10,20
    

    This command writes an event from the MyApp source to the Application event log.

  2. Write an event to the Application event log of a remote computer:
    PS C:\> Write-EventLog -ComputerName "Server01" -LogName Application -Source "MyApp" -EventID 3001 -Message "MyApp added a user-requested feature to the display."
    

    This command writes an event from the MyApp source to the Application event log on the Server01 remote computer.

Additional Notes
 To use Write-EventLog *, start Windows PowerShell by using the Run as administrator option.

 *

This work is licensed under a Creative Commons Attribution 4.0 International. It is attributed to Microsoft Corporation and can be found here.

PowerShell Commands