Go to file
Calle Pettersson 5c7c0aaa69
Apply suggestions from code review
Signed-off-by: Calle Pettersson <calle@cape.nu>
2020-06-28 12:19:43 +02:00
collector Revert fsrm struct removal 2020-06-07 17:58:14 +02:00
contrib/console_templates Update console_template metrics 2020-05-24 20:54:35 +02:00
docs Apply suggestions from code review 2020-06-28 12:19:43 +02:00
installer Update CI and installer 2020-05-24 20:54:35 +02:00
tools/collector-generator Merge pull request #500 from martinlindhe/update-template 2020-05-24 20:03:44 +02:00
.gitignore Merge branch 'master' into features/sql-transactions-collector 2019-08-04 15:50:20 +03:00
.golangci.yaml Switch to go modules 2019-12-28 16:28:10 +01:00
.promu.yml Update CI and installer 2020-05-24 20:54:35 +02:00
appveyor.yml Update AppVeyor configuration 2020-06-02 15:17:56 +02:00
CODE_OF_CONDUCT.md Update common Prometheus files 2020-06-23 00:12:11 +00:00
exporter_test.go Adding windows build constraints 2018-11-29 19:51:12 -05:00
exporter.go Add endpoint for getting the version of the binary (#555) 2020-06-23 12:48:19 +02:00
go.mod Update module name 2020-05-24 20:54:35 +02:00
go.sum Adds MS Exchange collector (#508) 2020-05-24 18:05:27 +02:00
LICENSE add perf collector, exposing Win32_PerfRawData_PerfDisk_LogicalDisk 2016-08-26 11:08:12 +02:00
MAINTAINERS.md Update maintainers 2020-06-01 11:36:54 +02:00
Makefile Switch to go modules 2019-12-28 16:28:10 +01:00
README.md Add Collector for Microsoft FileSystem Resource Manager Quotas (#437) 2020-06-07 17:40:55 +02:00

windows_exporter

Build status

A Prometheus exporter for Windows machines.

Collectors

Name Description Enabled by default
ad Active Directory Domain Services
adfs Active Directory Federation Services
cpu CPU usage
cs "Computer System" metrics (system properties, num cpus/total memory)
container Container metrics
dns DNS Server
exchange Exchange metrics
fsrmquota Microsoft File Server Resource Manager (FSRM) Quotas collector
hyperv Hyper-V hosts
iis IIS sites and applications
logical_disk Logical disks, disk I/O
logon User logon sessions
memory Memory usage metrics
msmq MSMQ queues
mssql SQL Server Performance Objects metrics
netframework_clrexceptions .NET Framework CLR Exceptions
netframework_clrinterop .NET Framework Interop Metrics
netframework_clrjit .NET Framework JIT metrics
netframework_clrloading .NET Framework CLR Loading metrics
netframework_clrlocksandthreads .NET Framework locks and metrics threads
netframework_clrmemory .NET Framework Memory metrics
netframework_clrremoting .NET Framework Remoting metrics
netframework_clrsecurity .NET Framework Security Check metrics
net Network interface I/O
os OS metrics (memory, processes, users)
process Per-process metrics
remote_fx RemoteFX protocol (RDP) metrics
service Service state metrics
system System calls
tcp TCP connections
thermalzone Thermal information
terminal_services Terminal services (RDS)
textfile Read prometheus metrics from a text file
vmware Performance counters installed by the Vmware Guest agent

See the linked documentation on each collector for more information on reported metrics, configuration settings and usage examples.

Installation

The latest release can be downloaded from the releases page.

Each release provides a .msi installer. The installer will setup the windows_exporter as a Windows service, as well as create an exception in the Windows Firewall.

If the installer is run without any parameters, the exporter will run with default settings for enabled collectors, ports, etc. The following parameters are available:

Name Description
ENABLED_COLLECTORS As the --collectors.enabled flag, provide a comma-separated list of enabled collectors
LISTEN_ADDR The IP address to bind to. Defaults to 0.0.0.0
LISTEN_PORT The port to bind to. Defaults to 9182.
METRICS_PATH The path at which to serve metrics. Defaults to /metrics
TEXTFILE_DIR As the --collector.textfile.directory flag, provide a directory to read text files with metrics from
EXTRA_FLAGS Allows passing full CLI flags. Defaults to an empty string.

Parameters are sent to the installer via msiexec. Example invocations:

msiexec /i <path-to-msi-file> ENABLED_COLLECTORS=os,iis LISTEN_PORT=5000

Example service collector with a custom query.

msiexec /i <path-to-msi-file> ENABLED_COLLECTORS=os,service --% EXTRA_FLAGS="--collector.service.services-where ""Name LIKE 'sql%'"""

On some older versions of Windows you may need to surround parameter values with double quotes to get the install command parsing properly:

msiexec /i C:\Users\Administrator\Downloads\windows_exporter.msi ENABLED_COLLECTORS="ad,iis,logon,memory,process,tcp,thermalzone" TEXTFILE_DIR="C:\custom_metrics\"

Roadmap

See open issues

Usage

go get -u github.com/prometheus/promu
go get -u github.com/prometheus-community/windows_exporter
cd $env:GOPATH/src/github.com/prometheus-community/windows_exporter
promu build -v .
.\windows_exporter.exe

The prometheus metrics will be exposed on localhost:9182

Examples

Enable only service collector and specify a custom query

.\windows_exporter.exe --collectors.enabled "service" --collector.service.services-where "Name='windows_exporter'"

Enable only process collector and specify a custom query

.\windows_exporter.exe --collectors.enabled "process" --collector.process.whitelist="firefox.+"

When there are multiple processes with the same name, WMI represents those after the first instance as process-name#index. So to get them all, rather than just the first one, the regular expression must use .+. See process for more information.

License

Under MIT