2016-08-26 09:08:12 +00:00
# WMI exporter
2016-08-27 10:59:57 +00:00
[![Build status ](https://ci.appveyor.com/api/projects/status/ljwan71as6pf2joe?svg=true )](https://ci.appveyor.com/project/martinlindhe/wmi-exporter)
2016-08-26 09:08:12 +00:00
Prometheus exporter for Windows machines, using the WMI (Windows Management Instrumentation).
## Collectors
2016-10-14 08:19:57 +00:00
Name | Description | Enabled by default
---------|-------------|--------------------
2018-08-02 06:42:02 +00:00
ad | [Win32_PerfRawData_DirectoryServices_DirectoryServices ](https://msdn.microsoft.com/en-us/library/ms803980.aspx ) Active Directory |
2016-10-14 08:19:57 +00:00
cpu | [Win32_PerfRawData_PerfOS_Processor ](https://msdn.microsoft.com/en-us/library/aa394317(v=vs.90 ).aspx) metrics (cpu usage) | ✓
cs | [Win32_ComputerSystem ](https://msdn.microsoft.com/en-us/library/aa394102 ) metrics (system properties, num cpus/total memory) | ✓
2016-11-14 19:34:48 +00:00
dns | [Win32_PerfRawData_DNS_DNS ](https://technet.microsoft.com/en-us/library/cc977686.aspx ) metrics (DNS Server) |
2018-08-02 06:42:02 +00:00
hyperv | Performance counters for Hyper-V hosts |
2016-10-14 08:19:57 +00:00
iis | [Win32_PerfRawData_W3SVC_WebService ](https://msdn.microsoft.com/en-us/library/aa394345 ) IIS metrics |
logical_disk | [Win32_PerfRawData_PerfDisk_LogicalDisk ](https://msdn.microsoft.com/en-us/windows/hardware/aa394307(v=vs.71 )) metrics (disk I/O) | ✓
net | [Win32_PerfRawData_Tcpip_NetworkInterface ](https://technet.microsoft.com/en-us/security/aa394340(v=vs.80 )) metrics (network interface I/O) | ✓
2018-08-02 06:42:02 +00:00
msmq | [Win32_PerfRawData_MSMQ_MSMQQueue ](http://wutils.com/wmi/root/cimv2/win32_perfrawdata_msmq_msmqqueue/ ) metrics (MSMQ/journal count) |
mssql | various [SQL Server Performance Objects ](https://docs.microsoft.com/en-us/sql/relational-databases/performance-monitor/use-sql-server-objects#SQLServerPOs ) metrics |
2016-10-14 08:19:57 +00:00
os | [Win32_OperatingSystem ](https://msdn.microsoft.com/en-us/library/aa394239 ) metrics (memory, processes, users) | ✓
2017-07-16 08:49:42 +00:00
process | [Win32_PerfRawData_PerfProc_Process ](https://msdn.microsoft.com/en-us/library/aa394323(v=vs.85 ).aspx) metrics (per-process stats) |
2017-03-03 13:51:24 +00:00
service | [Win32_Service ](https://msdn.microsoft.com/en-us/library/aa394418(v=vs.85 ).aspx) metrics (service states) | ✓
2016-10-14 08:19:57 +00:00
system | Win32_PerfRawData_PerfOS_System metrics (system calls) | ✓
2017-12-20 13:26:30 +00:00
tcp | [Win32_PerfRawData_Tcpip_TCPv4 ](https://msdn.microsoft.com/en-us/library/aa394341(v=vs.85 ).aspx) metrics (tcp connections) |
2018-04-03 19:37:10 +00:00
textfile | Read prometheus metrics from a text file | ✓
2017-06-10 11:59:40 +00:00
vmware | Performance counters installed by the Vmware Guest agent |
2016-08-26 13:06:10 +00:00
The HELP texts shows the WMI data source, please see MSDN documentation for details.
2016-08-26 09:08:12 +00:00
2016-09-16 06:36:58 +00:00
## Installation
2017-05-22 17:17:31 +00:00
The latest release can be downloaded from the [releases page ](https://github.com/martinlindhe/wmi_exporter/releases ).
2016-09-16 06:36:58 +00:00
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
-----|------------
2017-08-12 06:56:09 +00:00
`ENABLED_COLLECTORS` | As the `--collectors.enabled` flag, provide a comma-separated list of enabled collectors
2016-09-16 06:36:58 +00:00
`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`
2018-04-03 19:37:10 +00:00
`TEXTFILE_DIR` | As the `--collector.textfile.directory` flag, provide a directory to read text files with metrics from
2016-09-16 06:36:58 +00:00
Parameters are sent to the installer via `msiexec` . Example invocation:
```powershell
msiexec /i < path-to-msi-file > ENABLED_COLLECTORS=os,iis LISTEN_PORT=5000
```
2016-08-26 09:08:12 +00:00
2016-08-26 10:53:22 +00:00
## Roadmap
2016-08-26 09:35:31 +00:00
2016-10-14 12:32:11 +00:00
See [open issues ](https://github.com/martinlindhe/wmi_exporter/issues )
2016-08-26 09:35:31 +00:00
2016-08-26 13:06:10 +00:00
2016-08-27 09:39:21 +00:00
## Usage
2018-03-13 17:04:49 +00:00
go get -u github.com/golang/dep
2017-08-10 00:14:06 +00:00
go get -u github.com/prometheus/promu
2016-08-27 09:39:21 +00:00
go get -u github.com/martinlindhe/wmi_exporter
cd $env:GOPATH/src/github.com/martinlindhe/wmi_exporter
2017-08-10 00:14:06 +00:00
promu build -v .
2016-08-27 09:39:21 +00:00
.\wmi_exporter.exe
2016-08-27 12:49:34 +00:00
The prometheus metrics will be exposed on [localhost:9182 ](http://localhost:9182 )
2016-08-27 09:39:21 +00:00
2017-08-10 22:31:39 +00:00
## Examples
### Enable only service collector and specify a custom query
2017-08-12 06:56:09 +00:00
.\wmi_exporter.exe --collectors.enabled "service" --collector.service.services-where "Name='wmi_exporter'"
2017-08-10 00:07:52 +00:00
### Enable only process collector and specify a custom query
2017-08-12 06:56:09 +00:00
.\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.
2017-08-10 00:07:52 +00:00
2016-08-26 09:08:12 +00:00
## License
Under [MIT ](LICENSE )