Icinga

Last updated
Icinga
Initial releaseMay 2009 (2009-05)
Stable release
2.14.2 (Icinga 2) / January 18, 2024;8 months ago (2024-01-18) [1]
Repository
Written in C++, PHP
Operating system Cross-platform (master on Linux only)
Type Network monitoring
License GPLv2
Website icinga.com OOjs UI icon edit-ltr-progressive.svg
Operating principle of Nagios Monitoring.png
Operating principle of Nagios

Icinga is an open-source computer system and network monitoring application. It was created as a fork of the Nagios system monitoring application in 2009. [2] [3]

Contents

Icinga tries to improve Nagios' development process [4] as well as adding new features [5] [6] such as a modern Web 2.0 style user interface, additional database connectors (for MySQL, Oracle, and PostgreSQL), and a REST API that lets administrators integrate numerous extensions without complicated modification of the Icinga core.

The first stable version, 1.0, was released in December 2009, and new versions were released every couple of months as of January 2010. [7]

In 2012 developement of a new core component was started and released in 2014 as Icinga 2 [8] to allow for profound architectural changes compared to the Nagios core.

History

In May 2009, a group of developers from the Nagios community announced the fork Icinga, citing their dissatisfaction with the stagnant development of the Nagios software at the time and their desire to open its development to a broader base. [4] The name Icinga is a Zulu word meaning "it looks for", "it browses" or "it examines" [9] and is pronounced with a click consonant. [10]

In their first year, Icinga developers released separate versions of Core, API, and Web, and celebrated their 10,000th download. [11]

In its second year, the Icinga project released unified and stable Core and Web; added dual-stack IPv6 and IPv4 support, optimized database connectivity, and revamped the Icinga Web user interface, integrating various community add-ons (PNP4Nagios, LConf, Heatmap and Business Process Addon). The project achieved more than 70,000 downloads and grew to 23 team members. [11]

In their second year, Icinga celebrated their 100,000th download, integrated the Icinga API component into Icinga Web, improved SLA reporting; and extended the Icinga virtual appliances to the Debian, OpenSUSE and CentOS operating systems. [12]

In October 2012, the Icinga project released a technology preview of Icinga 2. It was a core framework replacement and parallel development branch. The developers said they want to rewrite the core to fix problems. These include the complicated setup and scalability limits in big deployments. They plan to rewrite the Icinga 2 core in C++ and design a new component loader architecture. They also plan to change how monitoring checks run. [13]

In June 2014, the Icinga project released the first stable release of Icinga 2. [14] New features, such as an agent or API feature, are scheduled for later releases.

Features

Due to its nature as a fork, Icinga offers Nagios’ features with some additions such as optional reporting module with improved SLA accuracy, additional database connectors for PostgreSQL and Oracle, and distributed systems for redundant monitoring. Icinga also maintains configuration and plug-in compatibility with Nagios, [11] facilitating migration between the two monitoring software.

Monitoring

Notification

Visualisation & reporting

Architecture

Icinga modular architecture with Core, Icinga Data Out Database, Web as of v1.5 Icinga Architecture v1.5.png
Icinga modular architecture with Core, Icinga Data Out Database, Web as of v1.5

Icinga Core is written in C [17] and has a modular architecture with a standalone core, user interface, and database on which users can integrate various add-ons and plug-ins.

The latter communicates via Icinga's Doctrine abstraction layer, REST and plug-in APIs that mediate between the external data and internal structures. This bundling of components allows users to distribute Icinga's system for redundant monitoring. It also offers users the freedom to customize Icinga to suit their needs. [18]

Icinga Core

The Icinga Core manages monitoring tasks, receiving check results from various plug-ins. It then communicates these results to the IDODB (Icinga Data Out Database) through the IDOMOD (Icinga Data Out Module) interface and the IDO2DB (Icinga Data Out to Database) service daemon over SSL-encrypted TCP sockets. Though both come packaged (also known as IDOUtils) with the core, they are single-standing components that can be separated to distribute the data and processes across multiple servers for distributed system monitoring.

