From 51b3d88d222a6f7f49f0b4a3ebf62d14b6f7cb26 Mon Sep 17 00:00:00 2001 From: "Alexander A. Klimov" Date: Wed, 9 Dec 2020 12:32:09 +0100 Subject: [PATCH] Docs: enable syntax highlighting refs #8146 --- CONTRIBUTING.md | 65 +++--- RELEASE.md | 44 ++-- doc/02-installation.md | 166 +++++++-------- doc/03-monitoring-basics.md | 12 +- doc/05-service-monitoring.md | 18 +- doc/06-distributed-monitoring.md | 14 +- doc/07-agent-based-monitoring.md | 10 +- doc/11-cli-commands.md | 24 +-- doc/12-icinga2-api.md | 347 ++++++++++++++++--------------- doc/13-addons.md | 14 +- doc/14-features.md | 58 +++--- doc/15-troubleshooting.md | 121 +++++------ doc/16-upgrading-icinga-2.md | 20 +- doc/19-technical-concepts.md | 14 +- doc/20-script-debugger.md | 16 +- doc/21-development.md | 225 ++++++++++---------- doc/22-selinux.md | 56 ++--- 17 files changed, 621 insertions(+), 603 deletions(-) diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index b6729fa3d..ced22a354 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -43,20 +43,20 @@ Please continue reading in the following sections for a step by step guide. [Fork the project](https://help.github.com/articles/fork-a-repo/) to your GitHub account and clone the repository: -``` +```bash git clone git@github.com:dnsmichi/icinga2.git cd icinga2 ``` Add a new remote `upstream` with this repository as value. -``` +```bash git remote add upstream https://github.com/icinga/icinga2.git ``` You can pull updates to your fork's master branch: -``` +```bash git fetch --all git pull upstream HEAD ``` @@ -71,7 +71,7 @@ Generally a branch name should include a topic such as `bugfix` or `feature` fol by a description and an issue number if applicable. Branches should have only changes relevant to a specific issue. -``` +```bash git checkout -b bugfix/service-template-typo-1234 git checkout -b feature/config-handling-1235 ``` @@ -116,7 +116,7 @@ Don't worry, you can squash those changes into a single commit later on. Once you've commited your changes, please update your local master branch and rebase your bugfix/feature branch against it before submitting a PR. -``` +```bash git checkout master git pull upstream HEAD @@ -128,12 +128,14 @@ Once you've resolved any conflicts, push the branch to your remote repository. It might be necessary to force push after rebasing - use with care! New branch: -``` + +```bash git push --set-upstream origin bugfix/notifications ``` Existing branch: -``` + +```bash git push -f origin bugfix/notifications ``` @@ -162,7 +164,7 @@ developers might ask you to rebase your PR. First off, fetch and pull `upstream` master. -``` +```bash git checkout master git fetch --all git pull upstream HEAD @@ -170,7 +172,7 @@ git pull upstream HEAD Then change to your working branch and start rebasing it against master: -``` +```bash git checkout bugfix/notifications git rebase master ``` @@ -187,21 +189,21 @@ Edit the file and search for `>>>`. Fix, build, test and save as needed. Add the modified file(s) and continue rebasing. -``` +```bash git add path/to/conflict.cpp git rebase --continue ``` Once succeeded ensure to push your changed history remotely. -``` +```bash git push -f origin bugfix/notifications ``` If you fear to break things, do the rebase in a backup branch first and later replace your current branch. -``` +```bash git checkout bugfix/notifications git checkout -b bugfix/notifications-rebase @@ -225,7 +227,7 @@ Say you want to squash the last 3 commits in your branch into a single one. Start an interactive (`-i`) rebase from current HEAD minus three commits (`HEAD~3`). -``` +```bash git rebase -i HEAD~3 ``` @@ -239,7 +241,7 @@ squash b37fd5377 Doc updates Save and let rebase to its job. Then force push the changes to the remote origin. -``` +```bash git push -f origin bugfix/notifications ``` @@ -267,19 +269,19 @@ The documentation is written in GitHub flavored [Markdown](https://guides.github It is located in the `doc/` directory and can be edited with your preferred editor. You can also edit it online on GitHub. -``` +```bash vim doc/2-getting-started.md ``` In order to review and test changes, you can install the [mkdocs](https://www.mkdocs.org) Python library. -``` +```bash pip install mkdocs ``` This allows you to start a local mkdocs viewer instance on http://localhost:8000 -``` +```bash mkdocs serve ``` @@ -288,7 +290,7 @@ Changes on the chapter layout can be done inside the `mkdocs.yml` file in the ma There also is a script to ensure that relative URLs to other sections are updated. This script also checks for broken URLs. -``` +```bash ./doc/update-links.py doc/*.md ``` @@ -335,7 +337,7 @@ Your patch should consist of 2 parts: Create a new fix or feature branch and start your work. -``` +```bash git checkout -b feature/itl-check-printer ``` @@ -344,14 +346,14 @@ git checkout -b feature/itl-check-printer There already exists a defined structure for contributed plugins. Navigate to `itl/plugins-contrib.d` and verify where your command definitions fits into. -``` +```bash cd itl/plugins-contrib.d/ ls ``` If you want to add or modify an existing Monitoring Plugin please use `itl/command-plugins.conf` instead. -``` +```bash vim itl/command-plugins-conf ``` @@ -359,7 +361,7 @@ vim itl/command-plugins-conf Just edit it, and add your CheckCommand definition. -``` +```bash vim operating-system.conf ``` @@ -369,8 +371,8 @@ Proceed to the documentation. Create a new file with .conf suffix. -``` - $ vim printer.conf +```bash +vim printer.conf ``` Add the file to `itl/CMakeLists.txt` in the FILES line in **alpha-numeric order**. @@ -385,7 +387,7 @@ vim CMakeLists.txt Add the newly created file to your git commit. -``` +```bash git add printer.conf ``` @@ -396,7 +398,7 @@ Do not commit it yet but finish with the documentation. Edit the documentation file in the `doc/` directory. More details on documentation updates can be found [here](CONTRIBUTING.md#contributing-documentation). -``` +```bash vim doc/10-icinga-template-library.md ``` @@ -424,9 +426,10 @@ Explain its purpose and possible enhancements/shortcomings. refs #existingticketnumberifany ``` + Push the branch to the remote origin and create a [pull request](https://help.github.com/articles/using-pull-requests/). -``` +```bash git push --set-upstream origin feature/itl-check-printer hub pull-request ``` @@ -464,14 +467,14 @@ At the bottom it says "Add more commits by pushing to the bugfix/persistent-comm First off, add the remote repository as additional origin and fetch its content: -``` +```bash git remote add theflyingcorpse https://github.com/TheFlyingCorpse/icinga2 git fetch --all ``` Checkout the mentioned remote branch into a local branch (Note: `theflyingcorpse` is the name of the remote): -``` +```bash git checkout theflyingcorpse/bugfix/persistent-comments-are-not-persistent -b bugfix/persistent-comments-are-not-persistent ``` @@ -480,12 +483,12 @@ Rebase, amend, squash or add your own commits on top. Once you are satisfied, push the changes to the remote `theflyingcorpse` and its branch `bugfix/persistent-comments-are-not-persistent`. The syntax here is `git push :`. -``` +```bash git push theflyingcorpse bugfix/persistent-comments-are-not-persistent:bugfix/persistent-comments-are-not-persistent ``` In case you've changed the commit history (rebase, amend, squash), you'll need to force push. Be careful, this can't be reverted! -``` +```bash git push -f theflyingcorpse bugfix/persistent-comments-are-not-persistent:bugfix/persistent-comments-are-not-persistent ``` diff --git a/RELEASE.md b/RELEASE.md index 9b3ee7f39..9fb4bccc5 100644 --- a/RELEASE.md +++ b/RELEASE.md @@ -24,7 +24,7 @@ Specify the release version. -``` +```bash VERSION=2.11.0 ``` @@ -53,7 +53,7 @@ master branch which should be part of this release. Update the version: -``` +```bash perl -pi -e "s/Version: .*/Version: $VERSION/g" VERSION ``` @@ -65,26 +65,26 @@ issues/PRs. At the start include a link to the milestone's closed issues. ## Git Tag -``` +```bash git commit -v -a -m "Release version $VERSION" ``` Create a signed tag (tags/v) on the `master` branch (for major releases) or the `support` branch (for minor releases). -``` +```bash git tag -s -m "Version $VERSION" v$VERSION ``` Push the tag: -``` +```bash git push origin v$VERSION ``` **For major releases:** Create a new `support` branch: -``` +```bash git checkout master git push @@ -95,32 +95,32 @@ git push -u origin support/2.12 ## Package Builds -``` +```bash mkdir $HOME/dev/icinga/packaging cd $HOME/dev/icinga/packaging ``` ### RPM Packages -``` +```bash git clone git@git.icinga.com:packaging/rpm-icinga2.git && cd rpm-icinga2 ``` ### DEB Packages -``` +```bash git clone git@git.icinga.com:packaging/deb-icinga2.git && cd deb-icinga2 ``` #### Raspbian Packages -``` +```bash git clone git@git.icinga.com:packaging/raspbian-icinga2.git && cd raspbian-icinga2 ``` ### Windows Packages -``` +```bash git clone git@git.icinga.com:packaging/windows-icinga2.git && cd windows-icinga2 ``` @@ -146,7 +146,7 @@ variables: Commit the change. -``` +```bash git commit -av -m "Switch build type for 2.13" ``` @@ -191,7 +191,7 @@ perl -pi -e "s/^ ICINGA_FORCE_VERSION: .*/ ICINGA_FORCE_VERSION: v$VERSION/g" Commit the changes and push the branch. -``` +```bash git commit -av -m "Release $VERSION-1" git push origin 2.11 ``` @@ -218,14 +218,14 @@ tag the release commit and push it. RPM/DEB/Raspbian: -``` +```bash git tag -s $VERSION-1 -m "Release v$VERSION-1" git push origin $VERSION-1 ``` Windows: -``` +```bash git tag -s $VERSION -m "Release v$VERSION" git push origin $VERSION ``` @@ -258,7 +258,7 @@ are triggered and automatically published to packages.icinga.com ### CentOS -``` +```bash docker run -ti centos:7 bash yum -y install https://packages.icinga.com/epel/icinga-rpm-release-7-latest.noarch.rpm @@ -269,7 +269,7 @@ icinga2 daemon -C ### Ubuntu -``` +```bash docker run -ti ubuntu:bionic bash apt-get update @@ -336,7 +336,7 @@ Navigate to `puppet-customer/icinga.git` and do the following steps: #### Testing -``` +```bash git checkout testing && git pull vim files/var/www/docs/config/icinga2-latest.yml @@ -347,7 +347,7 @@ git push SSH into the webserver and do a manual Puppet dry run with the testing environment. -``` +```bash puppet agent -t --environment testing --noop ``` @@ -355,7 +355,7 @@ Once succeeded, continue with production deployment. #### Production -``` +```bash git checkout master && git pull git merge testing git push @@ -363,7 +363,7 @@ git push SSH into the webserver and do a manual Puppet run from the production environment (default). -``` +```bash puppet agent -t ``` @@ -371,7 +371,7 @@ puppet agent -t SSH into the webserver or ask @bobapple. -``` +```bash cd /usr/local/icinga-docs-tools && ./build-docs.rb -c /var/www/docs/config/icinga2-latest.yml ``` diff --git a/doc/02-installation.md b/doc/02-installation.md index a4ab04ac1..745c4f03b 100644 --- a/doc/02-installation.md +++ b/doc/02-installation.md @@ -51,7 +51,7 @@ The following commands must be executed with `root` permissions unless noted oth Debian: -``` +```bash apt-get update apt-get -y install apt-transport-https wget gnupg @@ -68,7 +68,7 @@ apt-get update Ubuntu: -``` +```bash apt-get update apt-get -y install apt-transport-https wget gnupg @@ -85,7 +85,7 @@ apt-get update Raspbian Buster: -``` +```bash apt-get update apt-get -y install apt-transport-https wget gnupg @@ -108,7 +108,7 @@ apt-get update Debian Stretch: -``` +```bash DIST=$(awk -F"[)(]+" '/VERSION=/ {print $2}' /etc/os-release); \ echo "deb https://deb.debian.org/debian ${DIST}-backports main" > \ /etc/apt/sources.list.d/${DIST}-backports.list @@ -120,25 +120,25 @@ apt-get update RHEL/CentOS 8: -``` +```bash dnf install https://packages.icinga.com/epel/icinga-rpm-release-8-latest.noarch.rpm ``` RHEL/CentOS 7: -``` +```bash yum install https://packages.icinga.com/epel/icinga-rpm-release-7-latest.noarch.rpm ``` RHEL/CentOS 6 x64: -``` +```bash yum install https://packages.icinga.com/epel/icinga-rpm-release-6-latest.noarch.rpm ``` Fedora 31: -``` +```bash dnf install https://packages.icinga.com/fedora/icinga-rpm-release-31-latest.noarch.rpm ``` @@ -149,7 +149,7 @@ as part of the [EPEL repository](https://fedoraproject.org/wiki/EPEL). CentOS 8 additionally needs the PowerTools repository for EPEL: -``` +```bash dnf install 'dnf-command(config-manager)' dnf config-manager --set-enabled PowerTools @@ -158,7 +158,7 @@ dnf install epel-release CentOS 7/6: -``` +```bash yum install epel-release ``` @@ -167,7 +167,7 @@ repository before installing the [EPEL rpm package](https://fedoraproject.org/wi RHEL 8: -``` +```bash ARCH=$( /bin/arch ) subscription-manager repos --enable rhel-8-server-optional-rpms @@ -178,14 +178,14 @@ dnf install https://dl.fedoraproject.org/pub/epel/epel-release-latest-8.noarch.r RHEL 7: -``` +```bash subscription-manager repos --enable rhel-7-server-optional-rpms yum install https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm ``` RHEL 6: -``` +```bash subscription-manager repos --enable rhel-6-server-optional-rpms yum install https://dl.fedoraproject.org/pub/epel/epel-release-latest-6.noarch.rpm ``` @@ -197,7 +197,7 @@ since v2.11. SLES 15/12: -``` +```bash rpm --import https://packages.icinga.com/icinga.key zypper ar https://packages.icinga.com/SUSE/ICINGA-release.repo @@ -206,7 +206,7 @@ zypper ref openSUSE: -``` +```bash rpm --import https://packages.icinga.com/icinga.key zypper ar https://packages.icinga.com/openSUSE/ICINGA-release.repo @@ -215,7 +215,7 @@ zypper ref #### Alpine Linux Repositories -``` +```bash echo "http://dl-cdn.alpinelinux.org/alpine/edge/main" >> /etc/apk/repositories echo "http://dl-cdn.alpinelinux.org/alpine/edge/community" >> /etc/apk/repositories apk update @@ -234,13 +234,13 @@ with `root` permissions unless noted otherwise. Debian/Ubuntu: -``` +```bash apt-get install icinga2 ``` RHEL/CentOS 8 and Fedora: -``` +```bash dnf install icinga2 systemctl enable icinga2 systemctl start icinga2 @@ -248,7 +248,7 @@ systemctl start icinga2 RHEL/CentOS 7: -``` +```bash yum install icinga2 systemctl enable icinga2 systemctl start icinga2 @@ -256,7 +256,7 @@ systemctl start icinga2 RHEL/CentOS 6: -``` +```bash yum install icinga2 chkconfig icinga2 on service icinga2 start @@ -264,19 +264,19 @@ service icinga2 start SLES/openSUSE: -``` +```bash zypper install icinga2 ``` FreeBSD: -``` +```bash pkg install icinga2 ``` Alpine Linux: -``` +```bash apk add icinga2 ``` @@ -316,7 +316,7 @@ to determine where to find the plugin binaries. ### Debian/Ubuntu -``` +```bash apt-get install monitoring-plugins ``` @@ -327,19 +327,19 @@ as part of the [EPEL repository](02-installation.md#package-repositories-rhel-ep RHEL/CentOS 8: -``` +```bash dnf install nagios-plugins-all ``` RHEL/CentOS 7/6: -``` +```bash yum install nagios-plugins-all ``` Fedora: -``` +```bash dnf install nagios-plugins-all ``` @@ -349,19 +349,19 @@ The packages for SLES/OpenSUSE depend on other packages which are distributed as part of the [server:monitoring repository](https://build.opensuse.org/project/repositories/server:monitoring). Please make sure to enable this repository beforehand. -``` +```bash zypper install monitoring-plugins ``` ### FreeBSD -``` +```bash pkg install monitoring-plugins ``` ### Alpine Linux -``` +```bash apk add monitoring-plugins ``` @@ -423,7 +423,7 @@ Job for icinga2.service failed. See 'systemctl status icinga2.service' and 'jour If you're stuck with configuration errors, you can manually invoke the [configuration validation](11-cli-commands.md#config-validation). -``` +```bash icinga2 daemon -C ``` @@ -462,7 +462,7 @@ using the init script. Using Debian packages the user and group are set to On FreeBSD you need to enable icinga2 in your rc.conf -``` +```bash sysrc icinga2_enable=yes service icinga2 restart @@ -480,13 +480,13 @@ which confines Icinga 2 including enabled features and running commands. RHEL/CentOS 8 and Fedora: -``` +```bash dnf install icinga2-selinux ``` RHEL/CentOS 7: -``` +```bash yum install icinga2-selinux ``` @@ -514,25 +514,25 @@ Info: installing removed addon 'icinga2' to /var/lib/vim/addons RHEL/CentOS 8 and Fedora: -``` +```bash dnf install vim-icinga2 ``` RHEL/CentOS 7/6: -``` +```bash yum install vim-icinga2 ``` SLES/openSUSE: -``` +```bash zypper install vim-icinga2 ``` Alpine Linux: -``` +```bash apk add icinga2-vim ``` @@ -546,8 +546,8 @@ syntax on Test it: -``` -# vim /etc/icinga2/conf.d/templates.conf +```bash +vim /etc/icinga2/conf.d/templates.conf ``` ![Vim with syntax highlighting](images/installation/vim-syntax.png "Vim with Icinga 2 syntax highlighting") @@ -563,26 +563,26 @@ Debian/Ubuntu: RHEL/CentOS 8 and Fedora: -``` +```bash dnf install nano-icinga2 ``` RHEL/CentOS 7/6: -``` +```bash yum install nano-icinga2 ``` SLES/openSUSE: -``` +```bash zypper install nano-icinga2 ``` Copy the `/etc/nanorc` sample file to your home directory. -``` -$ cp /etc/nanorc ~/.nanorc +```bash +cp /etc/nanorc ~/.nanorc ``` Include the `icinga2.nanorc` file. @@ -596,8 +596,8 @@ include "/usr/share/nano/icinga2.nanorc" Test it: -``` -$ nano /etc/icinga2/conf.d/templates.conf +```bash +nano /etc/icinga2/conf.d/templates.conf ``` ![Nano with syntax highlighting](images/installation/nano-syntax.png "Nano with Icinga 2 syntax highlighting") @@ -624,7 +624,7 @@ exporting all configuration and status information into a database. Debian/Ubuntu: -``` +```bash apt-get install mariadb-server mariadb-client mysql_secure_installation @@ -632,7 +632,7 @@ mysql_secure_installation RHEL/CentOS and Fedora: -``` +```bash yum install mariadb-server mariadb systemctl enable mariadb systemctl start mariadb @@ -641,7 +641,7 @@ mysql_secure_installation SUSE: -``` +```bash zypper install mysql mysql-client chkconfig mysqld on service mysqld start @@ -649,7 +649,7 @@ service mysqld start FreeBSD: -``` +```bash pkg install mysql56-server sysrc mysql_enable=yes service mysql-server restart @@ -658,7 +658,7 @@ mysql_secure_installation Alpine Linux: -``` +```bash apk add mariadb rc-service mariadb setup rc-update add mariadb default @@ -672,19 +672,19 @@ distribution's package manager. Debian/Ubuntu: -``` +```bash apt-get install icinga2-ido-mysql ``` RHEL/CentOS: -``` +```bash yum install icinga2-ido-mysql ``` SUSE: -``` +```bash zypper install icinga2-ido-mysql ``` @@ -721,7 +721,7 @@ quit After creating the database you can import the Icinga 2 IDO schema using the following command. Enter the root password into the prompt when asked. -``` +```bash mysql -u root -p icinga < /usr/share/icinga2-ido-mysql/schema/mysql.sql ``` @@ -746,13 +746,13 @@ Make sure to restart Icinga 2 for these changes to take effect. Restart Icinga 2. -``` +```bash systemctl restart icinga2 ``` Alpine Linux: -``` +```bash rc-service icinga2 restart ``` @@ -764,13 +764,13 @@ Continue with the [webserver setup](02-installation.md#icinga2-user-interface-we Debian/Ubuntu: -``` +```bash apt-get install postgresql ``` RHEL/CentOS: -``` +```bash yum install postgresql-server postgresql postgresql-setup initdb systemctl enable postgresql @@ -779,7 +779,7 @@ systemctl start postgresql SUSE: -``` +```bash zypper install postgresql postgresql-server chkconfig postgresql on service postgresql initdb @@ -788,7 +788,7 @@ service postgresql start FreeBSD: -``` +```bash pkg install postgresql93-server sysrc postgresql_enable=yes service postgresql initdb @@ -797,7 +797,7 @@ service postgresql start Alpine Linux: -``` +```bash apk add postgresql rc-update add postgresql default rc-service postgresql setup @@ -811,19 +811,19 @@ distribution's package manager. Debian/Ubuntu: -``` +```bash apt-get install icinga2-ido-pgsql ``` RHEL/CentOS: -``` +```bash yum install icinga2-ido-pgsql ``` SUSE: -``` +```bash zypper install icinga2-ido-pgsql ``` @@ -847,7 +847,7 @@ and located at `/usr/share/icinga2-ido-pgsql/schema/pgsql.sql`. Set up a PostgreSQL database for Icinga 2: -``` +```bash cd /tmp sudo -u postgres psql -c "CREATE ROLE icinga WITH LOGIN PASSWORD 'icinga'" sudo -u postgres createdb -O icinga -E UTF8 icinga @@ -875,7 +875,7 @@ host all all 127.0.0.1/32 ident host all all ::1/128 ident ``` -``` +```bash systemctl restart postgresql ``` @@ -883,7 +883,7 @@ systemctl restart postgresql After creating the database and permissions you need to import the IDO database schema using the following command: -``` +```bash export PGPASSWORD=icinga psql -U icinga -d icinga < /usr/share/icinga2-ido-pgsql/schema/pgsql.sql ``` @@ -912,13 +912,13 @@ Make sure to restart Icinga 2 for these changes to take effect. Restart Icinga 2. -``` +```bash systemctl restart icinga2 ``` Alpine Linux: -``` +```bash rc-service icinga2 restart ``` @@ -937,13 +937,13 @@ documentation. Debian/Ubuntu: -``` +```bash apt-get install apache2 ``` RHEL/CentOS/Fedora: -``` +```bash yum install httpd systemctl enable httpd systemctl start httpd @@ -951,7 +951,7 @@ systemctl start httpd SUSE: -``` +```bash zypper install apache2 chkconfig apache2 on service apache2 start @@ -959,7 +959,7 @@ service apache2 start FreeBSD (Nginx, but you could also use the `apache24` package): -``` +```bash pkg install nginx php56-gettext php56-ldap php56-openssl php56-mysql php56-pdo_mysql php56-pgsql php56-pdo_pgsql php56-sockets php56-gd pecl-imagick pecl-intl sysrc php_fpm_enable=yes sysrc nginx_enable=yes @@ -973,7 +973,7 @@ service nginx start Alpine Linux: -``` +```bash apk add apache2 php7-apache2 sed -i -e "s/^#LoadModule rewrite_module/LoadModule rewrite_module/" /etc/apache2/httpd.conf rc-update add apache2 default @@ -986,14 +986,14 @@ Enable port 80 (http). Best practice is to only enable port 443 (https) and use firewall-cmd: -``` +```bash firewall-cmd --add-service=http firewall-cmd --permanent --add-service=http ``` iptables: -``` +```bash iptables -A INPUT -p tcp -m tcp --dport 80 -j ACCEPT service iptables save ``` @@ -1012,7 +1012,7 @@ You can run the CLI command `icinga2 api setup` to enable the certificates as well as a new API user `root` with an auto-generated password in the `/etc/icinga2/conf.d/api-users.conf` configuration file: -``` +```bash icinga2 api setup ``` @@ -1030,13 +1030,13 @@ object ApiUser "icingaweb2" { Restart Icinga 2 to activate the configuration. -``` +```bash systemctl restart icinga2 ``` Alpine Linux: -``` +```bash rc-service icinga2 restart ``` @@ -1169,13 +1169,13 @@ Make sure to restart Icinga 2 for these changes to take effect. Restart Icinga 2. -``` +```bash systemctl restart icinga2 ``` Alpine Linux: -``` +```bash rc-service icinga2 restart ``` diff --git a/doc/03-monitoring-basics.md b/doc/03-monitoring-basics.md index e210b1517..bcfe55343 100644 --- a/doc/03-monitoring-basics.md +++ b/doc/03-monitoring-basics.md @@ -2244,7 +2244,7 @@ The service specifies the [custom variable](03-monitoring-basics.md#custom-varia This results in this command line without the `--process` parameter: -``` +```bash '/bin/icingacli' 'businessprocess' 'process' 'check' 'bp-shop-web' ``` @@ -2272,7 +2272,7 @@ This can be used for the following scenarios: Whenever a host/service object sets the `http_sni` [custom variable](03-monitoring-basics.md#custom-variables) to `true`, the parameter is added to the command line. -``` +```bash '/usr/lib64/nagios/plugins/check_http' '--sni' ``` @@ -2311,7 +2311,7 @@ object Host "postgresql-cluster" { ... use the following command line: -``` +```bash '/usr/lib64/nagios/plugins/check_postgres.pl' '-H' '192.168.56.200' ``` @@ -2454,7 +2454,7 @@ object CheckCommand "mysql" { The executed command line visible with `ps` or `top` looks like this and hides the database credentials in the user's environment. -``` +```bash /usr/lib/nagios/plugins/check_mysql -H 192.168.56.101 -d icinga ``` @@ -2912,14 +2912,14 @@ object Service "businessprocess" { In order to test this scenario you can run: -``` +```bash nc -l 8080 ``` This allows to catch the web request. You can also enable the [debug log](15-troubleshooting.md#troubleshooting-enable-debug-output) and search for the event command execution log message. -``` +```bash tail -f /var/log/icinga2/debug.log | grep EventCommand ``` diff --git a/doc/05-service-monitoring.md b/doc/05-service-monitoring.md index cef5fc801..49343616e 100644 --- a/doc/05-service-monitoring.md +++ b/doc/05-service-monitoring.md @@ -53,13 +53,13 @@ by trying to run it on the console using whichever user Icinga 2 is running as: RHEL/CentOS/Fedora -``` +```bash sudo -u icinga /usr/lib64/nagios/plugins/check_mysql_health --help ``` Debian/Ubuntu -``` +```bash sudo -u nagios /usr/lib/nagios/plugins/check_mysql_health --help ``` @@ -123,7 +123,7 @@ and reference this in the created CheckCommand objects. Create a common directory e.g. `/opt/monitoring/plugins` and install the plugin there. -``` +```bash mkdir -p /opt/monitoring/plugins cp check_snmp_int.pl /opt/monitoring/plugins chmod +x /opt/monitoring/plugins/check_snmp_int.pl @@ -155,7 +155,7 @@ with the required parameters first. Example for database size checks with [check_mysql_health](10-icinga-template-library.md#plugin-contrib-command-mysql_health). -``` +```bash /usr/lib64/nagios/plugins/check_mysql_health --hostname '127.0.0.1' --username root --password icingar0xx --mode sql --name 'select sum(data_length + index_length) / 1024 / 1024 from information_schema.tables where table_schema = '\''icinga'\'';' '--name2' 'db_size' --units 'MB' --warning 4096 --critical 8192 ``` @@ -520,7 +520,7 @@ add them to the argument parser. Example for Python: -``` +```python import argparse import signal import sys @@ -538,7 +538,7 @@ Users might call plugins only with the critical threshold parameter, leaving out the warning parameter. Keep this in mind when evaluating the thresholds, always check if the parameters have been defined before. -``` +```python if args.critical: if ptc_value > args.critical: print("CRITICAL - ...") @@ -693,7 +693,7 @@ and provide a clear message followed by the Unknown state. Example in Python taken from [check_tinkerforge](https://github.com/NETWAYS/check_tinkerforge/blob/master/check_tinkerforge.py): -``` +```python import argparse import signal import sys @@ -721,7 +721,7 @@ too old or new versions on the community support channels. Example in Python taken from [check_tinkerforge](https://github.com/NETWAYS/check_tinkerforge/blob/master/check_tinkerforge.py): -``` +```python import argparse import signal import sys @@ -745,7 +745,7 @@ the plugin. Example in Python taken from [check_tinkerforge](https://github.com/NETWAYS/check_tinkerforge/blob/master/check_tinkerforge.py): -``` +```python import argparse import signal import sys diff --git a/doc/06-distributed-monitoring.md b/doc/06-distributed-monitoring.md index 2adc594b5..4930f7ab2 100644 --- a/doc/06-distributed-monitoring.md +++ b/doc/06-distributed-monitoring.md @@ -148,7 +148,7 @@ and `accept_config` can be configured here. In order to use the `api` feature you need to enable it and restart Icinga 2. -``` +```bash icinga2 feature enable api ``` @@ -3012,8 +3012,8 @@ have the `checker` feature enabled. Example: -``` -# icinga2 feature enable checker +```bash +icinga2 feature enable checker ``` All nodes in the same zone load-balance the check execution. If one instance shuts down, @@ -3026,8 +3026,8 @@ have the `notification` feature enabled. Example: -``` -# icinga2 feature enable notification +```bash +icinga2 feature enable notification ``` Notifications are load-balanced amongst all nodes in a zone. By default this functionality @@ -3043,8 +3043,8 @@ have the DB IDO feature enabled. Example DB IDO MySQL: -``` -# icinga2 feature enable ido-mysql +```bash +icinga2 feature enable ido-mysql ``` By default the DB IDO feature only runs on one node. All other nodes in the same zone disable diff --git a/doc/07-agent-based-monitoring.md b/doc/07-agent-based-monitoring.md index c911904f6..7a1a73afa 100644 --- a/doc/07-agent-based-monitoring.md +++ b/doc/07-agent-based-monitoring.md @@ -73,7 +73,7 @@ CheckCommand already. SSH key pair for the Icinga daemon user. In case the user has no shell, temporarily enable this. When asked for a passphrase, **do not set it** and press enter. -``` +```bash sudo su - icinga ssh-keygen -b 4096 -t rsa -C "icinga@$(hostname) user for check_by_ssh" -f $HOME/.ssh/id_rsa @@ -81,7 +81,7 @@ ssh-keygen -b 4096 -t rsa -C "icinga@$(hostname) user for check_by_ssh" -f $HOME On the remote agent, create the icinga user and generate a temporary password. -``` +```bash useradd -m icinga passwd icinga ``` @@ -90,7 +90,7 @@ Copy the public key from the Icinga server to the remote agent, e.g. with `ssh-c or manually into `/home/icinga/.ssh/authorized_keys`. This will ask for the password once. -``` +```bash sudo su - icinga ssh-copy-id -i $HOME/.ssh/id_rsa icinga@ssh-agent1.localdomain @@ -100,7 +100,7 @@ After the SSH key is copied, test at the connection **at least once** and accept the host key verification. If you forget about this step, checks will become UNKNOWN later. -``` +```bash ssh -i $HOME/.ssh/id_rsa icinga@ssh-agent1.localdomain ``` @@ -273,7 +273,7 @@ Create the `coldstart_reset_event.sh` shell script to pass the expanded variable data in. The `$service.state_id$` is important in order to prevent an endless loop of event firing after the service has been reset. -``` +```bash #!/bin/bash SERVICE_STATE_ID="" diff --git a/doc/11-cli-commands.md b/doc/11-cli-commands.md index 0e7175b36..2324ab764 100644 --- a/doc/11-cli-commands.md +++ b/doc/11-cli-commands.md @@ -75,28 +75,28 @@ You need to install the `bash-completion` package if not already installed. RHEL/CentOS/Fedora: -``` -# yum install bash-completion +```bash +yum install bash-completion ``` SUSE: -``` -# zypper install bash-completion +```bash +zypper install bash-completion ``` Debian/Ubuntu: -``` -# apt-get install bash-completion +```bash +apt-get install bash-completion ``` Ensure that the `bash-completion.d` directory is added to your shell environment. You can manually source the icinga2 bash-completion file into your current session and test it: -``` -# source /etc/bash-completion.d/icinga2 +```bash +source /etc/bash-completion.d/icinga2 ``` @@ -305,8 +305,8 @@ On operating systems without the `libedit` library installed there is no support for line-editing or a command history. However you can use the `rlwrap` program if you require those features: -``` -$ rlwrap icinga2 console +```bash +rlwrap icinga2 console ``` The debug console can be used to connect to a running Icinga 2 instance using @@ -725,8 +725,8 @@ Every time you have changed your configuration you should first tell Icinga 2 to [validate](11-cli-commands.md#config-validation). If there are no validation errors, you can safely reload the Icinga 2 daemon. -``` -# systemctl reload icinga2 +```bash +systemctl reload icinga2 ``` The `reload` action will send the `SIGHUP` signal to the Icinga 2 daemon diff --git a/doc/12-icinga2-api.md b/doc/12-icinga2-api.md index 0202eafc5..4f4eee374 100644 --- a/doc/12-icinga2-api.md +++ b/doc/12-icinga2-api.md @@ -23,14 +23,14 @@ You can run the CLI command `icinga2 api setup` to enable the certificates as well as a new API user `root` with an auto-generated password in the `/etc/icinga2/conf.d/api-users.conf` configuration file: -``` -# icinga2 api setup +```bash +icinga2 api setup ``` Make sure to restart Icinga 2 to enable the changes you just made: -``` -# systemctl restart icinga2 +```bash +systemctl restart icinga2 ``` If you prefer to set up the API manually, you will have to perform the following steps: @@ -96,7 +96,7 @@ list. Depending on the number of affected objects in your request, the The output will be sent back as a JSON object: -``` +```json { "results": [ { @@ -114,14 +114,14 @@ The output will be sent back as a JSON object: You can also use [jq](https://stedolan.github.io/jq/) or `python -m json.tool` in combination with curl on the CLI. -``` +```bash curl ... | jq curl ... | python -m json.tool ``` jq also has additional filter capabilities, as shown in [this blogpost](https://www.netways.de/blog/2018/08/24/json-in-bequem/). -``` +```bash curl ... |jq '{name: .results[].name}' ``` @@ -198,8 +198,8 @@ An `ApiUser` object can have both authentication methods configured. You can test authentication by sending a GET request to the API: -``` -$ curl -k -s -S -i -u root:icinga 'https://localhost:5665/v1' +```bash +curl -k -s -S -i -u root:icinga 'https://localhost:5665/v1' ``` In case you get an error message make sure to check the API user credentials. @@ -207,8 +207,8 @@ In case you get an error message make sure to check the API user credentials. When using client certificates for authentication you'll need to pass your client certificate and private key to the curl call: -``` -$ curl -k --cert example.localdomain.crt --key example.localdomain.key 'https://example.localdomain:5665/v1/status' +```bash +curl -k --cert example.localdomain.crt --key example.localdomain.key 'https://example.localdomain:5665/v1/status' ``` In case of an error make sure to verify the client certificate and CA. @@ -217,8 +217,8 @@ The curl parameter `-k` disables certificate verification and should therefore only be used for testing. In order to securely check each connection you'll need to specify the trusted CA certificate using the curl parameter`--cacert`: -``` -$ curl -u root:icinga --cacert ca.crt 'icinga2.node1.localdomain:5665/v1' +```bash +curl -u root:icinga --cacert ca.crt 'icinga2.node1.localdomain:5665/v1' ``` Read the next chapter on [API permissions](12-icinga2-api.md#icinga2-api-permissions) @@ -319,7 +319,7 @@ Example for a URL-encoded query string: Here are the exact same query parameters as a JSON object: -``` +```json { "filter": "match(\"example.localdomain*\",host.name)", "attrs": [ "host.name", "host.state" ] } ``` @@ -349,7 +349,7 @@ Example as URL parameter: Example as JSON object: -``` +```json { "pretty": true } ``` @@ -361,16 +361,16 @@ header. This comes in handy when you are using HTTP proxies disallowing `PUT` or Query an existing object by sending a `POST` request with `X-HTTP-Method-Override: GET` as request header: -``` -$ curl -k -s -S -i -u 'root:icinga' -H 'Accept: application/json' \ +```bash +curl -k -s -S -i -u 'root:icinga' -H 'Accept: application/json' \ -H 'X-HTTP-Method-Override: GET' -X POST \ 'https://localhost:5665/v1/objects/hosts' ``` Delete an existing object by sending a `POST` request with `X-HTTP-Method-Override: DELETE` as request header: -``` -$ curl -k -s -S -i -u 'root:icinga' -H 'Accept: application/json' \ +```bash +curl -k -s -S -i -u 'root:icinga' -H 'Accept: application/json' \ -H 'X-HTTP-Method-Override: DELETE' -X POST \ 'https://localhost:5665/v1/objects/hosts/example.localdomain' ``` @@ -378,7 +378,7 @@ $ curl -k -s -S -i -u 'root:icinga' -H 'Accept: application/json' \ Query objects with complex filters. For a detailed introduction into filter, please read the [following chapter](12-icinga2-api.md#icinga2-api-filters). -``` +```bash curl -k -s -S -i -u 'root:icinga' -H 'Accept: application/json' \ -H 'X-HTTP-Method-Override: GET' -X POST \ 'https://localhost:5665/v1/objects/services' \ @@ -481,8 +481,8 @@ Some queries can be performed for more than just one object type. One example is action which can be used for both hosts and services. When using advanced filters you will also have to specify the type using the `type` parameter: -``` -$ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' -X POST \ +```bash +curl -k -s -S -i -u root:icinga -H 'Accept: application/json' -X POST \ 'https://localhost:5665/v1/actions/reschedule-check' \ -d '{ "type": "Service", "filter": "service.name==\"ping6\"", "pretty": true }' ``` @@ -511,8 +511,8 @@ assign its value inside the `filter_vars` dictionary. That way you can also keep the `filter` string the same for different requests with only changing the `filter_vars`. -``` -$ curl -k -s -S -i -u 'root:icinga' -H 'Accept: application/json' \ +```bash +curl -k -s -S -i -u 'root:icinga' -H 'Accept: application/json' \ -H 'X-HTTP-Method-Override: GET' -X POST \ 'https://localhost:5665/v1/objects/hosts' \ -d '{ "filter": "group in host.groups", "filter_vars": { "group": "linux-servers" }, "pretty": true }' @@ -527,7 +527,7 @@ a URL parameter because there is no way to specify a dictionary in a URL. The example from [X-HTTP-Method-Override](12-icinga2-api.md#icinga2-api-requests-method-override) can be enhanced to avoid additional parameter value escaping. -``` +```bash curl -k -s -S -i -u 'root:icinga' -H 'Accept: application/json' \ -H 'X-HTTP-Method-Override: GET' -X POST \ 'https://localhost:5665/v1/objects/services' \ @@ -569,8 +569,8 @@ a `GET` query to the `/v1/objects/` URL endpoint. ` Use [X-HTTP-Method-Override](12-icinga2-api.md#icinga2-api-requests-method-override) > and pass everything in the request body like this: -``` -$ curl -k -s -S -i -u 'root:icinga' -H 'Accept: application/json' \ +```bash +curl -k -s -S -i -u 'root:icinga' -H 'Accept: application/json' \ -H 'X-HTTP-Method-Override: GET' -X POST \ 'https://localhost:5665/v1/objects/services' \ -d '{ "attrs": [ "display_name", "check_command" ], "joins": [ "host.name", "host.address" ], "filter": "host.vars.os==\"Linux\"", "pretty": true }' @@ -741,14 +741,14 @@ This is another example for listing all service objects which are unhandled prob and no downtime or acknowledgement set). We're using [X-HTTP-Method-Override](12-icinga2-api.md#icinga2-api-requests-method-override) here because we want to pass all query attributes in the request body. -``` -$ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ +```bash +curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ -H 'X-HTTP-Method-Override: GET' -X POST \ 'https://127.0.0.1:5665/v1/objects/services' \ -d '{ "joins": [ "host.name", "host.address" ], "attrs": [ "name", "state", "downtime_depth", "acknowledgement" ], "filter": "service.state != ServiceOK && service.downtime_depth == 0.0 && service.acknowledgement == 0.0", "pretty": true }' ``` -``` +```json { "results": [ { @@ -776,14 +776,14 @@ In order to list all acknowledgements without expire time, you query the `/v1/ob URL endpoint with `joins` and `filter` request parameters using the [X-HTTP-Method-Override](12-icinga2-api.md#icinga2-api-requests-method-override) method: -``` -$ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ +```bash +curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ -H 'X-HTTP-Method-Override: GET' -X POST \ 'https://localhost:5665/v1/objects/comments' \ -d '{ "joins": [ "service.name", "service.acknowledgement", "service.acknowledgement_expiry" ], "attrs": [ "author", "text" ], "filter": "service.acknowledgement!=0 && service.acknowledgement_expiry==0", "pretty": true }' ``` -``` +```json { "results": [ { @@ -828,13 +828,13 @@ If attributes are of the Dictionary type, you can also use the indexer format. T Example for creating the new host object `example.localdomain`: -``` -$ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ +```bash +curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ -X PUT 'https://localhost:5665/v1/objects/hosts/example.localdomain' \ -d '{ "templates": [ "generic-host" ], "attrs": { "address": "192.168.1.1", "check_command": "hostalive", "vars.os" : "Linux" }, "pretty": true }' ``` -``` +```json { "results": [ { @@ -849,13 +849,13 @@ If the configuration validation fails, the new object will not be created and th contains a detailed error message. The following example is missing the `check_command` attribute which is required for host objects: -``` -$ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ +```bash +curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ -X PUT 'https://localhost:5665/v1/objects/hosts/example.localdomain' \ -d '{ "attrs": { "address": "192.168.1.1", "vars.os" : "Linux" }, "pretty": true }' ``` -``` +```json { "results": [ { @@ -871,16 +871,16 @@ $ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ Service objects must be created using their full name ("hostname!servicename") referencing an existing host object: -``` -$ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ +```bash +curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ -X PUT 'https://localhost:5665/v1/objects/services/example.localdomain!realtime-load' \ -d '{ "templates": [ "generic-service" ], "attrs": { "check_command": "load", "check_interval": 1,"retry_interval": 1 } }' ``` Example for a new CheckCommand object: -``` -$ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ +```bash +curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ -X PUT 'https://localhost:5665/v1/objects/checkcommands/mytest' \ -d '{ "templates": [ "plugin-check-command" ], "attrs": { "command": [ "/usr/local/sbin/check_http" ], "arguments": { "-I": "$mytest_iparam$" } } }' ``` @@ -917,13 +917,13 @@ If attributes are of the [Dictionary](17-language-reference.md#dictionary) type, The following example updates the `address` attribute and the custom variable `os` for the `example.localdomain` host: -``` -$ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ +```bash +curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ -X POST 'https://localhost:5665/v1/objects/hosts/example.localdomain' \ -d '{ "attrs": { "address": "192.168.1.2", "vars.os" : "Windows" }, "pretty": true }' ``` -``` +```json { "results": [ { @@ -949,12 +949,12 @@ In addition to these parameters a [filter](12-icinga2-api.md#icinga2-api-filters Example for deleting the host object `example.localdomain`: -``` -$ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ +```bash +curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ -X DELETE 'https://localhost:5665/v1/objects/hosts/example.localdomain?cascade=1&pretty=1' ``` -``` +```json { "results": [ { @@ -987,8 +987,8 @@ notification on a program-wide basis must be applied by updating the [IcingaApplication object](12-icinga2-api.md#icinga2-api-config-objects) called `app`. -``` -$ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ +```bash +curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ -X POST 'https://localhost:5665/v1/objects/icingaapplications/app' \ -d '{ "attrs": { "enable_notifications": false } }' ``` @@ -998,8 +998,11 @@ $ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ If you don't want to write JSON manually, especially for adding the `start_time` and `end_time` parameters, you can use [jo](https://github.com/jpmens/jo) to format this. +```bash +jo -p pretty=true type=Service filter="service.name==\"ping4\"" author=icingaadmin comment="IPv4 network maintenance" fixed=true start_time=$(date +%s -d "+0 hour") end_time=$(date +%s -d "+1 hour") ``` -$ jo -p pretty=true type=Service filter="service.name==\"ping4\"" author=icingaadmin comment="IPv4 network maintenance" fixed=true start_time=$(date +%s -d "+0 hour") end_time=$(date +%s -d "+1 hour") + +```json { "pretty": true, "type": "Service", @@ -1014,8 +1017,8 @@ $ jo -p pretty=true type=Service filter="service.name==\"ping4\"" author=icingaa Now wrap this into the actual curl command: -``` -$ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ +```bash +curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ -X POST 'https://localhost:5665/v1/actions/schedule-downtime' \ -d "$(jo -p pretty=true type=Service filter="service.name==\"ping4\"" author=icingaadmin comment="IPv4 network maintanence" fixed=true start_time=$(date +%s -d "+0 hour") end_time=$(date +%s -d "+1 hour"))" ``` @@ -1043,13 +1046,13 @@ In addition to these parameters a [filter](12-icinga2-api.md#icinga2-api-filters Example for the service `passive-ping`: -``` -$ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ +```bash +curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ -X POST 'https://localhost:5665/v1/actions/process-check-result' \ -d '{ "type": "Service", "filter": "host.name==\"icinga2-master1.localdomain\" && service.name==\"passive-ping\"", "exit_status": 2, "plugin_output": "PING CRITICAL - Packet loss = 100%", "performance_data": [ "rta=5000.000000ms;3000.000000;5000.000000;0.000000", "pl=100%;80;100;0" ], "check_source": "example.localdomain", "pretty": true }' ``` -``` +```json { "results": [ { @@ -1064,8 +1067,8 @@ You can avoid URL encoding of white spaces in object names by using the `filter` Example for using the `Host` type and filter by the host name: -``` -$ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ +```bash +curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ -X POST 'https://localhost:5665/v1/actions/process-check-result' \ -d '{ "filter": "host.name==\"example.localdomain\"", "type": "Host", "exit_status": 1, "plugin_output": "Host is not available." }' ``` @@ -1094,13 +1097,13 @@ The example reschedules all services with the name "ping6" to immediately perfor (`next_check` default), ignoring any time periods or whether active checks are allowed for the service (`force=true`). -``` -$ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ +```bash +curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ -X POST 'https://localhost:5665/v1/actions/reschedule-check' \ -d '{ "type": "Service", "filter": "service.name==\"ping6\"", "force": true, "pretty": true }' ``` -``` +```json { "results": [ { @@ -1129,13 +1132,13 @@ In addition to these parameters a [filter](12-icinga2-api.md#icinga2-api-filters Example for a custom host notification announcing a global maintenance to host owners: -``` -$ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ +```bash +curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ -X POST 'https://localhost:5665/v1/actions/send-custom-notification' \ -d '{ "type": "Host", "author": "icingaadmin", "comment": "System is going down for maintenance", "force": true, "pretty": true }' ``` -``` +```json { "results": [ { @@ -1146,6 +1149,7 @@ $ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ "code": 200.0, "status": "Successfully sent custom notification for object 'host1'." } + ] } ``` @@ -1166,13 +1170,13 @@ In addition to these parameters a [filter](12-icinga2-api.md#icinga2-api-filters Example: -``` -$ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ +```bash +curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ -X POST 'https://localhost:5665/v1/actions/delay-notification' \ -d '{ "type": "Service", "timestamp": 1446389894, "pretty": true }' ``` -``` +```json { "results": [ { @@ -1183,6 +1187,7 @@ $ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ "code": 200.0, "status": "Successfully delayed notifications for object 'host1!service1'." } + ] } ``` @@ -1208,13 +1213,13 @@ In addition to these parameters a [filter](12-icinga2-api.md#icinga2-api-filters The following example acknowledges all services which are in a hard critical state and sends out a notification for them: -``` -$ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ +```bash +curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ -X POST 'https://localhost:5665/v1/actions/acknowledge-problem' \ -d '{ "type": "Service", "filter": "service.state==2&service.state_type=1", "author": "icingaadmin", "comment": "Global outage. Working on it.", "notify": true, "pretty": true }' ``` -``` +```json { "results": [ { @@ -1225,6 +1230,7 @@ $ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ "code": 200.0, "status": "Successfully acknowledged problem for object 'icinga2-satellite2.localdomain!ping4'." } + ] } ``` @@ -1243,13 +1249,13 @@ In addition to these parameters a [filter](12-icinga2-api.md#icinga2-api-filters The example removes all service acknowledgements: -``` -$ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ +```bash +curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ -X POST 'https://localhost:5665/v1/actions/remove-acknowledgement' \ -d '{ "type": "Service", "pretty": true }' ``` -``` +```json { "results": [ { @@ -1260,6 +1266,7 @@ $ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ "code": 200.0, "status": "Successfully removed acknowledgement for object 'example2.localdomain!aws-health'." } + ] } ``` @@ -1278,13 +1285,13 @@ In addition to these parameters a [filter](12-icinga2-api.md#icinga2-api-filters The following example adds a comment for all `ping4` services: -``` -$ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ +```bash +curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ -X POST 'https://localhost:5665/v1/actions/add-comment' \ -d '{ "type": "Service", "filter": "service.name==\"ping4\"", "author": "icingaadmin", "comment": "Troubleticket #123456789 opened.", "pretty": true }' ``` -``` +```json { "results": [ { @@ -1320,13 +1327,13 @@ In addition to these parameters a [filter](12-icinga2-api.md#icinga2-api-filters Example for a simple filter using the `comment` URL parameter: -``` -$ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ +```bash +curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ -X POST 'https://localhost:5665/v1/actions/remove-comment' \ -d '{ "comment": "icinga2-satellite2.localdomain!ping4!9a4c43f5-9407-a536-18bf-4a6cc4b73a9f", "pretty": true }' ``` -``` +```json { "results": [ { @@ -1339,13 +1346,13 @@ $ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ Example for removing all service comments using a service name filter for `ping4`: -``` -$ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ +```bash +curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ -X POST 'https://localhost:5665/v1/actions/remove-comment' -d '{ "type": "Service", "filter": "service.name==\"ping4\"", "pretty": true }' ``` -``` +```json { "results": [ { @@ -1382,13 +1389,13 @@ In addition to these parameters a [filter](12-icinga2-api.md#icinga2-api-filters Example for scheduling a downtime for all `ping4` services: -``` -$ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ +```bash +curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ -X POST 'https://localhost:5665/v1/actions/schedule-downtime' \ -d '{ "type": "Service", "filter": "service.name==\"ping4\"", "start_time": 1446388806, "end_time": 1446389806, "duration": 1000, "author": "icingaadmin", "comment": "IPv4 network maintenance", "pretty": true }' ``` -``` +```json { "results": [ { @@ -1419,8 +1426,8 @@ like this: Schedule a downtime for one (or multiple) hosts and all of their services. Note the `all_services` attribute. -``` -$ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ +```bash +curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ -X POST 'https://localhost:5665/v1/actions/schedule-downtime' \ -d "$(jo -p pretty=true type=Host filter="match(\"*satellite*\", host.name)" all_services=true author=icingaadmin comment="Cluster upgrade maintenance" fixed=true start_time=$(date +%s -d "+0 hour") end_time=$(date +%s -d "+1 hour"))" ``` @@ -1442,13 +1449,13 @@ In addition to these parameters a [filter](12-icinga2-api.md#icinga2-api-filters Example for a simple filter using the `downtime` URL parameter: -``` -$ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ +```bash +curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ -X POST 'https://localhost:5665/v1/actions/remove-downtime' \ -d '{ "downtime": "icinga2-satellite2.localdomain!ping4!abc59032-4589-abcd-4567-ecf67856c347", "pretty": true }' ``` -``` +```json { "results": [ { @@ -1461,13 +1468,13 @@ $ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ Example for removing all host downtimes using a host name filter for `icinga2-satellite2.localdomain`: -``` -$ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ +```bash +curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ -X POST 'https://localhost:5665/v1/actions/remove-downtime' \ -d '{ "type": "Host", "filter": "host.name==\"icinga2-satellite2.localdomain\"", "pretty": true }' ``` -``` +```json { "results": [ { @@ -1481,8 +1488,8 @@ $ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ Example for removing a downtime from a host but not the services filtered by the author name. This example uses filter variables explained in the [advanced filters](12-icinga2-api.md#icinga2-api-advanced-filters) chapter. -``` -$ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ +```bash +curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ -X POST 'https://localhost:5665/v1/actions/remove-downtime' \ -d $'{ "type": "Downtime", @@ -1495,7 +1502,7 @@ $ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ }' ``` -``` +```json { "results": [ { @@ -1516,12 +1523,12 @@ This action does not support a target type or filter. Example: -``` -$ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ +```bash +curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ -X POST 'https://localhost:5665/v1/actions/shutdown-process?pretty=1' ``` -``` +```json { "results": [ { @@ -1542,12 +1549,12 @@ This action does not support a target type or filter. Example: -``` -$ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ +```bash +curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ -X POST 'https://localhost:5665/v1/actions/restart-process?pretty=1' ``` -``` +```json { "results": [ { @@ -1577,13 +1584,13 @@ Send a `POST` request to the URL endpoint `/v1/actions/generate-ticket`. Example: -``` -$ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ +```bash +curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ -X POST 'https://localhost:5665/v1/actions/generate-ticket' \ -d '{ "cn": "icinga2-agent1.localdomain", "pretty": true }' ``` -``` +```json { "results": [ { @@ -1618,13 +1625,13 @@ Send a `POST` request to the URL endpoint `/v1/actions/execute-command`. Example: -``` -$ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ +```bash +curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ -X POST 'https://localhost:5665/v1/actions/execute-command' \ -d '{"type": "Service", "service": "agent!custom_service", "ttl": 15, "macros": { "command_endpoint": "master", "ls_dir": "/tmp/foo" }, "command": "custom_command", "command_type": "CheckCommand" }' ``` -``` +```json { "results": [ { @@ -1849,8 +1856,8 @@ must support long-polling and HTTP/1.1. HTTP/1.0 is not supported. Example: -``` -$ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ +```bash +curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ -X POST 'https://localhost:5665/v1/events' \ -d '{ "queue": "myqueue", "types": [ "CheckResult" ], "filter": "event.check_result.exit_status==2" }' ``` @@ -1867,8 +1874,8 @@ Send a `GET` request to the URL endpoint `/v1/status` to retrieve status informa Example: -``` -$ curl -k -s -S -i -u root:icinga 'https://localhost:5665/v1/status?pretty=1' +```bash +curl -k -s -S -i -u root:icinga 'https://localhost:5665/v1/status?pretty=1' ``` ``` @@ -1892,11 +1899,11 @@ $ curl -k -s -S -i -u root:icinga 'https://localhost:5665/v1/status?pretty=1' You can limit the output by specifying a status type in the URL, e.g. `IcingaApplication`: -``` -$ curl -k -s -S -i -u root:icinga 'https://localhost:5665/v1/status/IcingaApplication?pretty=1' +```bash +curl -k -s -S -i -u root:icinga 'https://localhost:5665/v1/status/IcingaApplication?pretty=1' ``` -``` +```json { "results": [ { @@ -1945,12 +1952,12 @@ deploy global templates in [global cluster zones](06-distributed-monitoring.md#d Send a `POST` request to a new config package called `example-cmdb` in this example. This creates a new empty configuration package. -``` -$ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ +```bash +curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ -X POST 'https://localhost:5665/v1/config/packages/example-cmdb?pretty=1' ``` -``` +```json { "results": [ { @@ -2011,13 +2018,13 @@ The example below will create a new file called `test.conf` in the `conf.d` directory. Note: This example contains an error (`chec_command`). This is intentional. -``` -$ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' -X POST \ +```bash +curl -k -s -S -i -u root:icinga -H 'Accept: application/json' -X POST \ -d '{ "files": { "conf.d/test.conf": "object Host \"cmdb-host\" { chec_command = \"dummy\" }" }, "pretty": true }' \ 'https://localhost:5665/v1/config/stages/example-cmdb' ``` -``` +```json { "results": [ { @@ -2066,11 +2073,11 @@ A list of packages and their stages can be retrieved by sending a `GET` request The following example contains one configuration package `example-cmdb`. The package does not currently have an active stage. -``` -$ curl -k -s -S -i -u root:icinga 'https://localhost:5665/v1/config/packages?pretty=1' +```bash +curl -k -s -S -i -u root:icinga 'https://localhost:5665/v1/config/packages?pretty=1' ``` -``` +```json { "results": [ { @@ -2090,8 +2097,8 @@ In order to retrieve a list of files for a stage you can send a `GET` request to the URL endpoint `/v1/config/stages`. You need to include the package name (`example-cmdb`) and stage name (`7e7861c8-8008-4e8d-9910-2a0bb26921bd`) in the URL: -``` -$ curl -k -s -S -i -u root:icinga 'https://localhost:5665/v1/config/stages/example-cmdb/7e7861c8-8008-4e8d-9910-2a0bb26921bd?pretty=1' +```bash +curl -k -s -S -i -u root:icinga 'https://localhost:5665/v1/config/stages/example-cmdb/7e7861c8-8008-4e8d-9910-2a0bb26921bd?pretty=1' ``` ``` @@ -2133,8 +2140,8 @@ the package name, the stage name and the relative path to the file to the URL pa The following example fetches the configuration file `conf.d/test.conf`: -``` -$ curl -k -s -S -i -u root:icinga 'https://localhost:5665/v1/config/files/example-cmdb/7e7861c8-8008-4e8d-9910-2a0bb26921bd/conf.d/test.conf' +```bash +curl -k -s -S -i -u root:icinga 'https://localhost:5665/v1/config/files/example-cmdb/7e7861c8-8008-4e8d-9910-2a0bb26921bd/conf.d/test.conf' ``` ``` @@ -2153,8 +2160,8 @@ In order to check for validation errors you can fetch the `startup.log` file by sending a `GET` request to the URL endpoint `/v1/config/files`. You must include the package name, stage name and the `startup.log` in the URL path. -``` -$ curl -k -s -S -i -u root:icinga 'https://localhost:5665/v1/config/files/example-cmdb/7e7861c8-8008-4e8d-9910-2a0bb26921bd/startup.log' +```bash +curl -k -s -S -i -u root:icinga 'https://localhost:5665/v1/config/files/example-cmdb/7e7861c8-8008-4e8d-9910-2a0bb26921bd/startup.log' ``` ``` @@ -2183,12 +2190,12 @@ stage name inside the URL path. The following example removes the failed configuration stage `7e7861c8-8008-4e8d-9910-2a0bb26921bd` in the `example-cmdb` configuration package: -``` -$ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ +```bash +curl -k -s -S -i -u root:icinga -H 'Accept: application/json' \ -X DELETE 'https://localhost:5665/v1/config/stages/example-cmdb/7e7861c8-8008-4e8d-9910-2a0bb26921bd?pretty=1' ``` -``` +```json { "results": [ { @@ -2207,12 +2214,12 @@ with the package name in the URL path. This example entirely deletes the configuration package `example-cmdb`: -``` -$ curl -k -s -S -i -u root:icinga -H 'Accept: application/json' -X DELETE \ +```bash +curl -k -s -S -i -u root:icinga -H 'Accept: application/json' -X DELETE \ 'https://localhost:5665/v1/config/packages/example-cmdb?pretty=1' ``` -``` +```json { "results": [ { @@ -2242,11 +2249,11 @@ Each response entry in the results array contains the following attributes: In order to view a specific configuration object type specify its name inside the URL path: -``` -$ curl -k -s -S -i -u root:icinga 'https://localhost:5665/v1/types/Object?pretty=1' +```bash +curl -k -s -S -i -u root:icinga 'https://localhost:5665/v1/types/Object?pretty=1' ``` -``` +```json { "results": [ { @@ -2293,8 +2300,8 @@ a `GET` query to the `/v1/templates/` URL endpoint. ` OPTIMIZE TABLE icinga_statehistory; If you want to optimize all tables in a specified database, there is a script called `mysqlcheck`. This also allows to repair broken tables in the case of emergency. -``` +```bash mysqlcheck --optimize icinga ``` @@ -241,8 +241,8 @@ TCP port, defaulting to `2003`. You can enable the feature using -``` -# icinga2 feature enable graphite +```bash +icinga2 feature enable graphite ``` By default the [GraphiteWriter](09-object-types.md#objecttype-graphitewriter) feature @@ -372,8 +372,8 @@ defined InfluxDB HTTP API. You can enable the feature using -``` -# icinga2 feature enable influxdb +```bash +icinga2 feature enable influxdb ``` By default the [InfluxdbWriter](09-object-types.md#objecttype-influxdbwriter) feature @@ -488,8 +488,8 @@ The check results include parsed performance data metrics if enabled. Enable the feature and restart Icinga 2. -``` -# icinga2 feature enable elasticsearch +```bash +icinga2 feature enable elasticsearch ``` The default configuration expects an Elasticsearch instance running on `localhost` on port `9200` @@ -572,8 +572,8 @@ While it has been specified by the [Graylog](https://www.graylog.org) project as You can enable the feature using -``` -# icinga2 feature enable gelf +```bash +icinga2 feature enable gelf ``` By default the `GelfWriter` object expects the GELF receiver to listen at `127.0.0.1` on TCP port `12201`. @@ -612,8 +612,8 @@ write them to the defined TSDB TCP socket. You can enable the feature using -``` -# icinga2 feature enable opentsdb +```bash +icinga2 feature enable opentsdb ``` By default the `OpenTsdbWriter` object expects the TSD to listen at @@ -888,8 +888,8 @@ service_format_template = "DATATYPE::SERVICEPERFDATA\tTIMET::$icinga.timet$\tHOS The default templates are already provided with the Icinga 2 feature configuration which can be enabled using -``` -# icinga2 feature enable perfdata +```bash +icinga2 feature enable perfdata ``` By default all performance data files are rotated in a 15 seconds interval into @@ -936,8 +936,8 @@ interval to its `objects.cache` and `status.dat` files. Icinga 2 provides the `StatusDataWriter` object which dumps all configuration objects and status updates in a regular interval. -``` -# icinga2 feature enable statusdata +```bash +icinga2 feature enable statusdata ``` If you are not using any web interface or addon which uses these files, @@ -961,8 +961,8 @@ for answering queries to historical tables. The `CompatLogger` object can be enabled with -``` -# icinga2 feature enable compatlog +```bash +icinga2 feature enable compatlog ``` By default, the Icinga 1.x log file called `icinga.log` is located @@ -988,8 +988,8 @@ through the web interface). In order to enable the `ExternalCommandListener` configuration use the following command and restart Icinga 2 afterwards: -``` -# icinga2 feature enable command +```bash +icinga2 feature enable command ``` Icinga 2 creates the command pipe file as `/var/run/icinga2/cmd/icinga2.cmd` @@ -1067,14 +1067,14 @@ in the [Livestatus Schema](24-appendix.md#schema-livestatus) section. You can enable Livestatus using icinga2 feature enable: -``` -# icinga2 feature enable livestatus +```bash +icinga2 feature enable livestatus ``` After that you will have to restart Icinga 2: -``` -# systemctl restart icinga2 +```bash +systemctl restart icinga2 ``` By default the Livestatus socket is available in `/var/run/icinga2/cmd/livestatus`. @@ -1082,8 +1082,8 @@ By default the Livestatus socket is available in `/var/run/icinga2/cmd/livestatu In order for queries and commands to work you will need to add your query user (e.g. your web server) to the `icingacmd` group: -``` -# usermod -a -G icingacmd www-data +```bash +usermod -a -G icingacmd www-data ``` The Debian packages use `nagios` as the user and group name. Make sure to change `icingacmd` to @@ -1096,8 +1096,8 @@ In order to use the historical tables provided by the livestatus feature (for ex are expected to be in `/var/log/icinga2/compat`. A different path can be set using the `compat_log_path` configuration attribute. -``` -# icinga2 feature enable compatlog +```bash +icinga2 feature enable compatlog ``` #### Livestatus Sockets @@ -1143,8 +1143,8 @@ EOF A list of available external commands and their parameters can be found [here](24-appendix.md#external-commands-list-detail) -``` -$ echo -e 'COMMAND ' | netcat 127.0.0.1 6558 +```bash +echo -e 'COMMAND ' | netcat 127.0.0.1 6558 ``` #### Livestatus Filters diff --git a/doc/15-troubleshooting.md b/doc/15-troubleshooting.md index fdb29570f..f4003fb82 100644 --- a/doc/15-troubleshooting.md +++ b/doc/15-troubleshooting.md @@ -54,7 +54,7 @@ Install tools which help you to do so. Opinions differ, let us know if you have [htop](https://hisham.hm/htop/) is a better replacement for `top` and helps to analyze processes interactively. -``` +```bash yum install htop apt-get install htop ``` @@ -68,32 +68,33 @@ Attach it when posting a question to the community channels. The [sysstat](https://github.com/sysstat/sysstat) package provides a number of tools to analyze the performance on Linux. On FreeBSD you could use `systat` for example. -``` +```bash yum install sysstat apt-get install sysstat ``` Example for `vmstat` (summary of memory, processes, etc.): -``` -// summary +```bash +# summary vmstat -s -// print timestamps, format in MB, stats every 1 second, 5 times +# print timestamps, format in MB, stats every 1 second, 5 times vmstat -t -S M 1 5 ``` Example for `iostat`: -``` +```bash watch -n 1 iostat ``` Example for `sar`: -``` -sar //cpu -sar -r //ram -sar -q //load avg -sar -b //I/O + +```bash +sar # cpu +sar -r # ram +sar -q # load avg +sar -b # I/O ``` `sysstat` also provides the `iostat` binary. On FreeBSD you could use `systat` for example. @@ -124,16 +125,16 @@ Get-Content .\icinga2.log -tail 10 -wait Enable the `debuglog` feature: -``` -# icinga2 feature enable debuglog -# service icinga2 restart +```bash +icinga2 feature enable debuglog +service icinga2 restart ``` The debug log file can be found in `/var/log/icinga2/debug.log`. You can tail the log files with an administrative shell: -``` +```bash cd /var/log/icinga2 tail -f debug.log ``` @@ -141,8 +142,8 @@ tail -f debug.log Alternatively you may run Icinga 2 in the foreground with debugging enabled. Specify the console log severity as an additional parameter argument to `-x`. -``` -# /usr/sbin/icinga2 daemon -x notice +```bash +/usr/sbin/icinga2 daemon -x notice ``` The [log severity](09-object-types.md#objecttype-filelogger) can be one of `critical`, `warning`, `information`, `notice` @@ -290,8 +291,8 @@ encapsulated by `/* ... */`). Run the [configuration validation](11-cli-commands.md#config-validation) and add `notice` as log severity. Search for the file which should be included i.e. using the `grep` CLI command. -``` -# icinga2 daemon -C -x notice | grep command +```bash +icinga2 daemon -C -x notice | grep command ``` ### Configuration attributes are inherited from @@ -382,10 +383,10 @@ $ ICINGA2_API_PASSWORD=icinga icinga2 console --connect 'https://root@localhost: Example for searching the debug log: -``` -# icinga2 feature enable debuglog -# systemctl restart icinga2 -# tail -f /var/log/icinga2/debug.log | grep "notice/Process" +```bash +icinga2 feature enable debuglog +systemctl restart icinga2 +tail -f /var/log/icinga2/debug.log | grep "notice/Process" ``` @@ -404,8 +405,8 @@ and verify why the checks are not executed there. Test a plugin as icinga user. -``` -# sudo -u icinga /usr/lib/nagios/plugins/check_ping -4 -H 127.0.0.1 -c 5000,100% -w 3000,80% +```bash +sudo -u icinga /usr/lib/nagios/plugins/check_ping -4 -H 127.0.0.1 -c 5000,100% -w 3000,80% ``` > **Note** @@ -425,8 +426,8 @@ The feature 'checker' is already enabled. Fetch all check result events matching the `event.service` name `random`: -``` -$ curl -k -s -u root:icinga -H 'Accept: application/json' -X POST \ +```bash +curl -k -s -u root:icinga -H 'Accept: application/json' -X POST \ 'https://localhost:5665/v1/events?queue=debugchecks&types=CheckResult&filter=match%28%22random*%22,event.service%29' ``` @@ -579,7 +580,7 @@ The error message could look like this: In order to solve the problem, increase the value for `DefaultTasksMax` or set it to `infinity`. -``` +```bash mkdir /etc/systemd/system/icinga2.service.d cat >/etc/systemd/system/icinga2.service.d/limits.conf < /root/analyze_notification_problem.log +grep Notification /var/log/icinga2/debug.log > /root/analyze_notification_problem.log ``` You can use the Icinga 2 API [event streams](12-icinga2-api.md#icinga2-api-event-streams) to receive live notification streams: -``` -$ curl -k -s -u root:icinga -H 'Accept: application/json' -X POST 'https://localhost:5665/v1/events?queue=debugnotifications&types=Notification' +```bash +curl -k -s -u root:icinga -H 'Accept: application/json' -X POST 'https://localhost:5665/v1/events?queue=debugnotifications&types=Notification' ``` @@ -869,19 +870,19 @@ to `features-enabled` and that the latter is included in [icinga2.conf](04-confi Look up the [object type](09-object-types.md#object-types) for the required feature and verify it is enabled: -``` -# icinga2 object list --type +```bash +icinga2 object list --type ``` Example for the `graphite` feature: -``` -# icinga2 object list --type GraphiteWriter +```bash +icinga2 object list --type GraphiteWriter ``` Look into the log and check whether the feature logs anything specific for this matter. -``` +```bash grep GraphiteWriter /var/log/icinga2/icinga2.log ``` @@ -958,7 +959,7 @@ again, carefully do the following steps with creating a backup before: Navigate into the API package prefix. -``` +```bash cd /var/lib/icinga2/api/packages ``` @@ -983,20 +984,20 @@ If you have more than one stage directory here, pick the latest modified directory. Copy the directory name `abcd-ef12-3456-7890` and add it into a new file `active-stage`. This can be done like this: -``` +```bash echo "dbe0bef8-c72c-4cc9-9779-da7c4527c5b2" > active-stage ``` `active.conf` needs to have the correct active stage too, add it again like this. Note: This is deep down in the code, use with care! -``` +```bash sed -i 's/ActiveStages\["_api"\] = .*/ActiveStages\["_api"\] = "dbe0bef8-c72c-4cc9-9779-da7c4527c5b2"/g' /var/lib/icinga2/api/packages/_api/active.conf ``` Restart Icinga 2. -``` +```bash systemctl restart icinga2 ``` @@ -1034,8 +1035,8 @@ Print the CA and client certificate and ensure that the following attributes are Navigate into the local certificate store: -``` -$ cd /var/lib/icinga2/certs/ +```bash +cd /var/lib/icinga2/certs/ ``` Make sure to verify the agents' certificate and its stored `ca.crt` in `/var/lib/icinga2/certs` and ensure that @@ -1274,13 +1275,13 @@ SSL-Session: You can specifically use one cipher or a list with the `-cipher` parameter: -``` +```bash openssl s_client -connect 192.168.33.5:5665 -cipher 'ECDHE-RSA-AES256-GCM-SHA384' ``` In order to fully simulate a connecting client, provide the certificates too: -``` +```bash CERTPATH='/var/lib/icinga2/certs' HOSTNAME='icinga2.vagrant.demo.icinga.com' openssl s_client -connect 192.168.33.5:5665 -cert "${CERTPATH}/${HOSTNAME}.crt" -key "${CERTPATH}/${HOSTNAME}.key" -CAfile "${CERTPATH}/ca.crt" -cipher 'ECDHE-RSA-AES256-GCM-SHA384' @@ -1301,8 +1302,8 @@ the child node actively connectsm, you can still simulate a TLS handshake. Use `openssl s_server` instead of `openssl s_client` on the master during the connection attempt. -``` -$ openssl s_server -connect 192.168.56.101:5665 +```bash +openssl s_server -connect 192.168.56.101:5665 ``` Since the server role chooses the preferred cipher suite in Icinga, @@ -1385,12 +1386,12 @@ General connection errors could be one of the following problems: Use tools like `netstat`, `tcpdump`, `nmap`, etc. to make sure that the cluster communication works (default port is `5665`). -``` -# tcpdump -n port 5665 -i any +```bash +tcpdump -n port 5665 -i any -# netstat -tulpen | grep icinga +netstat -tulpen | grep icinga -# nmap icinga2-agent1.localdomain +nmap icinga2-agent1.localdomain ``` ### Cluster Troubleshooting TLS Errors @@ -1473,8 +1474,8 @@ Additional tasks: Fetch all check result events matching the `event.service` name `remote-client`: -``` -$ curl -k -s -u root:icinga -H 'Accept: application/json' -X POST 'https://localhost:5665/v1/events?queue=debugcommandendpoint&types=CheckResult&filter=match%28%22remote-client*%22,event.service%29' +```bash +curl -k -s -u root:icinga -H 'Accept: application/json' -X POST 'https://localhost:5665/v1/events?queue=debugcommandendpoint&types=CheckResult&filter=match%28%22remote-client*%22,event.service%29' ``` @@ -1508,19 +1509,19 @@ object Zone "master" { Then create a new directory in `zones.d` called `master`, if not existing. -``` +```bash mkdir -p /etc/icinga2/zones.d/master ``` Now move the directory tree from `conf.d` into the `master` zone. -``` +```bash mv conf.d/* /etc/icinga2/zones.d/master/ ``` Validate the configuration and reload Icinga. -``` +```bash icinga2 daemon -C systemctl restart icinga2 ``` diff --git a/doc/16-upgrading-icinga-2.md b/doc/16-upgrading-icinga-2.md index 61abca0cf..4b0027399 100644 --- a/doc/16-upgrading-icinga-2.md +++ b/doc/16-upgrading-icinga-2.md @@ -51,7 +51,7 @@ config files for the zone(s). **If your config master is 2.11.x already, you are In order to fix this, upgrade to at least 2.11.1, and purge away the local config sync storage once, then restart. -``` +```bash yum install icinga2 rm -rf /var/lib/icinga2/api/zones/* @@ -872,10 +872,10 @@ $ ls /usr/share/icinga2-ido-mysql/schema/upgrade/ There are two new upgrade files called `2.5.0.sql`, `2.6.0.sql` and `2.8.0.sql` which must be applied incrementally to your IDO database. -``` -# mysql -u root -p icinga < /usr/share/icinga2-ido-mysql/schema/upgrade/2.5.0.sql -# mysql -u root -p icinga < /usr/share/icinga2-ido-mysql/schema/upgrade/2.6.0.sql -# mysql -u root -p icinga < /usr/share/icinga2-ido-mysql/schema/upgrade/2.8.0.sql +```bash +mysql -u root -p icinga < /usr/share/icinga2-ido-mysql/schema/upgrade/2.5.0.sql +mysql -u root -p icinga < /usr/share/icinga2-ido-mysql/schema/upgrade/2.6.0.sql +mysql -u root -p icinga < /usr/share/icinga2-ido-mysql/schema/upgrade/2.8.0.sql ``` ## Upgrading the PostgreSQL database @@ -908,9 +908,9 @@ $ ls /usr/share/icinga2-ido-pgsql/schema/upgrade/ There are two new upgrade files called `2.5.0.sql`, `2.6.0.sql` and `2.8.0.sql` which must be applied incrementally to your IDO database. -``` -# export PGPASSWORD=icinga -# psql -U icinga -d icinga < /usr/share/icinga2-ido-pgsql/schema/upgrade/2.5.0.sql -# psql -U icinga -d icinga < /usr/share/icinga2-ido-pgsql/schema/upgrade/2.6.0.sql -# psql -U icinga -d icinga < /usr/share/icinga2-ido-pgsql/schema/upgrade/2.8.0.sql +```bash +export PGPASSWORD=icinga +psql -U icinga -d icinga < /usr/share/icinga2-ido-pgsql/schema/upgrade/2.5.0.sql +psql -U icinga -d icinga < /usr/share/icinga2-ido-pgsql/schema/upgrade/2.6.0.sql +psql -U icinga -d icinga < /usr/share/icinga2-ido-pgsql/schema/upgrade/2.8.0.sql ``` diff --git a/doc/19-technical-concepts.md b/doc/19-technical-concepts.md index 18f88e839..a1ea82c79 100644 --- a/doc/19-technical-concepts.md +++ b/doc/19-technical-concepts.md @@ -422,7 +422,7 @@ is a list with multiple indexes with the keys for scheduling info and the object Each check command execution logs the start and end time where Icinga 2 (and the end user) is able to calculate the plugin execution time from it. -``` +```cpp GetExecutionEnd() - GetExecutionStart() ``` @@ -438,7 +438,7 @@ and computed from inside the check result. The difference between the two deltas is called `check latency`. -``` +```cpp (GetScheduleEnd() - GetScheduleStart()) - CalculateExecutionTime() ``` @@ -454,7 +454,7 @@ The higher the severity number is, the more important the problem is. Flags: -``` +```cpp /** * Severity Flags * @@ -476,7 +476,7 @@ enum SeverityFlag Host: -``` +```cpp /* OK/Warning = Up, Critical/Unknown = Down */ if (!HasBeenChecked()) severity |= SeverityFlagPending; @@ -496,7 +496,7 @@ Host: Service: -``` +```cpp if (!HasBeenChecked()) severity |= SeverityFlagPending; else if (state == ServiceWarning) @@ -702,7 +702,7 @@ This index is used to lookup the corresponding endpoint in the connected endpoin including the local endpoint. Whether the local endpoint is equal to the selected endpoint, or not, this sets the authority to `true` or `false`. -``` +```cpp authority = endpoints[Utility::SDBM(object->GetName()) % endpoints.size()] == my_endpoint; ``` @@ -1106,7 +1106,7 @@ RelayMessageOne() takes care of the routing. This involves fetching the targetZo With passing the `origin` the following condition prevents sending a message back to sender: -``` +```cpp if (origin && origin->FromClient && targetEndpoint == origin->FromClient->GetEndpoint()) { ``` diff --git a/doc/20-script-debugger.md b/doc/20-script-debugger.md index 733142d21..e8ee6db6c 100644 --- a/doc/20-script-debugger.md +++ b/doc/20-script-debugger.md @@ -3,8 +3,8 @@ You can run the Icinga 2 daemon with the `-X` (`--script-debugger`) parameter to enable the script debugger: -``` -# icinga2 daemon -X +```bash +icinga2 daemon -X ``` When an exception occurs or the [debugger](17-language-reference.md#breakpoints) @@ -13,8 +13,8 @@ allows the user to debug the script. You can also attach the script debugger to the [configuration validation](11-cli-commands.md#config-validation): -``` -# icinga2 daemon -C -X +```bash +icinga2 daemon -C -X ``` Here is a list of common errors which can be diagnosed with the script debugger: @@ -135,8 +135,8 @@ The following example tries filter for all host objects where the custom variabl `host.vars.os != ""`. Another idea is to use the [contains](18-library-reference.md#dictionary-contains) method on the custom attribute dictionary like this: `host.vars.contains("os")`. -``` -$ curl -k -s -u root:icinga -H 'Accept: application/json' -H 'X-HTTP-Method-Override: GET' \ +```bash +curl -k -s -u root:icinga -H 'Accept: application/json' -H 'X-HTTP-Method-Override: GET' \ -X POST 'https://localhost:5665/v1/objects/services' \ -d '{ "filter": "host.vars.contains(\"os\")", "attrs": [ "__name" ], "joins": [ "host.name", "host.vars" ], "pretty": true }' ``` @@ -170,8 +170,8 @@ In order to stay safe, add more checks to the API filter: Example: -``` -$ curl -k -s -u root:icinga -H 'Accept: application/json' -H 'X-HTTP-Method-Override: GET' \ +```bash +curl -k -s -u root:icinga -H 'Accept: application/json' -H 'X-HTTP-Method-Override: GET' \ -X POST 'https://localhost:5665/v1/objects/services' \ -d '{ "filter": "host.vars && typeof(host.vars) == Dictionary && host.vars.contains(\"os\")", "attrs": [ "__name" ], "joins": [ "host.name", "host.vars" ], "pretty": true }' ``` diff --git a/doc/21-development.md b/doc/21-development.md index ff329976a..a2bf23d54 100644 --- a/doc/21-development.md +++ b/doc/21-development.md @@ -88,7 +88,7 @@ process and can safely be ignored. > Since v2.11 we would attach to the umbrella process spawned with `/usr/lib/icinga2/sbin/icinga2`, > therefore rather attach to a running process. > -``` +```bash # Typically the order of PIDs is: 1) umbrella 2) spawn helper 3) main process pidof icinga2 @@ -169,7 +169,7 @@ process and store it into a new file (e.g. for debugging dead locks). Icinga 2 runs with 2 processes: main and command executor, therefore generate two backtrace logs and add them to the GitHub issue. -``` +```bash for pid in $(pidof icinga2); do gdb -p $pid -batch -ex "thread apply all bt full" -ex "detach" -ex "q" > gdb_bt_${pid}_`date +%s`.log; done ``` @@ -177,7 +177,7 @@ for pid in $(pidof icinga2); do gdb -p $pid -batch -ex "thread apply all bt full Instead of a full backtrace, you sometimes just need a list of running threads. -``` +```bash for pid in $(pidof icinga2); do gdb -p $pid -batch -ex "info threads" -ex "detach" -ex "q" > gdb_threads_${pid}_`date +%s`.log; done ``` @@ -317,13 +317,13 @@ Max core file size unlimited unlimited bytes The Icinga 2 daemon runs with the SUID bit set. Therefore you need to explicitly enable core dumps for SUID on Linux. -``` +```bash sysctl -w fs.suid_dumpable=2 ``` Adjust the coredump kernel format and file location on Linux: -``` +```bash sysctl -w kernel.core_pattern=/var/lib/cores/core.%e.%p install -m 1777 -d /var/lib/cores @@ -331,7 +331,7 @@ install -m 1777 -d /var/lib/cores MacOS: -``` +```bash sysctl -w kern.corefile=/cores/core.%P chmod 777 /cores @@ -365,15 +365,15 @@ gdb /usr/lib64/icinga2/sbin/icinga2 core.icinga2. LLDB is available on macOS with the Xcode command line tools. -``` -$ xcode-select --install +```bash +xcode-select --install ``` In order to run Icinga 2 with LLDB you need to pass the binary as argument. Since v2.11 we would attach to the umbrella process, therefore rather attach to a running process. -``` +```bash # Typically the order of PIDs is: 1) umbrella 2) spawn helper 3) main process pidof icinga2 @@ -390,7 +390,7 @@ Closed FD 6 which we inherited from our parent process. [2020-01-29 12:22:33 +0100] information/RunWorker: DEBUG: Current PID: 85253. Sleeping for 120 seconds to allow lldb/gdb -p attachment. ``` -``` +```bash lldb -p 85253 ``` @@ -544,7 +544,7 @@ on GitHub and mention that you're testing the snapshot packages. In addition to that, the `icinga-rpm-release` package already provides the `icinga-snapshot-builds` repository but it is disabled by default. -``` +```bash yum -y install https://packages.icinga.com/epel/icinga-rpm-release-7-latest.noarch.rpm yum -y install epel-release yum makecache @@ -558,7 +558,7 @@ yum install --enablerepo=icinga-snapshot-builds icinga2 It is advised to configure both Icinga repositories, stable and snapshot and selectively choose the repository with the `-t` flag on `apt-get install`. -``` +```bash apt-get update apt-get -y install apt-transport-https wget gnupg @@ -581,7 +581,7 @@ apt-get update On Debian Stretch, you'll also need to add Debian Backports. -``` +```bash DIST=$(awk -F"[)(]+" '/VERSION=/ {print $2}' /etc/os-release); \ echo "deb https://deb.debian.org/debian ${DIST}-backports main" > \ /etc/apt/sources.list.d/${DIST}-backports.list @@ -591,14 +591,14 @@ apt-get update Then install the snapshot packages. -``` +```bash DIST=$(awk -F"[)(]+" '/VERSION=/ {print $2}' /etc/os-release); \ apt-get install -t icinga-${DIST}-snapshots icinga2 ``` #### Ubuntu -``` +```bash apt-get update apt-get -y install apt-transport-https wget gnupg @@ -621,7 +621,7 @@ apt-get update Then install the snapshot packages. -``` +```bash . /etc/os-release; if [ ! -z ${UBUNTU_CODENAME+x} ]; then DIST="${UBUNTU_CODENAME}"; else DIST="$(lsb_release -c| awk '{print $2}')"; fi; \ apt-get install -t icinga-${DIST}-snapshots icinga2 ``` @@ -630,7 +630,7 @@ apt-get install -t icinga-${DIST}-snapshots icinga2 The required Boost packages are provided with the stable release repository. -``` +```bash rpm --import https://packages.icinga.com/icinga.key zypper ar https://packages.icinga.com/SUSE/ICINGA-release.repo @@ -642,7 +642,7 @@ zypper ref Selectively install the snapshot packages using the `-r` parameter. -``` +```bash zypper in -r icinga-snapshot-builds icinga2 ``` @@ -652,14 +652,14 @@ zypper in -r icinga-snapshot-builds icinga2 Build the binaries and run the tests. -``` +```bash make -j4 -C debug make test -C debug ``` Run a specific boost test: -``` +```bash debug/Bin/Debug/boosttest-test-base --run_test=remote_url ``` @@ -848,9 +848,11 @@ current year as this implies yearly updates we don't want. Depending on the file type, this must be a comment. -``` +```cpp /* Icinga 2 | (c) 2012 Icinga GmbH | GPLv2+ */ +``` +```bash # Icinga 2 | (c) 2012 Icinga GmbH | GPLv2+ ``` @@ -863,7 +865,7 @@ We follow the clang format, with some exceptions. - Curly braces for functions and classes always start at a new line. -``` +```cpp String ConfigObjectUtility::EscapeName(const String& name) { //... @@ -878,7 +880,7 @@ String ConfigObjectUtility::CreateObjectConfig(const Type::Ptr& type, const Stri - Too long lines break at a parameter, the new line needs a tab indent. -``` +```cpp static String CreateObjectConfig(const Type::Ptr& type, const String& fullName, bool ignoreOnError, const Array::Ptr& templates, const Dictionary::Ptr& attrs); ``` @@ -886,7 +888,7 @@ String ConfigObjectUtility::CreateObjectConfig(const Type::Ptr& type, const Stri - Conditions require curly braces if it is not a single if with just one line. -``` +```cpp if (s == "OK") { //... } else { @@ -917,7 +919,7 @@ use that information as a summary and link over to it on purpose. - Single line comments may use `//` or `/* ... */` - Multi line comments must use this format: -``` +```cpp /* Ensure to check for XY * This relies on the fact that ABC has been set before. */ @@ -937,7 +939,7 @@ The `return` value should describe the value type and additional details. Example: -``` +```cpp /** * Reads a message from the connected peer. * @@ -983,7 +985,7 @@ Always use an empty line after the header include parts. The icinga namespace is used globally, as otherwise we would need to write `icinga::Utility::FormatDateTime()`. -``` +```cpp using namespace icinga; ``` @@ -991,7 +993,7 @@ Other namespaces must be declared in the scope they are used. Typically this is inside the function where `boost::asio` and variants would complicate the code. -``` +```cpp namespace ssl = boost::asio::ssl; auto context (std::make_shared(ssl::context::sslv23)); @@ -1003,7 +1005,7 @@ Ensure to pass values and pointers as const reference. By default, all values will be copied into the function scope, and we want to avoid this wherever possible. -``` +```cpp std::vector EventQueue::GetQueuesForType(const String& type) ``` @@ -1034,7 +1036,7 @@ optimizes this anyways. Wrong: -``` +```cpp int res = s == "OK" ? 0 : s == "WARNING" ? 1; return res; @@ -1042,7 +1044,7 @@ Wrong: Better: -``` +```cpp int res = 3; if (s == "OK") { @@ -1055,7 +1057,7 @@ Better: Even better: Create a lookup map instead of if branches. The complexity is reduced to O(log(n)). -``` +```cpp std::map stateMap = { { "OK", 1 }, { "WARNING", 2 } @@ -1083,7 +1085,7 @@ Icinga objects can be locked with the `ObjectLock` class. Object locks and guards must be limited to the scope where they are needed. Otherwise we could create dead locks. -``` +```cpp { ObjectLock olock(frame.Locals); for (const Dictionary::Pair& kv : frame.Locals) { @@ -1112,7 +1114,7 @@ which are made available in the DSL too. - Always use `String` instead of `std::string`. If you need a C-string, use the `CStr()` method. - Avoid casts and rather use the `Convert` class methods. -``` +```cpp double s = static_cast(v); //Wrong double s = Convert::ToDouble(v); //Correct, ToDouble also provides overloads with different value types @@ -1243,7 +1245,7 @@ they are allowed: Typedefs allow developers to use shorter names for specific types, classes and structs. -``` +```cpp typedef std::map >::iterator Iterator; ``` @@ -1258,7 +1260,7 @@ is required. The following example iterates over a map returned from `GetTypes()`. -``` +```cpp for (const auto& kv : GetTypes()) { result.insert(kv.second); } @@ -1267,7 +1269,7 @@ The following example iterates over a map returned from `GetTypes()`. The long example would require us to define a map iterator, and a slightly different algorithm. -``` +```cpp typedef std::map TypeMap; typedef std::map::const_iterator TypeMapIterator; @@ -1281,7 +1283,7 @@ different algorithm. We could also use a pair here, but requiring to know the specific types of the map keys and values. -``` +```cpp typedef std::pair kv_pair; for (const kv_pair& kv : GetTypes()) { @@ -1347,7 +1349,7 @@ Create two build directories for different binary builds. * `debug` contains the debug build binaries. They contain more debug information and run tremendously slower than release builds from packages. Don't use them for benchmarks. * `release` contains the release build binaries, as you would install them on a live system. This helps comparing specific scenarios for race conditions and more. -``` +```bash mkdir -p release debug ``` @@ -1361,7 +1363,7 @@ are best effort and sometimes out-of-date. Git Master may contain updates. #### CentOS 7 -``` +```bash yum -y install gdb vim git bash-completion htop yum -y install rpmdevtools ccache \ @@ -1388,19 +1390,19 @@ build inside the `release` directory. First, off export some generics for Boost. -``` +```bash export I2_BOOST="-DBoost_NO_BOOST_CMAKE=TRUE -DBoost_NO_SYSTEM_PATHS=TRUE -DBOOST_LIBRARYDIR=/usr/lib64/boost169 -DBOOST_INCLUDEDIR=/usr/include/boost169 -DBoost_ADDITIONAL_VERSIONS='1.69;1.69.0'" ``` Second, add the prefix path to it. -``` +```bash export I2_GENERIC="$I2_BOOST -DCMAKE_INSTALL_PREFIX=/usr/local/icinga2" ``` Third, define the two build types with their specific CMake variables. -``` +```bash export I2_DEBUG="-DCMAKE_BUILD_TYPE=Debug -DICINGA2_UNITY_BUILD=OFF $I2_GENERIC" export I2_RELEASE="-DCMAKE_BUILD_TYPE=RelWithDebInfo -DICINGA2_WITH_TESTS=ON -DICINGA2_UNITY_BUILD=ON $I2_GENERIC" ``` @@ -1408,7 +1410,7 @@ export I2_RELEASE="-DCMAKE_BUILD_TYPE=RelWithDebInfo -DICINGA2_WITH_TESTS=ON -DI Fourth, depending on your likings, you may add a bash alias for building, or invoke the commands inside: -``` +```bash alias i2_debug="cd /root/icinga2; mkdir -p debug; cd debug; cmake $I2_DEBUG ..; make -j2; sudo make -j2 install; cd .." alias i2_release="cd /root/icinga2; mkdir -p release; cd release; cmake $I2_RELEASE ..; make -j2; sudo make -j2 install; cd .." ``` @@ -1419,7 +1421,7 @@ This is taken from the [centos7-dev](https://github.com/Icinga/icinga-vagrant/tr The source installation doesn't set proper permissions, this is handled in the package builds which are officially supported. -``` +```bash chown -R icinga:icinga /usr/local/icinga2/var/ /usr/local/icinga2/lib/icinga2/prepare-dirs /usr/local/icinga2/etc/sysconfig/icinga2 @@ -1435,8 +1437,8 @@ Debian Buster doesn't need updated Boost packages from packages.icinga.com, the distribution already provides 1.66+. For older versions such as Stretch, include the release repository for packages.icinga.com as shown in the [setup instructions](02-installation.md#package-repositories-debian-ubuntu-raspbian). -``` -$ docker run -ti debian:buster bash +```bash +docker run -ti debian:buster bash apt-get update apt-get -y install apt-transport-https wget gnupg @@ -1445,7 +1447,7 @@ apt-get -y install gdb vim git cmake make ccache build-essential libssl-dev biso apt-get -y install libboost-all-dev ``` -``` +```bash ln -s /usr/bin/ccache /usr/local/bin/gcc ln -s /usr/bin/ccache /usr/local/bin/g++ @@ -1472,7 +1474,7 @@ make -j2 install -C debug The source installation doesn't set proper permissions, this is handled in the package builds which are officially supported. -``` +```bash chown -R icinga:icinga /usr/local/icinga2/var/ /usr/local/icinga2/lib/icinga2/prepare-dirs /usr/local/icinga2/etc/sysconfig/icinga2 @@ -1487,8 +1489,8 @@ vim /usr/local/icinga2/etc/icinga2/conf.d/api-users.conf Requires Boost packages from packages.icinga.com. -``` -$ docker run -ti ubuntu:bionic bash +```bash +docker run -ti ubuntu:bionic bash apt-get update apt-get -y install apt-transport-https wget gnupg @@ -1504,7 +1506,7 @@ wget -O - https://packages.icinga.com/icinga.key | apt-key add - apt-get update ``` -``` +```bash apt-get -y install gdb vim git cmake make ccache build-essential libssl-dev bison flex default-libmysqlclient-dev libpq-dev libedit-dev monitoring-plugins apt-get install -y libboost1.67-icinga-all-dev @@ -1529,14 +1531,14 @@ cmake .. $I2_DEBUG cd .. ``` -``` +```bash make -j2 install -C debug ``` The source installation doesn't set proper permissions, this is handled in the package builds which are officially supported. -``` +```bash chown -R icinga:icinga /usr/local/icinga2/var/ /usr/local/icinga2/lib/icinga2/prepare-dirs /usr/local/icinga2/etc/sysconfig/icinga2 @@ -1569,13 +1571,13 @@ This requires at least v2.11. Explicitly use OpenSSL 1.1.x, older versions are out of support. -``` +```bash brew install ccache boost cmake bison flex openssl@1.1 mysql-connector-c++ postgresql libpq ``` ##### ccache -``` +```bash sudo mkdir /opt/ccache sudo ln -s `which ccache` /opt/ccache/clang @@ -1596,7 +1598,7 @@ typically run slower than release builds and must not be used for performance be The preferred installation prefix is `/usr/local/icinga/icinga2`. This allows to put e.g. Icinga Web 2 into the `/usr/local/icinga` directory as well. -``` +```bash mkdir -p release debug export I2_USER=$(id -u -n) @@ -1616,7 +1618,7 @@ make -j4 install -C debug In order to run Icinga without any path prefix, and also use Bash completion it is advised to source additional things into the local dev environment. -``` +```bash export PATH=/usr/local/icinga/icinga2/sbin/:$PATH test -f /usr/local/icinga/icinga2/etc/bash_completion.d/icinga2 && source /usr/local/icinga/icinga2/etc/bash_completion.d/icinga2 @@ -1626,7 +1628,7 @@ test -f /usr/local/icinga/icinga2/etc/bash_completion.d/icinga2 && source /usr/l This is derived from [dnsmichi's flavour](https://github.com/dnsmichi/dotfiles) and not generally best practice. -``` +```bash vim $HOME/.bash_profile export I2_USER=$(id -u -n) @@ -1650,7 +1652,7 @@ source $HOME/.bash_profile `make install` doesn't set all required permissions, override this. -``` +```bash chown -R $I2_USER:$I2_GROUP /usr/local/icinga/icinga2 ``` @@ -1658,7 +1660,7 @@ chown -R $I2_USER:$I2_GROUP /usr/local/icinga/icinga2 Start Icinga in foreground. -``` +```bash icinga2 daemon ``` @@ -1666,23 +1668,26 @@ Reloads triggered with HUP or cluster syncs just put the process into background #### Plugins -``` +```bash brew install monitoring-plugins sudo vim /usr/local/icinga/icinga2/etc/icinga2/constants.conf +``` + +``` const PluginDir = "/usr/local/sbin" ``` #### Backends: Redis -``` +```bash brew install redis brew services start redis ``` #### Databases: MariaDB -``` +```bash brew install mariadb mkdir -p /usr/local/etc/my.cnf.d brew services start mariadb @@ -1702,7 +1707,7 @@ ln -s /Users/michi/.my.cnf $HOME/.my.cnf exit ``` -``` +```bash mysql -e 'create database icinga;' mysql -e "grant all on icinga.* to 'icinga'@'localhost' identified by 'icinga';" mysql icinga < $HOME/dev/icinga/icinga2/lib/db_ido_mysql/schema/mysql.sql @@ -1710,7 +1715,7 @@ mysql icinga < $HOME/dev/icinga/icinga2/lib/db_ido_mysql/schema/mysql.sql #### API -``` +```bash icinga2 api setup cd /usr/local/icinga/icinga2/var/lib/icinga2/certs HOST_NAME=mbpmif.int.netways.de @@ -2131,7 +2136,7 @@ The following examples source from armhf on Raspberry Pi. #### ccache -``` +```bash apt install -y ccache /usr/sbin/update-ccache-symlinks @@ -2145,13 +2150,14 @@ source ~/.bashrc && echo $PATH Copy the icinga2 source code into `$HOME/icinga2`. Clone the `deb-icinga2` repository into `debian/`. -``` +```bash git clone https://github.com/Icinga/icinga2 $HOME/icinga2 git clone https://github.com/Icinga/deb-icinga2 $HOME/icinga2/debian ``` Then build a Debian package and install it like normal. -``` + +```bash dpkg-buildpackage -uc -us ``` @@ -2219,26 +2225,26 @@ external command pipe and livestatus features require a dedicated command group `icingacmd`. You can choose your own user/group names and pass them to CMake using the `ICINGA2_USER`, `ICINGA2_GROUP` and `ICINGA2_COMMAND_GROUP` variables. -``` -# groupadd icinga -# groupadd icingacmd -# useradd -c "icinga" -s /sbin/nologin -G icingacmd -g icinga icinga +```bash +groupadd icinga +groupadd icingacmd +useradd -c "icinga" -s /sbin/nologin -G icingacmd -g icinga icinga ``` On Alpine (which uses ash busybox) you can run: -``` -# addgroup -S icinga -# addgroup -S icingacmd -# adduser -S -D -H -h /var/spool/icinga2 -s /sbin/nologin -G icinga -g icinga icinga -# adduser icinga icingacmd +```bash +addgroup -S icinga +addgroup -S icingacmd +adduser -S -D -H -h /var/spool/icinga2 -s /sbin/nologin -G icinga -g icinga icinga +adduser icinga icingacmd ``` Add the web server user to the icingacmd group in order to grant it write permissions to the external command pipe and livestatus socket: -``` -# usermod -a -G icingacmd www-data +```bash +usermod -a -G icingacmd www-data ``` Make sure to replace "www-data" with the name of the user your web server @@ -2249,18 +2255,18 @@ is running as. Once you have installed all the necessary build requirements you can build Icinga 2 using the following commands: -``` -$ mkdir release && cd release -$ cmake .. -$ cd .. -$ make -C release -$ make install -C release +```bash +mkdir release && cd release +cmake .. +cd .. +make -C release +make install -C release ``` You can specify an alternative installation prefix using `-DCMAKE_INSTALL_PREFIX`: -``` -$ cmake .. -DCMAKE_INSTALL_PREFIX=/tmp/icinga2 +```bash +cmake .. -DCMAKE_INSTALL_PREFIX=/tmp/icinga2 ``` ### CMake Variables @@ -2351,7 +2357,7 @@ can be used to disable the usage of `git describe`. Setup your build environment: -``` +```bash yum -y install rpmdevtools ``` @@ -2359,7 +2365,7 @@ yum -y install rpmdevtools SLES: -``` +```bash zypper addrepo http://download.opensuse.org/repositories/devel:tools/SLE_12_SP4/devel:tools.repo zypper refresh zypper install rpmdevtools spectool @@ -2367,7 +2373,7 @@ zypper install rpmdevtools spectool OpenSuSE: -``` +```bash zypper addrepo http://download.opensuse.org/repositories/devel:tools/openSUSE_Leap_15.0/devel:tools.repo zypper refresh zypper install rpmdevtools spectool @@ -2377,14 +2383,14 @@ zypper install rpmdevtools spectool Prepare the rpmbuild directory tree: -``` +```bash cd $HOME rpmdev-setuptree ``` Snapshot builds: -``` +```bash curl https://raw.githubusercontent.com/Icinga/rpm-icinga2/master/icinga2.spec -o $HOME/rpmbuild/SPECS/icinga2.spec ``` @@ -2396,7 +2402,7 @@ curl https://raw.githubusercontent.com/Icinga/rpm-icinga2/master/icinga2.spec -o Copy the tarball to `rpmbuild/SOURCES` e.g. by using the `spectool` binary provided with `rpmdevtools`: -``` +```bash cd $HOME/rpmbuild/SOURCES spectool -g ../SPECS/icinga2.spec @@ -2405,7 +2411,7 @@ cd $HOME/rpmbuild Install the build dependencies. Example for CentOS 7: -``` +```bash yum -y install libedit-devel ncurses-devel gcc-c++ libstdc++-devel openssl-devel \ cmake flex bison boost-devel systemd mysql-devel postgresql-devel httpd \ selinux-policy-devel checkpolicy selinux-policy selinux-policy-doc @@ -2415,13 +2421,13 @@ Note: If you are using Amazon Linux, systemd is not required. A shorter way is available using the `yum-builddep` command on RHEL based systems: -``` +```bash yum-builddep SPECS/icinga2.spec ``` Build the RPM: -``` +```bash rpmbuild -ba SPECS/icinga2.spec ``` @@ -2441,7 +2447,7 @@ The RedHat Developer Toolset is required for building Icinga 2 beforehand. This contains a modern version of flex and a C++ compiler which supports C++11 features. -``` +```bash cat >/etc/yum.repos.d/devtools-2.repo <$HOME/.rpmmacros < /etc/sudoers.d/dirk +```bash +semanage login -a dirk -s staff_u +echo "dirk ALL=(ALL) NOPASSWD: ALL" > /etc/sudoers.d/dirk ``` Login to the system using ssh and verify your id. @@ -278,8 +278,8 @@ $ sudo -r icinga2adm_r -t icinga2adm_t systemctl reload icinga2.service Now the commands will work, but you have always to remember to add the arguments, so change the sudo rule to set it by default. -``` -# echo "dirk ALL=(ALL) ROLE=icinga2adm_r TYPE=icinga2adm_t NOPASSWD: ALL" > /etc/sudoers.d/dirk +```bash +echo "dirk ALL=(ALL) ROLE=icinga2adm_r TYPE=icinga2adm_t NOPASSWD: ALL" > /etc/sudoers.d/dirk ``` Now try the commands again without providing the role and type and they will work, but if you try to read apache logs or restart apache for example it will still fail.