# Microsoft Exchange Server 2016 by Zabbix agent ## Overview Official Template for Microsoft Exchange Server 2016. ## Requirements Zabbix version: 7.0 and higher. ## Tested versions This template has been tested on: - Microsoft Exchange Server 2016 CU18 ## Configuration > Zabbix should be configured according to the instructions in the [Templates out of the box](https://www.zabbix.com/documentation/7.0/manual/config/templates_out_of_the_box) section. ## Setup Metrics are collected by Zabbix agent. 1\. Import the template into Zabbix. 2\. Link the imported template to a host with MS Exchange. Note that template doesn't provide information about Windows services state. Recommended to use it with "OS Windows by Zabbix agent" template. ### Macros used |Name|Description|Default| |----|-----------|-------| |{$MS.EXCHANGE.PERF.INTERVAL}|

Update interval for perf_counter_en items.

|`60`| |{$MS.EXCHANGE.DB.FAULTS.TIME}|

The time during which the database page faults may exceed the threshold.

|`5m`| |{$MS.EXCHANGE.DB.FAULTS.WARN}|

Threshold for database page faults trigger.

|`0`| |{$MS.EXCHANGE.LOG.STALLS.TIME}|

The time during which the log records stalled may exceed the threshold.

|`10m`| |{$MS.EXCHANGE.LOG.STALLS.WARN}|

Threshold for log records stalled trigger.

|`100`| |{$MS.EXCHANGE.DB.ACTIVE.READ.TIME}|

The time during which the active database read operations latency may exceed the threshold.

|`5m`| |{$MS.EXCHANGE.DB.ACTIVE.READ.WARN}|

Threshold for active database read operations latency trigger.

|`0.02`| |{$MS.EXCHANGE.DB.ACTIVE.WRITE.TIME}|

The time during which the active database write operations latency may exceed the threshold.

|`10m`| |{$MS.EXCHANGE.DB.ACTIVE.WRITE.WARN}|

Threshold for active database write operations latency trigger.

|`0.05`| |{$MS.EXCHANGE.DB.PASSIVE.READ.TIME}|

The time during which the passive database read operations latency may exceed the threshold.

|`5m`| |{$MS.EXCHANGE.DB.PASSIVE.READ.WARN}|

Threshold for passive database read operations latency trigger.

|`0.2`| |{$MS.EXCHANGE.DB.PASSIVE.WRITE.TIME}|

The time during which the passive database write operations latency may exceed the threshold.

|`10m`| |{$MS.EXCHANGE.RPC.TIME}|

The time during which the RPC requests latency may exceed the threshold.

|`10m`| |{$MS.EXCHANGE.RPC.WARN}|

Threshold for RPC requests latency trigger.

|`0.05`| |{$MS.EXCHANGE.RPC.COUNT.TIME}|

The time during which the RPC total requests may exceed the threshold.

|`5m`| |{$MS.EXCHANGE.RPC.COUNT.WARN}|

Threshold for LDAP triggers.

|`70`| |{$MS.EXCHANGE.LDAP.TIME}|

The time during which the LDAP metrics may exceed the threshold.

|`5m`| |{$MS.EXCHANGE.LDAP.WARN}|

Threshold for LDAP triggers.

|`0.05`| ### Items |Name|Description|Type|Key and additional info| |----|-----------|----|-----------------------| |MS Exchange: Databases total mounted|

Shows the number of active database copies on the server.

|Zabbix agent|perf_counter_en["\MSExchange Active Manager(_total)\Database Mounted"]

**Preprocessing**

| |MS Exchange [Client Access Server]: ActiveSync: ping command pending|

Shows the number of ping commands currently pending in the queue.

|Zabbix agent|perf_counter_en["\MSExchange ActiveSync\Ping Commands Pending", {$MS.EXCHANGE.PERF.INTERVAL}]| |MS Exchange [Client Access Server]: ActiveSync: requests per second|

Shows the number of HTTP requests received from the client via ASP.NET per second. Determines the current Exchange ActiveSync request rate. Used only to determine current user load.