The Icinga Classic user interface also comes packaged with Icinga Core and can be used as a substitute for the PHP-based Icinga Web interface.

Icinga 2

Icinga 2 manages monitoring tasks, running checks, and sending alert notifications. The Icinga 2 features can be enabled on-demand, be it default features such as the 'checker' or 'notification' component, or external interfaces compatible with Icinga 1.x and its user interfaces, for example, the IDO DB (Icinga Data Out Database). Icinga 2 ships a built-in cluster stack secured by SSL x509 certificates attempting to make distributed monitoring setups more easy.

The configuration syntax is different for Icinga Core 1.x and Nagios and requires a migration on upgrade.

Icinga's User Interface

Icinga offers a web interface for users to view monitoring results and send commands to the Icinga Core, called Icinga Web (also referred to as New Web) is the projective and PHP based, Web 2.0 inspired front end that uses Cronks (widgets) to offer drag-n-drop customized dashboards. Icinga Web is a standalone piece, of software. It communicates to the core, database, and 3rd party add-ons the thrinput/dmponent layers: Doctrine abstraction, layer the (Input/Database), REST API (external scripts) and Command Control Interface (writing to a pipe, executing commands).

The interface presents information on host and service status, history, notifications, and status maps to show the health of a network in real-time and also supports IPv4 as well as IPv6 addresses.

Icinga Data Out Database

The Icinga Data Out Database (IDODB) is a storage point for historical monitoring data for add-ons or the Icinga Web interface to access. In contrast to its predecessor Nagios, Icinga supports PostgreSQL and Oracle databases in addition to MySQL.

Icinga Reporting

The Icinga project offers an optional Icinga Reporting module based on the open source Jasper Reports. It can be integrated into both Icinga Classic and Icinga Web user interfaces. The module provides template-based reports (e.g., Top 10 problematic hosts or services, synopsis of complete monitoring environment, availability reports, etc.) that can be saved to a repository with varying access levels and automated report generation and distribution. Reports can also be viewed in both of Icinga's optional user interfaces.

Icinga Mobile

Icinga Mobile is a user interface for smartphones and tablet browsers that run on WebKit. These usually are available on iOS, Android, BlackBerry Tablet OS and webOS. Based on JavaScript and Sencha Touch, Icinga Mobile is downloaded onto a server for access by authorized users via their mobile devices. Administration and updates can thus be made centrally, to automatically apply to all users of a computer network. [19]

Extended functionality

Screenshot of Icinga Web 1.8 with integrated Business Process View add-on Icinga Web 1.8 Business Process Monitoring.png
Screenshot of Icinga Web 1.8 with integrated Business Process View add-on

Some of the most popular add-ons to extend Icinga's functionality include:

Icinga has been deployed in distributed and failover setups. [20] The software has modular architecture with standalone Core, Web and IDODB (Icinga Data Out Database), which provides distributed monitoring and distributed systems monitoring.

Nagios Remote Plugin Executor (NRPE) is an Icinga-compatible agent that allows remote systems monitoring using scripts that are hosted on remote systems. It allows for monitoring resources such as disk usage, system load or the number of users currently logged in. Icinga periodically polls the agent on the remote system using the check_nrpe plug-in. In setups using the optional Icinga Web user interface, monitoring data from multiple Icinga Core instances can be displayed as long as each instance writes to the same IDODB. Icinga can have its various components split and scattered in a distributed setup.

The user access, notifications, and views can be customized.

See also

Related Research Articles

<span class="mw-page-title-main">Database</span> Organized collection of data in computing

In computing, a database is an organized collection of data or a type of data store based on the use of a database management system (DBMS), the software that interacts with end users, applications, and the database itself to capture and analyze the data. The DBMS additionally encompasses the core facilities provided to administer the database. The sum total of the database, the DBMS and the associated applications can be referred to as a database system. Often the term "database" is also used loosely to refer to any of the DBMS, the database system or an application associated with the database.

