# Solaris by Zabbix agent ## Overview It is an official Solaris OS template. It requires Zabbix agent 7.0 or newer. ## Requirements Zabbix version: 7.0 and higher. ## Tested versions This template has been tested on: - Solaris OS ## 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 Install Zabbix agent on Solaris OS according to Zabbix documentation. ### Macros used |Name|Description|Default| |----|-----------|-------| |{$AGENT.TIMEOUT}|
The timeout after which the agent is considered unavailable. It works only for the agents reachable from Zabbix server/proxy (in passive mode).
|`3m`| ### Items |Name|Description|Type|Key and additional info| |----|-----------|----|-----------------------| |Solaris: Maximum number of processes|It could be increased by using the sysctl utility or modifying the file /etc/sysctl.conf.
|Zabbix agent|kernel.maxproc| |Solaris: Number of running processes|The number of processes in a running state.
|Zabbix agent|proc.num[,,run]| |Solaris: Number of processes|The total number of processes in any state.
|Zabbix agent|proc.num[]| |Solaris: Host boot time||Zabbix agent|system.boottime| |Solaris: Interrupts per second||Zabbix agent|system.cpu.intr**Preprocessing**
The processor load is calculated as the system CPU load divided by the number of CPU cores.
|Zabbix agent|system.cpu.load[percpu,avg1]| |Solaris: Processor load (5 min average per core)|The processor load is calculated as the system CPU load divided by the number of CPU cores.
|Zabbix agent|system.cpu.load[percpu,avg5]| |Solaris: Processor load (15 min average per core)|The processor load is calculated as the system CPU load divided by the number of CPU cores.
|Zabbix agent|system.cpu.load[percpu,avg15]| |Solaris: Context switches per second||Zabbix agent|system.cpu.switches**Preprocessing**
The time the CPU has spent doing nothing.
|Zabbix agent|system.cpu.util[,idle]| |Solaris: CPU iowait time|The amount of time the CPU has been waiting for the I/O to complete.
|Zabbix agent|system.cpu.util[,iowait]| |Solaris: CPU system time|The time the CPU has spent running the kernel and its processes.
|Zabbix agent|system.cpu.util[,system]| |Solaris: CPU user time|The time the CPU has spent running users' processes that are not niced.
|Zabbix agent|system.cpu.util[,user]| |Solaris: Host name|A host name of the system.
|Zabbix agent|system.hostname**Preprocessing**
Discard unchanged with heartbeat: `1d`
The information as normally returned by the 'uname -a'.
|Zabbix agent|system.uname**Preprocessing**
Discard unchanged with heartbeat: `1d`
The number of users who are currently logged in.
|Zabbix agent|system.users.num| |Solaris: Checksum of /etc/passwd||Zabbix agent|vfs.file.cksum[/etc/passwd,sha256]**Preprocessing**
Discard unchanged with heartbeat: `1h`
The available memory is defined as free+cached+buffers memory.
|Zabbix agent|vm.memory.size[available]| |Solaris: Total memory||Zabbix agent|vm.memory.size[total]| |Solaris: Host name of Zabbix agent running||Zabbix agent|agent.hostname**Preprocessing**
Discard unchanged with heartbeat: `1d`
**Preprocessing**
Discard unchanged with heartbeat: `1d`
Monitoring agent availability status
|Zabbix internal|zabbix[host,agent,available]| |Solaris: Zabbix agent ping|The agent always returns 1 for this item. It could be used in combination with nodata() for the availability check.
|Zabbix agent|agent.ping| |Solaris: Get filesystems|The `vfs.fs.get` key acquires raw information set about the file systems. Later to be extracted by preprocessing in dependent items.
|Zabbix agent|vfs.fs.get| ### Triggers |Name|Description|Expression|Severity|Dependencies and additional info| |----|-----------|----------|--------|--------------------------------| |Solaris: Configured max number of processes is too low||`last(/Solaris by Zabbix agent/kernel.maxproc)<256`|Info|| |Solaris: Too many processes running||`avg(/Solaris by Zabbix agent/proc.num[,,run],5m)>30`|Warning|| |Solaris: Too many processes||`avg(/Solaris by Zabbix agent/proc.num[],5m)>300`|Warning|| |Solaris: Processor load is too high||`avg(/Solaris by Zabbix agent/system.cpu.load[percpu,avg1],5m)>5`|Warning|| |Solaris: Disk I/O is overloaded|The OS spends significant time waiting for the I/O (input/output) operations. It could be an indicator of performance issues with the storage system.
|`avg(/Solaris by Zabbix agent/system.cpu.util[,iowait],5m)>20`|Warning|| |Solaris: Hostname was changed||`last(/Solaris by Zabbix agent/system.hostname,#1)<>last(/Solaris by Zabbix agent/system.hostname,#2)`|Info|| |Solaris: Lack of free swap space|It probably means that the systems requires more physical memory.
|`last(/Solaris by Zabbix agent/system.swap.size[,pfree])<50`|Warning|| |Solaris: Host information was changed||`last(/Solaris by Zabbix agent/system.uname,#1)<>last(/Solaris by Zabbix agent/system.uname,#2)`|Info|| |Solaris: Server has just been restarted||`change(/Solaris by Zabbix agent/system.uptime)<0`|Info|| |Solaris: /etc/passwd has been changed||`last(/Solaris by Zabbix agent/vfs.file.cksum[/etc/passwd,sha256],#1)<>last(/Solaris by Zabbix agent/vfs.file.cksum[/etc/passwd,sha256],#2)`|Warning|| |Solaris: Lack of available memory on server||`last(/Solaris by Zabbix agent/vm.memory.size[available])<20M`|Average|| |Solaris: Zabbix agent is not available|For passive checks only the availability of the agents and a host is used with {$AGENT.TIMEOUT} as the time threshold.
|`max(/Solaris by Zabbix agent/zabbix[host,agent,available],{$AGENT.TIMEOUT})=0`|Average|**Manual close**: Yes| ### LLD rule Network interface discovery |Name|Description|Type|Key and additional info| |----|-----------|----|-----------------------| |Network interface discovery|The discovery of network interfaces as defined in the global regular expression "Network interfaces for discovery".
|Zabbix agent|net.if.discovery| ### Item prototypes for Network interface discovery |Name|Description|Type|Key and additional info| |----|-----------|----|-----------------------| |Interface {#IFNAME}: Incoming network traffic||Zabbix agent|net.if.in[{#IFNAME}]**Preprocessing**
Custom multiplier: `8`
**Preprocessing**
Custom multiplier: `8`
Discovery of different types of file systems as defined in the global regular expression "File systems for discovery".
|Dependent item|vfs.fs.dependent.discovery| ### Item prototypes for Mounted filesystem discovery |Name|Description|Type|Key and additional info| |----|-----------|----|-----------------------| |{#FSNAME}: Get filesystem data||Dependent item|vfs.fs.dependent[{#FSNAME},data]**Preprocessing**
JSON Path: `$.[?(@.fsname=='{#FSNAME}')].first()`
The filesystem is mounted as read-only. It is available only for Zabbix agents 6.4 and higher.
|Dependent item|vfs.fs.dependent[{#FSNAME},readonly]**Preprocessing**
JSON Path: `$.options`
⛔️Custom on fail: Discard value
Regular expression: `(?:^|,)ro\b 1`
⛔️Custom on fail: Set value to: `0`
**Preprocessing**
JSON Path: `$.inodes.pfree`
**Preprocessing**
JSON Path: `$.bytes.free`
**Preprocessing**
JSON Path: `$.bytes.pfree`
**Preprocessing**
JSON Path: `$.bytes.total`
**Preprocessing**
JSON Path: `$.bytes.used`
The filesystem has become read-only. A possible reason is an I/O error. It is available only for Zabbix agents 6.4 and higher.
|`last(/Solaris by Zabbix agent/vfs.fs.dependent[{#FSNAME},readonly],#2)=0 and last(/Solaris by Zabbix agent/vfs.fs.dependent[{#FSNAME},readonly])=1`|Average|**Manual close**: Yes| |{#FSNAME}: Free inodes is less than 20%||`last(/Solaris by Zabbix agent/vfs.fs.dependent.inode[{#FSNAME},pfree])<20`|Warning|| |{#FSNAME}: Free disk space is less than 20%||`last(/Solaris by Zabbix agent/vfs.fs.dependent.size[{#FSNAME},pfree])<20`|Warning|| ## 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)