Monit¶
OPNsense uses Monit for monitoring services. Monit has quite extensive monitoring capabilities, which is why the configuration options are extensive as well. This guide will do a quick walk through the setup, with the configuration options explained in more detail afterwards, along with some caveats.
Global setup¶
Navigate to From: sender@example.com
in the “Mail format” field. Save the alert and apply the changes.
Adding an alert¶
First, you have to decide what you want to monitor and what constitutes a failure. It helps if you have some knowledge about how Monit alerts are set up. This is described in the Monit documentation.
If you have done that, you have to add the condition first. Navigate to the ‘Service Test Settings’ tab and look if the condition you want to add already exists. If it doesn’t, click the + button to add it.
Now navigate to the ‘Service Test’ tab and click the + icon. In the dialog, you can now add your service test. If you’re done, save it, then apply the changes.
The fields in the dialogs are described in more detail in the “Settings overview” section of this document.
Example 1¶
In this example, we’ll add a service to restart the FTP proxy (running on port 8021) if it has stopped. To avoid an eternal loop in case something is wrong, we’ll also add a provision to stop trying if the FTP proxy has had to be restarted five times in a row.
First, make sure you have followed the steps under “Global setup”. Then, navigate to the “Service Tests Settings” tab. Here, you need to add two tests:
Setting |
Value |
---|---|
Name |
FTPProxy8021 |
Condition |
failed host 127.0.0.1 port 8021 type tcp |
Action |
Restart |
Setting |
Value |
---|---|
Name |
RestartLimit5 |
Condition |
5 restarts within 5 cycles |
Action |
Unmonitor |
Now, navigate to the “Service Settings” tab. Here, add the following service:
Setting |
Value |
---|---|
Name |
FTPProxy8021 |
Type |
Process |
PID File |
/var/run/osftpproxy.127_0_0_1_8021.pid |
Start |
/usr/local/sbin/configctl ftpproxy start 127_0_0_1_8021 |
Stop |
/usr/local/sbin/configctl ftpproxy stop 127_0_0_1_8021 |
Tests |
FTPProxy8021, RestartLimit5 |
Save and apply.
Example 2¶
In this example, we want to monitor a VPN tunnel and ping a remote system. If the ping does not respond anymore, IPsec should be restarted.
First, make sure you have followed the steps under “Global setup”. Then, navigate to the “Service Tests Settings” tab. Here, you need to add one test:
Setting |
Value |
---|---|
Name |
IPSEC_RESTART |
Condition |
failed ping4 count 5 address <local IP> |
Action |
Restart |
Now, navigate to the “Service Settings” tab. Here, add the following service:
Setting |
Value |
---|---|
Name |
IPSEC_MONITOR |
Type |
Remote Host |
Address |
<remote IP> |
Start |
/usr/local/sbin/configctl ipsec start |
Stop |
/usr/local/sbin/configctl ipsec stop |
Tests |
IPSEC_RESTART |
Save and apply.
Example 3¶
In this example, we want to monitor Suricata EVE Log for alerts and send an e-mail. This is really simple, be sure to keep false positives low to no get spammed by alerts.
First, make sure you have followed the steps under “Global setup”. Then, navigate to the “Service Tests Settings” tab. Here, you need to add one test:
Setting |
Value |
---|---|
Name |
SURICATA_EVE |
Condition |
content = “blocked” |
Action |
Alert |
Now, navigate to the “Service Settings” tab. Here, add the following service:
Setting |
Value |
---|---|
Name |
SURICATA_ALERT |
Type |
File |
Path |
/var/log/suricata/eve.json |
Tests |
SURICATA_EVE |
Save and apply. From now on you will receive with the alert message for every block action.
Settings overview¶
Navigate to
. You will see four tabs, which we will describe in more detail belowGeneral Settings¶
Click ‘advanced mode’ to see all the settings.
Setting |
Description |
---|---|
Enable Monit |
Turns Monit on or off. |
Polling interval |
How often Monit checks the status of the components it monitors. |
Start delay |
How long Monit waits before checking components when it starts. |
Mail Server |
A list of mail servers to send notifications to (also see below this table). |
Mail Server Port |
The mail server port to use. 25 and 465 are common examples. |
Username |
The username used to log into your SMTP server, if needed. Often, but not always, the same as your e-mail address. |
Password |
The password used to log into your SMTP server, if needed. |
Secure Connection |
Use TLS when connecting to the mail server. |
SSL Version |
The TLS version to use. AUTO will try to negotiate a working version. |
Verify SSL Certificates |
Checks the TLS certificate for validity. If you use a self-signed certificate, turn this option off. |
Log File |
The log file of the Monit process. This can be the keyword |
State File |
The state file of the Monit process. |
Eventqueue Path |
The path to the eventqueue directory. |
Eventqueue Slots |
The number of eventqueue slots. |
Enable HTTPD |
Turns on the Monit web interface. (Required to see options below.) |
Monit HTTPD Port |
The listen port of the Monit web interface service. |
Monit HTTPD Access List |
The username:password or host/network etc. for accessing the Monit web interface service. |
M/Monit URL |
The M/Monit URL, e.g. https://user:pass@192.168.1.10:8443/collector |
M/Monit Timeout |
When doing requests to M/Monit, time out after this amount of seconds. |
M/Monit Register Credentials |
Automatically register in M/Monit by sending Monit credentials (see Monit Access List above). |
In the “Mail Server” settings, you can specify multiple servers. Monit will try the mail servers in order, starting with the first, advancing to the second if the first server does not work, etc. If no server works Monit will not attempt to send the e-mail again.
Two things to keep in mind: the authentication settings are shared between all the servers, and the ‘From:’ address is set in the “Alert Settings”.
Authentication options for the Monit web interface are described in https://mmonit.com/monit/documentation/monit.html#Authentication.
M/Monit is a commercial service to collect data from several Monit instances. To use it from OPNsense, fill in the appropriate fields and add corresponding firewall rules as well.
Alert Settings¶
This lists the e-mail addresses to report to. Click the Edit icon of a pre-existing entry or the Add icon (a plus sign in the lower right corner) to see the options listed below.
Setting |
Description |
---|---|
Enable alert |
Turns this alert on or off. |
Recipient |
The e-mail address to send this e-mail to. |
Not on |
When off, notifications will be sent for events specified below. When on, notifications will be sent for events not specified below. |
Events |
Events that trigger this notification (or that don’t, if “Not on” is selected). |
Mail format |
Can be used to control the mail formatting and from address. See below this table. |
Reminder |
Send a reminder if the problem still persists after this amount of checks. |
Description |
A description for this rule, in order to easily find it in the Alert Settings list. |
“Mail format” is a newline-separated list of properties to control the mail formatting. It is also needed to correctly set the From address. For example:
From: sender@example.com
Reply-To: support@example.com
Subject: $SERVICE at $HOST failed
Service Settings¶
This lists the services that are set. There are some services precreated, but you add as many as you like. Click the Edit icon of a pre-existing entry or the Add icon (a plus sign in the lower right corner) to see the options listed below.
Setting |
Description |
---|---|
Enable service checks |
Turns this service on or off. |
Name |
A name for this service, consisting of only letters, digits and underscore. More descriptive names can be set in the Description field. |
Type |
The kind of object to check. ‘Custom’ allows you to use custom scripts. |
Path |
The path to the directory, file, or script, where applicable. |
Program Timeout |
How often to run this check. |
Start |
The start script of the service, if applicable. |
Stop |
The stop script of the service, if applicable. |
Tests |
The condition to test on to determine if an alert needs to get sent. These conditions are created on the Service Test Settings tab. |
Description |
A description for this service, in order to easily find it in the Service Settings list. |
Service Test Settings¶
Setting |
Description |
---|---|
Name |
The name of the test. |
Condition |
A condition that adheres to the Monit syntax, see the Monit documentation |
Action |
What to do when the condition gets hit. |
There are some precreated service tests. Most of these are typically used for one scenario, like the ‘Memory usage > 75%’ test. Some, however, are more generic and can be used to test output of your own scripts. These include:
Service Test |
Description |
---|---|
NonZeroStatus |
The returned status code is not 0. (Scripts typically exit with 0 if there were no problems, and with non-zero if there were.) |
ChangedStatus |
The returned status code has changed since the last it the script was run. |
Status¶
The Monit status panel can be accessed via
. For every active service, it will show the status, along with extra information if the service provides it.Advanced Configurations¶
Some installations require configuration settings that are not accessible in the UI.
To support these, individual configuration files with a .conf
extension can be put into the
/usr/local/etc/monit.opnsense.d
directory. These files will be automatically included by
the UI generated configuration. Multiple configuration files can be placed there. But note that
The wildcard include processing in Monit is based on
glob(7)
. So the order in which the files are included is in ascending ASCII order.Monit supports up to 1024 include files. If this limit is exceeded, Monit will report an error.
It makes sense to check if the configuration file is valid. You can do so by using the following command:
# Run syntax check for the control file configctl monit check
This is a sample configuration file to customize the limits of the Monit daemon:
## Set limits for various tests. The following example shows the default values:
##
set limits {
programOutput: 5120 B, # check program's output truncate limit
# sendExpectBuffer: 256 B, # limit for send/expect protocol test
fileContentBuffer: 5120 B, # limit for file content test
# httpContentBuffer: 1 MB, # limit for HTTP content test
# networkTimeout: 5 seconds # timeout for network I/O
# programTimeout: 300 seconds # timeout for check program
# stopTimeout: 30 seconds # timeout for service stop
# startTimeout: 120 seconds # timeout for service start
# restartTimeout: 30 seconds # timeout for service restart
}
Warning
It is the sole responsibility of the administrator which places a file in the extension directory to ensure that the configuration is valid.