Middleware in the context of distributed applications is software that provides services beyond those provided by the operating system to enable the various components of a distributed system to communicate and manage data. Middleware supports and simplifies complex distributed applications. It includes web servers, application servers, messaging and similar tools that support application development and delivery. Middleware is especially integral to modern information technology based on XML, SOAP, Web services, and service-oriented architecture.

<span class="mw-page-title-main">WebObjects</span> Java web application server and framework originally developed by NeXT Software

WebObjects is a discontinued Java web application server and a server-based web application framework originally developed by NeXT Software, Inc.

Nagios is an event monitoring system that offers monitoring and alerting services for servers, switches, applications and services. It alerts users when things go wrong and alerts them a second time when the problem has been resolved.

A GIS software program is a computer program to support the use of a geographic information system, providing the ability to create, store, manage, query, analyze, and visualize geographic data, that is, data representing phenomena for which location is important. The GIS software industry encompasses a broad range of commercial and open-source products that provide some or all of these capabilities within various information technology architectures.

<span class="mw-page-title-main">Mantis Bug Tracker</span> Bug tracking system

Mantis Bug Tracker is a free and open source, web-based bug tracking system. The most common use of MantisBT is to track software defects. However, MantisBT is often configured by users to serve as a more generic issue tracking system and project management tool.

<span class="mw-page-title-main">LAMP (software bundle)</span> Acronym for a common web hosting solution

A LAMP is one of the most common software stacks for the web's most popular applications. Its generic software stack model has largely interchangeable components.

<span class="mw-page-title-main">Zenoss</span>

The company Zenoss, Inc. was founded in 2005 and is headquartered in Austin, Texas. The company develops hybrid IT monitoring and analytics software.

The following tables compare general and technical information for a number of notable network monitoring systems. Please see the individual products' articles for further information.

<span class="mw-page-title-main">Shinken (software)</span> Network monitoring software

Shinken is an open source computer system and network monitoring software application compatible with Nagios. It watches hosts and services, gathers performance data and alerts users when error conditions occur and again when the conditions clear.

<span class="mw-page-title-main">Nconf</span> Network monitoring configuration software

NConf is an open source tool for configuring the Nagios network monitoring system. It is mainly targeted at sysadmins who are looking for a more convenient way of managing their Nagios configuration files through the use of a graphical user interface, as opposed to maintaining the configuration files with a text editor.

<span class="mw-page-title-main">OpenMediaVault</span> NAS operating system

OpenMediaVault (OMV) is a free Linux distribution designed for network-attached storage (NAS). The project's lead developer is Volker Theile, who instituted it in 2009. OMV is based on the Debian operating system, and is licensed through the GNU General Public License v3.

Checkmk is a software system developed in Python and C++ for IT Infrastructure monitoring. It is used for the monitoring of servers, applications, networks, cloud infrastructures, containers, storage, databases and environment sensors.

<span class="mw-page-title-main">Actian Zen</span>

Actian Zen is an ACID-compliant, zero-DBA, embedded, nano-footprint, multi-model, Multi-Platform database management system (DBMS). It was originally developed by Pervasive Software, which was acquired by Actian Corporation in 2013.

<span class="mw-page-title-main">Fat-Free Framework</span>

Fat-Free Framework is an open-source web framework distributed under the GNU General Public License and hosted by GitHub and SourceForge. The software seeks to combine a full featureset with a lightweight code base while being easy to learn, use and extend.

<span class="mw-page-title-main">Apache Spark</span> Open-source data analytics cluster computing framework

Apache Spark is an open-source unified analytics engine for large-scale data processing. Spark provides an interface for programming clusters with implicit data parallelism and fault tolerance. Originally developed at the University of California, Berkeley's AMPLab, the Spark codebase was later donated to the Apache Software Foundation, which has maintained it since.

<span class="mw-page-title-main">Naemon</span> Open-Source Computer System Monitoring Software

Naemon is an open-source computer system monitoring, network monitoring and infrastructure monitoring software application. Naemon offers monitoring and alerting services for servers, switches, applications, and services. It alerts the users when things go wrong and alerts them a second time when the problem has been resolved. Naemon was created in 2014 as a fork of Nagios.