|Zabbix agent|perf_counter_en["\MSExchange ActiveSync\Requests/sec", {$MS.EXCHANGE.PERF.INTERVAL}]| |MS Exchange [Client Access Server]: ActiveSync: sync commands per second|

Shows the number of sync commands processed per second. Clients use this command to synchronize items within a folder.

|Zabbix agent|perf_counter_en["\MSExchange ActiveSync\Sync Commands/sec", {$MS.EXCHANGE.PERF.INTERVAL}]| |MS Exchange [Client Access Server]: Autodiscover: requests per second|

Shows the number of Autodiscover service requests processed each second. Determines current user load.

|Zabbix agent|perf_counter_en["\MSExchangeAutodiscover\Requests/sec", {$MS.EXCHANGE.PERF.INTERVAL}]| |MS Exchange [Client Access Server]: Availability Service: availability requests per second|

Shows the number of requests serviced per second. The request can be only for free/ busy information or include suggestions. One request may contain multiple mailboxes. Determines the rate at which Availability service requests are occurring.

|Zabbix agent|perf_counter_en["\MSExchange Availability Service\Availability Requests (sec)", {$MS.EXCHANGE.PERF.INTERVAL}]| |MS Exchange [Client Access Server]: Outlook Web App: current unique users|

Shows the number of unique users currently logged on to Outlook Web App. This value monitors the number of unique active user sessions, so that users are only removed from this counter after they log off or their session times out. Determines current user load.

|Zabbix agent|perf_counter_en["\MSExchange OWA\Current Unique Users", {$MS.EXCHANGE.PERF.INTERVAL}]| |MS Exchange [Client Access Server]: Outlook Web App: requests per second|

Shows the number of requests handled by Outlook Web App per second. Determines current user load.

|Zabbix agent|perf_counter_en["\MSExchange OWA\Requests/sec", {$MS.EXCHANGE.PERF.INTERVAL}]| |MS Exchange [Client Access Server]: MSExchangeWS: requests per second|

Shows the number of requests processed each second. Determines current user load.

|Zabbix agent|perf_counter_en["\MSExchangeWS\Requests/sec", {$MS.EXCHANGE.PERF.INTERVAL}]| ### LLD rule Databases discovery |Name|Description|Type|Key and additional info| |----|-----------|----|-----------------------| |Databases discovery|

Discovery of Exchange databases.

|Zabbix agent|perf_instance.discovery["MSExchange Active Manager"]

**Preprocessing**

| ### Item prototypes for Databases discovery |Name|Description|Type|Key and additional info| |----|-----------|----|-----------------------| |Active Manager [{#INSTANCE}]: Database copy role|

Database copy active or passive role.

|Zabbix agent|perf_counter_en["\MSExchange Active Manager({#INSTANCE})\Database Copy Role Active"]

**Preprocessing**

