Go to file
2018-11-18 22:26:38 +01:00
collector Fix naming 2018-11-18 18:26:15 +01:00
docs Fix broken summary table in collector docs (#286) 2018-11-18 22:26:38 +01:00
installer Merge pull request #186 from martinlindhe/service-recovery 2018-04-06 07:19:44 +02:00
tools/collector-generator Refactor wmi query generator to use wildcard selector 2018-06-06 10:38:36 +02:00
vendor textfile collector: Skip BOM when present 2018-11-18 10:23:15 -05:00
.gitignore Bring the textfile collector over from node_exporter (#174) 2018-04-03 21:37:10 +02:00
.promu.yml Fix promu build 2017-09-08 09:38:33 +01:00
appveyor.yml appveyor: re-enable tests 2018-03-13 20:50:31 +01:00
AUTHORS.md AUTHORS.md 2016-09-19 09:06:26 +02:00
exporter_test.go Add [defaults] placeholder support to collectors.enabled 2017-03-04 12:44:47 +01:00
exporter.go fix typo in exporter.go 2018-08-05 21:39:43 -04:00
Gopkg.lock textfile collector: Skip BOM when present 2018-11-18 10:23:15 -05:00
Gopkg.toml Use dep instead of govendor 2018-03-13 20:48:33 +01:00
LICENSE add perf collector, exposing Win32_PerfRawData_PerfDisk_LogicalDisk 2016-08-26 11:08:12 +02:00
Makefile Fix promu build 2017-09-08 09:38:33 +01:00
README.md Fix broken summary table in collector docs (#286) 2018-11-18 22:26:38 +01:00

WMI exporter

Build status

Prometheus exporter for Windows machines, using the WMI (Windows Management Instrumentation).

Collectors

Name Description Enabled by default
ad Active Directory Domain Services
cpu CPU usage
cs "Computer System" metrics (system properties, num cpus/total memory)
dns DNS Server
hyperv Hyper-V hosts
iis IIS sites and applications
logical_disk Logical disks, disk I/O
net Network interface I/O
memory Memory usage metrics
msmq MSMQ queues
mssql SQL Server Performance Objects metrics
os OS metrics (memory, processes, users)
process Per-process metrics
service Service state metrics
system System calls
tcp TCP connections
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 WMI 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

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

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

Roadmap

See open issues

Usage

go get -u github.com/golang/dep
go get -u github.com/prometheus/promu
go get -u github.com/martinlindhe/wmi_exporter
cd $env:GOPATH/src/github.com/martinlindhe/wmi_exporter
promu build -v .
.\wmi_exporter.exe

The prometheus metrics will be exposed on localhost:9182

Examples

Enable only service collector and specify a custom query

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

Enable only process collector and specify a custom query

.\wmi_exporter.exe --collectors.enabled "process" --collector.process.processes-where "Name LIKE '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 query needs to be a wildcard search using a % character.

Please note that in Windows batch scripts (and when using the cmd command prompt), the % character is reserved, so it has to be escaped with another %. For example, the wildcard syntax for searching for all firefox processes is firefox%%.

License

Under MIT