<span class="mw-page-title-main">Octopussy (software)</span> Log analysis software

Octopussy, also known as 8Pussy, is a free and open-source computer-software which monitors systems, by constantly analyzing the syslog data they generate and transmit to such a central Octopussy server. Therefore, software like Octopussy plays an important role in maintaining an information security management system within ISO/IEC 27001-compliant environments.

<span class="mw-page-title-main">Alyvix</span> IT monitoring software

Alyvix is an open source software application developed in Python for System monitoring and IT monitoring, synthetic monitoring and application performance management on Windows computers. It is used for visually monitoring fixed applications, streamed and cloud applications, and websites, as well as for robotic process automation.

References

  1. "Releases" . Retrieved 25 March 2024 via GitHub.
  2. Gewirtz, David (2019-04-11). "What's in a name? These DevOps tools come with strange backstories 6 - Page 6". ZDNet . Archived from the original on 2019-07-11. Retrieved 2019-07-11.
  3. Asay, Matt (6 May 2009). "Open-source working as advertised: ICINGA forks Nagios". CNET.
  4. 1 2 "Why a fork? - Icinga: Open Source Monitoring". Icinga. Archived from the original on 2012-03-08. Retrieved 2013-03-12.
  5. Khamlichi, M.el. "ICINGA – An Advanced Opensource Monitoring Tool". Tutorial. Unixmen. Archived from the original on 2012-08-10. Retrieved 2012-11-04.
  6. "Open Source Monitoring: Icinga vs Nagios Sos open source". Sosopensource.com. 2010-11-25. Retrieved 2013-03-12.
  7. Benthin, Falko (2010). "Monitoring network computers with the Icinga Nagios fork". Admin Network & Security (1).
  8. Icinga/icinga2, Icinga, 2024-10-09, retrieved 2024-10-12
  9. "– Zulu-English online dictionary". Isizulu.net. Retrieved 2013-03-12.
  10. "A lesson in Zulu: "Icinga" - "Eee-Chingaa", "Aye-Singa", 'c', 'see', 'g', 'ng - Icinga: Open Source Monitoring". Icinga. 2010-11-03. Archived from the original on 2010-11-10. Retrieved 2013-03-12.
  11. 1 2 3 Mobily, Tony (27 April 2012). "Nagios Vs. Icinga: the real story of one of the most heated forks in free software". Free Software Magazine. Archived from the original on 15 September 2017. Retrieved 3 November 2012.
  12. "3 years old & 100,000 downloads! - Icinga, Classic, Doctrine - Icinga: Open Source Monitoring". Icinga. 2012-05-06. Archived from the original on 2012-05-17. Retrieved 2013-03-12.
  13. "Icinga 2 v.0.0.1 released! - What the hell is Icinga 2, download Icinga 2 the first technology preview v001 off Sourceforge now, What about Icinga 1x, testing, Development Roa". Icinga.org. 2012-10-25. Archived from the original on 2014-07-24. Retrieved 2013-03-12.
  14. "Icinga 2.0 has arrived". Icinga.org. 2014-06-16. Archived from the original on 2014-07-01. Retrieved 2014-09-03.
  15. "Citunius Notifier® for Icinga - Citunius GmbH". www.citunius.de. Retrieved 2017-11-25.
  16. Henning, Edward (6 December 2011). "Nagios fork Icinga 1.6 records SLA information". The H Open.
  17. "Intro - Icinga 2 - Icinga Wiki". Wiki.icinga.org. 2012-10-18. Archived from the original on 2013-09-27. Retrieved 2013-03-12.
  18. "Features - Icinga: Open Source Monitoring". Icinga. Archived from the original on 2013-09-27. Retrieved 2013-09-29.
  19. "Mobile - Icinga: Open Source Monitoring". Icinga. Archived from the original on 2013-01-27. Retrieved 2013-03-12.
  20. "Users - Icinga: Open Source Monitoring". Icinga. Archived from the original on 2013-03-02. Retrieved 2013-03-12.