﻿---
title: Running Logstash on Windows
description: Before reading this section, see Installing Logstash to get started.  You also need to be familiar with Running Logstash from the Command Line as command...
url: https://www.elastic.co/elastic/docs-builder/docs/3016/reference/logstash/running-logstash-windows
products:
  - Logstash
applies_to:
  - Elastic Cloud Serverless: Generally available
  - Elastic Stack: Generally available
---

# Running Logstash on Windows
Before reading this section, see [Installing Logstash](https://www.elastic.co/elastic/docs-builder/docs/3016/reference/logstash/installing-logstash) to get started.  You also need to be familiar with [Running Logstash from the Command Line](https://www.elastic.co/elastic/docs-builder/docs/3016/reference/logstash/running-logstash-command-line) as command line options are used to test running Logstash on Windows.
<important>
  Specifying command line options is useful when you are testing Logstash. However, in a production environment, we recommend that you use [logstash.yml](https://www.elastic.co/elastic/docs-builder/docs/3016/reference/logstash/logstash-settings-file) to control Logstash execution. Using the settings file makes it easier for you to specify multiple options, and it provides you with a single, versionable file that you can use to start up Logstash consistently for each run.
</important>

Logstash is not started automatically after installation. How to start and stop Logstash on Windows depends on whether you want to run it manually, as a service (with [NSSM](https://nssm.cc/)), or run it as a scheduled task. This guide provides an example of some of the ways Logstash can run on Windows.
<note>
  It is recommended to validate your configuration works by running Logstash manually before running Logstash as a service or a scheduled task.
</note>


## Validating JVM prerequisites on Windows

After installing a [supported JVM](https://www.elastic.co/support/matrix#matrix_jvm), open a [PowerShell](https://docs.microsoft.com/en-us/powershell/) session and run the following commands to verify `LS_JAVA_HOME` is set and the Java version:

### `Write-Host $env:LS_JAVA_HOME`

- The output should be pointed to where the JVM software is located, for example:
  ```sh
  PS C:\> Write-Host $env:LS_JAVA_HOME
  C:\Program Files\Java\jdk-11.0.3
  ```
- If `LS_JAVA_HOME` is not set, perform one of the following:
  - Set using the GUI:
  - Navigate to the Windows [Environmental Variables](https://docs.microsoft.com/en-us/windows/win32/procthread/environment-variables) window
- In the Environmental Variables window, edit LS_JAVA_HOME to point to where the JDK software is located, for example: `C:\Program Files\Java\jdk-11.0.3`
- Set using PowerShell:
  - In an Administrative PowerShell session, execute the following [SETX](https://docs.microsoft.com/en-us/windows-server/administration/windows-commands/setx) commands:
  ```sh
  PS C:\Windows\system32> SETX /m LS_JAVA_HOME "C:\Program Files\Java\jdk-11.0.3"
  PS C:\Windows\system32> SETX /m PATH "$env:PATH;C:\Program Files\Java\jdk-11.0.3\bin;"
  ```
- Exit PowerShell, then open a new PowerShell session and run `Write-Host $env:LS_JAVA_HOME` to verify


### `Java -version`

- This command produces output similar to the following:
  ```sh
  PS C:\> Java -version
  java version "11.0.3" 2019-04-16 LTS
  Java(TM) SE Runtime Environment 18.9 (build 11.0.3+12-LTS)
  Java HotSpot(TM) 64-Bit Server VM 18.9 (build 11.0.3+12-LTS, mixed mode)
  ```

Once you have [*Setting Up and Running Logstash*](https://www.elastic.co/elastic/docs-builder/docs/3016/reference/logstash/setting-up-running-logstash) and validated JVM pre-requisites, you may proceed.
<note>
  For the examples listed below, we are running Windows Server 2016, Java 11.0.3, have extracted the [Logstash ZIP package](https://www.elastic.co/downloads/logstash) to `C:\logstash-9.0.0\`, and using the example `syslog.conf` file shown below (stored in `C:\logstash-9.0.0\config\`).
</note>


## Running Logstash manually

Logstash can be run manually using [PowerShell](https://docs.microsoft.com/en-us/powershell/).  Open an Administrative [PowerShell](https://docs.microsoft.com/en-us/powershell/) session, then run the following commands:
```sh
PS C:\Windows\system32> cd C:\logstash-9.0.0\
PS C:\logstash-9.0.0> .\bin\logstash.bat -f .\config\syslog.conf
```

<note>
  In a production environment, we recommend that you use [logstash.yml](https://www.elastic.co/elastic/docs-builder/docs/3016/reference/logstash/logstash-settings-file) to control Logstash execution.
</note>

Wait for the following messages to appear, to confirm Logstash has started successfully:
```sh
[logstash.runner          ] Starting Logstash {"logstash.version"=>"9.0.0"}
[logstash.inputs.udp      ] Starting UDP listener {:address=>"0.0.0.0:514"}
[logstash.agent           ] Successfully started Logstash API endpoint {:port=>9600}
```


## Running Logstash as a service with NSSM

<note>
  It is recommended to validate your configuration works by running Logstash manually before you proceed.
</note>

Download [NSSM](https://nssm.cc/), then extract `nssm.exe` from `nssm-<version.number>\win64\nssm.exe` to `C:\logstash-9.0.0\bin\`. Then open an Administrative [PowerShell](https://docs.microsoft.com/en-us/powershell/) session, then run the following commands:
```sh
PS C:\Windows\system32> cd C:\logstash-9.0.0\
PS C:\logstash-9.0.0> .\bin\nssm.exe install logstash
```

Once the `NSSM service installer` window appears, specify the following parameters in the `Application` tab:
- In the `Application` tab:
  - Path: Path to `logstash.bat`: `C:\logstash-9.0.0\bin\logstash.bat`
- Startup Directory: Path to the `bin` directory: `C:\logstash-9.0.0\bin`
- Arguments: For this example to start Logstash: `-f C:\logstash-9.0.0\config\syslog.conf`
  <note>
  In a production environment, we recommend that you use [logstash.yml](https://www.elastic.co/elastic/docs-builder/docs/3016/reference/logstash/logstash-settings-file) to control Logstash execution.
  </note>
- Review and make any changes necessary in the `Details` tab:
  - Ensure `Startup Type` is set appropriately
- Set the `Display name` and `Description` fields to something relevant
- Review any other required settings (for the example we aren’t making any other changes)
  - Be sure to determine if you need to set the `Log on` user
- Validate the `Service name` is set appropriately
  - For this example, we will set ours to `logstash-syslog`
- Click `Install Service`
  - Click *OK* when the `Service "logstash-syslog" installed successfully!` window appears

Once the service has been installed with NSSM, validate and start the service following the [PowerShell Managing Services](https://docs.microsoft.com/en-us/powershell/scripting/samples/managing-services) documentation.

## Running Logstash with Task Scheduler

<note>
  It is recommended to validate your configuration works by running Logstash manually before you proceed.
</note>

Open the Windows [Task Scheduler](https://docs.microsoft.com/en-us/windows/desktop/taskschd/task-scheduler-start-page), then click `Create Task` in the Actions window.  Specify the following parameters in the `Actions` tab:
- In the `Actions` tab:
  - Click `New`, then specify the following:
- Action: `Start a program`
- Program/script: `C:\logstash-9.0.0\bin\logstash.bat`
- Add arguments: `-f C:\logstash-9.0.0\config\syslog.conf`
- Start in: `C:\logstash-9.0.0\bin\`
  <note>
  In a production environment, we recommend that you use [logstash.yml](https://www.elastic.co/elastic/docs-builder/docs/3016/reference/logstash/logstash-settings-file) to control Logstash execution.
  </note>
- Review and make any changes necessary in the `General`, `Triggers`, `Conditions`, and `Settings` tabs.
- Click `OK` to finish creating the scheduled task.
- Once the new task has been created, either wait for it to run on the schedule or select the service then click `Run` to start the task.

<note>
  Logstash can be stopped by selecting the service, then clicking `End` in the Task Scheduler window.
</note>


## Example Logstash Configuration

We will configure Logstash to listen for syslog messages over port 514 with this configuration (file name is `syslog.conf`):
```yaml
# Sample Logstash configuration for receiving
# UDP syslog messages over port 514

input {
  udp {
    port => 514
    type => "syslog"
  }
}

output {
  elasticsearch { hosts => ["localhost:9200"] }
  stdout { codec => rubydebug }
}
```