-
Notifications
You must be signed in to change notification settings - Fork 74
Users guide
Welcome to the Adagios user guide. It's wiki document so anyone can contribute to this document.
This guide assumes that you already have Adagios installed and running. If not consult the Install Guide on how to get Adagios up and running.
Remember this Document is about Adagios which is an addon to Nagios/Icinga. This guide will not go in detail about Nagios/Icinga features like what configuration objects do, and how to monitor specific systems. Instead consider the following documents:
- Nagios Object Definition Guide
- Introduction to Nagios Plugins
- Nagios Plugin Developer Guidelines
- Nagios Core Documentation
If you are doing custom installs of Adagios you may want to have a custom header and footer displayed in the output of web pages that adagios renders. You can include any information that browsers understand (html, javascript, etc).
This can be used to create your own custom menus and such.
You can include your custom content by dropping appropriately named files in your "serverside_includes" directory as it is specified in adagios.conf (by default /etc/adagios/ssi).
Custom headers are included at the top of the markup and custom footers right before /body.
There are two types of headers/footers.
- /etc/adagios/ssi/common-header.ssi and common-footer.ssi respectively. These are included on every page load.
- /etc/adagios/ssi/CUSTOMPAGE-header.ssi and CUSTOMPAGE-footer.ssi where CUSTOMPAGE is a name of one specific page to include data on. For example if you want to include html on the services page, you would create a file called /etc/adagios/ssi/adagios.status.views.services-footer.ssi
If your serverside include html tags include the special classes ssi-append and ssi-overwrite then adagios will recognize as html to inject somwhere else.
Add nagvis to top navigation bar:
<div class="ssi-append" data-for="#top_navigation_menuitems">
<li>
<a href="/nagvis"><i class="glyph-list glyph-grey"></i> Nagvis</a>
</li>
</div>
Same as above, but maintain adagios top navigation bar:
<div class="ssi-append" data-for="#top_navigation_menuitems">
<li>
<a href="{% url adagios.misc.views.iframe %}?url=/nagvis"><i class="glyph-list glyph-grey"></i> Nagvis</a>
</li>
</div>
We are currently working on a business intelligence module in Adagios. It's still under heavy development, but we better drop down a few notes to explain what its all about.
Few definitions:
- A "Business Process" (BP) is a way to group together services in Adagios
- I repeat: Business Process is a grouping tool!
- Business Process can contain one or more "Sub processes" which can be any of:
- Nagios Service checks
- Hosts
- Hostgroup
- Servicegroup
- Another Business Process (so nesting is supported)
- You can configure the status of a business process depending on its sub processes by setting the "Status Calculation Method". Examples of status calculation method for a business process is:
- Use worst service state
- Use worst host state
- Use custom Business intelligence rules
- Business Process states in Adagios are configurable, but generally the nagios-style states of 0,1,2,3 = ok,warn,crit,unknown are the default
- You can create your own custom views to display the status of a business process
- Graphs can be added to a business process
Adagios started of as a configuration interface only. So to begin with authentication was handled by the web server and there was no authorization. Now that Adagios is a half-decent status interface, it makes sense to give some users limited access to status information, and deny them access to configuration stuff.
To enable authorization in Adagios add the following to adagios.conf:
enable_authorization=True
administrators="nagiosadmin,admins"
After authorization has been enabled, access to a adagios is limited for everyone that is not in the administrators group. administrators do not need to be contacts, but if you specify a contact group (f.e. "admins") adagios will look through the contacts in that group and if a contact matches the user logging in, then it is granted access.
Adagios supports connecting to multiple backends for the purpose of showing multiple nagios instances in one web interface. At the point of this writing, this applies only for livestatus connections, not for editing configuration.
At the time of this writing. this is highly experimental.
Adagios uses the config variable livestatus_path to find a path to livestatus socket. If livestatus_path is not provided, adagios looks for it in your nagios.cfg and connects to it automatically.
To explicitly tell adagios which socket to use, or to have it connect to multiple sockets put a comma-separated list in livestatus_path like so:
livestatus_path="socket1,socket2,socket3"
# Example:
livestatus_path="/var/spool/nagios/cmd/livestatus,remoteserver.example.com:6559"