| |Information Store [{#INSTANCE}]: Database state|

Database state. Possible values:

0: Database without any copy and dismounted.

1: Database is a primary database and mounted.

2: Database is a passive copy and the state is healthy.

|Zabbix agent|perf_counter_en["\MSExchangeIS Store({#INSTANCE})\Database State"]

**Preprocessing**

| |Information Store [{#INSTANCE}]: Active mailboxes count|

Number of active mailboxes in this database.

|Zabbix agent|perf_counter_en["\MSExchangeIS Store({#INSTANCE})\Active mailboxes"]| |Information Store [{#INSTANCE}]: Page faults per second|

Indicates the rate of page faults that can't be serviced because there are no pages available for allocation from the database cache. If this counter is above 0, it's an indication that the MSExchange Database\I/O Database Writes (Attached) Average Latency is too high.

|Zabbix agent|perf_counter_en["\MSExchange Database({#INF.STORE})\Database Page Fault Stalls/sec", {$MS.EXCHANGE.PERF.INTERVAL}]| |Information Store [{#INSTANCE}]: Log records stalled|

Indicates the number of log records that can't be added to the log buffers per second because the log buffers are full. The average value should be below 10 per second. Spikes (maximum values) shouldn't be higher than 100 per second.

|Zabbix agent|perf_counter_en["\MSExchange Database({#INF.STORE})\Log Record Stalls/sec", {$MS.EXCHANGE.PERF.INTERVAL}]| |Information Store [{#INSTANCE}]: Log threads waiting|

Indicates the number of threads waiting to complete an update of the database by writing their data to the log.

|Zabbix agent|perf_counter_en["\MSExchange Database({#INF.STORE})\Log Threads Waiting", {$MS.EXCHANGE.PERF.INTERVAL}]| |Information Store [{#INSTANCE}]: RPC requests per second|

Shows the number of RPC operations per second for each database instance.

|Zabbix agent|perf_counter_en["\MSExchangeIS Store({#INSTANCE})\RPC Operations/sec", {$MS.EXCHANGE.PERF.INTERVAL}]| |Information Store [{#INSTANCE}]: RPC requests latency|

RPC Latency average is the average latency of RPC requests per database. Average is calculated over all RPCs since exrpc32 was loaded. Should be less than 50ms at all times, with spikes less than 100ms.

|Zabbix agent|perf_counter_en["\MSExchangeIS Store({#INSTANCE})\RPC Average Latency", {$MS.EXCHANGE.PERF.INTERVAL}]

**Preprocessing**

| |Information Store [{#INSTANCE}]: RPC requests total|

Indicates the overall RPC requests currently executing within the information store process. Should be below 70 at all times.

|Zabbix agent|perf_counter_en["\MSExchangeIS Store({#INSTANCE})\RPC requests", {$MS.EXCHANGE.PERF.INTERVAL}]| |Database Counters [{#INSTANCE}]: Active database read operations per second|

Shows the number of database read operations.

|Zabbix agent|perf_counter_en["\MSExchange Database ==> Instances({#INF.STORE}/_Total)\I/O Database Reads (Attached)/sec", {$MS.EXCHANGE.PERF.INTERVAL}]| |Database Counters [{#INSTANCE}]: Active database read operations latency|

Shows the average length of time per database read operation. Should be less than 20 ms on average.

|Zabbix agent|perf_counter_en["\MSExchange Database ==> Instances({#INF.STORE}/_Total)\I/O Database Reads (Attached) Average Latency", {$MS.EXCHANGE.PERF.INTERVAL}]

**Preprocessing**

| |Database Counters [{#INSTANCE}]: Passive database read operations latency|

Shows the average length of time per passive database read operation. Should be less than 200ms on average.

|Zabbix agent|perf_counter_en["\MSExchange Database ==> Instances({#INF.STORE}/_Total)\I/O Database Reads (Recovery) Average Latency", {$MS.EXCHANGE.PERF.INTERVAL}]

**Preprocessing**

| |Database Counters [{#INSTANCE}]: Active database write operations per second|

Shows the number of database write operations per second for each attached database instance.

|Zabbix agent|perf_counter_en["\MSExchange Database ==> Instances({#INF.STORE}/_Total)\I/O Database Writes (Attached)/sec", {$MS.EXCHANGE.PERF.INTERVAL}]| |Database Counters [{#INSTANCE}]: Active database write operations latency|

Shows the average length of time per database write operation. Should be less than 50ms on average.

|Zabbix agent|perf_counter_en["\MSExchange Database ==> Instances({#INF.STORE}/_Total)\I/O Database Writes (Attached) Average Latency", {$MS.EXCHANGE.PERF.INTERVAL}]

**Preprocessing**

| |Database Counters [{#INSTANCE}]: Passive database write operations latency|

Shows the average length of time, in ms, per passive database write operation. Should be less than the read latency for the same instance, as measured by the MSExchange Database ==> Instances({#INF.STORE}/_Total)\I/O Database Reads (Recovery) Average Latency counter.

|Zabbix agent|perf_counter_en["\MSExchange Database ==> Instances({#INF.STORE}/_Total)\I/O Database Writes (Recovery) Average Latency", {$MS.EXCHANGE.PERF.INTERVAL}]

**Preprocessing**

| ### Trigger prototypes for Databases discovery |Name|Description|Expression|Severity|Dependencies and additional info| |----|-----------|----------|--------|--------------------------------| |Information Store [{#INSTANCE}]: Page faults is too high|

Too much page faults stalls for database "{#INSTANCE}". This counter should be 0 on production servers.

|`min(/Microsoft Exchange Server 2016 by Zabbix agent/perf_counter_en["\MSExchange Database({#INF.STORE})\Database Page Fault Stalls/sec", {$MS.EXCHANGE.PERF.INTERVAL}],{$MS.EXCHANGE.DB.FAULTS.TIME})>{$MS.EXCHANGE.DB.FAULTS.WARN}`|Average|| |Information Store [{#INSTANCE}]: Log records stalls is too high|

Stalled log records too high. The average value should be less than 10 threads waiting.

|`avg(/Microsoft Exchange Server 2016 by Zabbix agent/perf_counter_en["\MSExchange Database({#INF.STORE})\Log Record Stalls/sec", {$MS.EXCHANGE.PERF.INTERVAL}],{$MS.EXCHANGE.LOG.STALLS.TIME})>{$MS.EXCHANGE.LOG.STALLS.WARN}`|Average|| |Information Store [{#INSTANCE}]: RPC Requests latency is too high|

Should be less than 50ms at all times, with spikes less than 100ms.

|`min(/Microsoft Exchange Server 2016 by Zabbix agent/perf_counter_en["\MSExchangeIS Store({#INSTANCE})\RPC Average Latency", {$MS.EXCHANGE.PERF.INTERVAL}],{$MS.EXCHANGE.RPC.TIME})>{$MS.EXCHANGE.RPC.WARN}`|Warning|| |Information Store [{#INSTANCE}]: RPC Requests total count is too high|

Should be below 70 at all times.

|`min(/Microsoft Exchange Server 2016 by Zabbix agent/perf_counter_en["\MSExchangeIS Store({#INSTANCE})\RPC requests", {$MS.EXCHANGE.PERF.INTERVAL}],{$MS.EXCHANGE.RPC.COUNT.TIME})>{$MS.EXCHANGE.RPC.COUNT.WARN}`|Warning|| |Database Counters [{#INSTANCE}]: Average read time latency is too high|

Should be less than 20ms on average.

|`min(/Microsoft Exchange Server 2016 by Zabbix agent/perf_counter_en["\MSExchange Database ==> Instances({#INF.STORE}/_Total)\I/O Database Reads (Attached) Average Latency", {$MS.EXCHANGE.PERF.INTERVAL}],{$MS.EXCHANGE.DB.ACTIVE.READ.TIME})>{$MS.EXCHANGE.DB.ACTIVE.READ.WARN}`|Warning|| |Database Counters [{#INSTANCE}]: Average read time latency is too high|

Should be less than 200ms on average.

|`min(/Microsoft Exchange Server 2016 by Zabbix agent/perf_counter_en["\MSExchange Database ==> Instances({#INF.STORE}/_Total)\I/O Database Reads (Recovery) Average Latency", {$MS.EXCHANGE.PERF.INTERVAL}],{$MS.EXCHANGE.DB.PASSIVE.READ.TIME})>{$MS.EXCHANGE.DB.PASSIVE.READ.WARN}`|Warning|| |Database Counters [{#INSTANCE}]: Average write time latency is too high for {$MS.EXCHANGE.DB.ACTIVE.WRITE.TIME}|

Should be less than 50ms on average.

|`min(/Microsoft Exchange Server 2016 by Zabbix agent/perf_counter_en["\MSExchange Database ==> Instances({#INF.STORE}/_Total)\I/O Database Writes (Attached) Average Latency", {$MS.EXCHANGE.PERF.INTERVAL}],{$MS.EXCHANGE.DB.ACTIVE.WRITE.TIME})>{$MS.EXCHANGE.DB.ACTIVE.WRITE.WARN}`|Warning|| |Database Counters [{#INSTANCE}]: Average write time latency is higher than read time latency for {$MS.EXCHANGE.DB.PASSIVE.WRITE.TIME}|

Should be less than the read latency for the same instance, as measured by the MSExchange Database ==> Instances({#INF.STORE}/_Total)\I/O Database Reads (Recovery) Average Latency counter.

|`avg(/Microsoft Exchange Server 2016 by Zabbix agent/perf_counter_en["\MSExchange Database ==> Instances({#INF.STORE}/_Total)\I/O Database Writes (Recovery) Average Latency", {$MS.EXCHANGE.PERF.INTERVAL}],{$MS.EXCHANGE.DB.PASSIVE.WRITE.TIME})>avg(/Microsoft Exchange Server 2016 by Zabbix agent/perf_counter_en["\MSExchange Database ==> Instances({#INF.STORE}/_Total)\I/O Database Reads (Recovery) Average Latency", {$MS.EXCHANGE.PERF.INTERVAL}],{$MS.EXCHANGE.DB.PASSIVE.WRITE.TIME})`|Warning|| ### LLD rule Web services discovery |Name|Description|Type|Key and additional info| |----|-----------|----|-----------------------| |Web services discovery|

Discovery of Exchange web services.

|Zabbix agent|perf_instance_en.discovery["Web Service"]| ### Item prototypes for Web services discovery |Name|Description|Type|Key and additional info| |----|-----------|----|-----------------------| |Web Service [{#INSTANCE}]: Current connections|

Shows the current number of connections established to the each Web Service.

|Zabbix agent|perf_counter_en["\Web Service({#INSTANCE})\Current Connections", {$MS.EXCHANGE.PERF.INTERVAL}]| ### LLD rule LDAP discovery |Name|Description|Type|Key and additional info| |----|-----------|----|-----------------------| |LDAP discovery|

Discovery of domain controller.

|Zabbix agent|perf_instance_en.discovery["MSExchange ADAccess Domain Controllers"]| ### Item prototypes for LDAP discovery |Name|Description|Type|Key and additional info| |----|-----------|----|-----------------------| |Domain Controller [{#INSTANCE}]: Read time|

Time that it takes to send an LDAP read request to the domain controller in question and get a response. Should ideally be below 50 ms; spikes below 100 ms are acceptable.

|Zabbix agent|perf_counter_en["\MSExchange ADAccess Domain Controllers({#INSTANCE})\LDAP Read Time", {$MS.EXCHANGE.PERF.INTERVAL}]

**Preprocessing**

| |Domain Controller [{#INSTANCE}]: Search time|

Time that it takes to send an LDAP search request and get a response. Should ideally be below 50 ms; spikes below 100 ms are acceptable.

|Zabbix agent|perf_counter_en["\MSExchange ADAccess Domain Controllers({#INSTANCE})\LDAP Search Time", {$MS.EXCHANGE.PERF.INTERVAL}]

**Preprocessing**

| ### Trigger prototypes for LDAP discovery |Name|Description|Expression|Severity|Dependencies and additional info| |----|-----------|----------|--------|--------------------------------| |Domain Controller [{#INSTANCE}]: LDAP read time is too high|

Should be less than 50ms at all times, with spikes less than 100ms.

|`min(/Microsoft Exchange Server 2016 by Zabbix agent/perf_counter_en["\MSExchange ADAccess Domain Controllers({#INSTANCE})\LDAP Read Time", {$MS.EXCHANGE.PERF.INTERVAL}],{$MS.EXCHANGE.LDAP.TIME})>{$MS.EXCHANGE.LDAP.WARN}`|Average|| |Domain Controller [{#INSTANCE}]: LDAP search time is too high|

Should be less than 50ms at all times, with spikes less than 100ms.

|`min(/Microsoft Exchange Server 2016 by Zabbix agent/perf_counter_en["\MSExchange ADAccess Domain Controllers({#INSTANCE})\LDAP Search Time", {$MS.EXCHANGE.PERF.INTERVAL}],{$MS.EXCHANGE.LDAP.TIME})>{$MS.EXCHANGE.LDAP.WARN}`|Average|| ## Feedback Please report any issues with the template at [`https://support.zabbix.com`](https://support.zabbix.com) You can also provide feedback, discuss the template, or ask for help at [`ZABBIX forums`](https://www.zabbix.com/forum/zabbix-suggestions-and-feedback)