Redhat安装icinga2

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介:

Redhat安装icinga2

 

指导参考网址:http://docs.icinga.org/icinga2/latest/doc/module/icinga2/toc

所需rpm包下载网址:http://packages.icinga.org/epel/

https://packages.icinga.org/epel/6/release/noarch/  icingaweb2包)

 

php-intlphp-pecl-imagick需要单独下

 

 

需要的包:libboost_system1libboost_thread1libboost_regex1libeditboost-license1、libboost_program_options1icinga2icinga2-binicinga2-common、icinga2-ido-mysqlicingaweb2icingaweb2-commonicingaweb2-vendor-*6个)、php-icingaicingaclinagios-plugins

 

安装httpd

# yum install httpd

# yum install php php-gd (注意php版本和icinga2等匹配,如果不匹配就得手动下重装了)

 

php相关包有:phpphp-cliphp-commonphp-gdphp-intlphp-mysqlphp-pdophp-xml

 

额外包:fpingperl-NET-SNMPperl-Crypt-DES  (需先下载好)

 

# rpm -i libboost* boost-license (需先下载好)

# rpm -i libicu-4.2.1-8.2.x86_64.rpm (需先下载好)

# rpm -i icinga2*  php-icinga    (需先下载好)

# rpm -i perl-Crypt-DES perl-NET-SNMP fping perl-Digest-SHA1 perl-Digest-HMACperl-Socket6

# rpm -i nagios-plugins-1.4.16-1.el6.rf.x86_64.rpm

如果提示下面相关报错,做下链接即可

# ln -s /usr/lib64/libicui18n.so.42 /usr/lib64/libicui18n.so.36

# ln -s /usr/lib64/libicuuc.so.42 /usr/lib64/libicuuc.so.36

# ln -s /usr/lib64/libicudata.so.42 /usr/lib64/libicudata.so.36

# ln -s /usr/lib64/libMagickWand.so.2 /usr/lib64/libMagickWand.so.5

 

Log路径:/var/log/icinga2/icinga2.log

 

安装mysql

# yum install mysql-server

 

# mysql-u root  

  • use mysql;

  • update user set password=password(’xxxx’) where user=’root’;

  • flush privileges;

  • quit

 

# mysql -u root -p’xxxx’

  • create database icinga2;

  • grant all on icinga2.* to icinga2@localhost identified by ‘xxxxxx’;

  • flush privileges;

  • quit

 

# mysql -u root -p’xxxx’  icinga2 </usr/share/icinga2-ido-mysql/schema/mysql.sql

 

 

# rpm -i icingaweb2-*

 

# service icinga2 restart

# service httpd restart


# vi /etc/php.ini (查找timezone) 


date.timezone = Asia/Shanghai

:wq


# service httpd restart (不然访问页面时会报timezone错误)

 

页面访问:http://ip/icingaweb2

 

暂时还不能登录,点击账号上面的web-basedsetup-wizard

 

然后照着提示在命令行里操作:

 

# icingacli setup config directory --group icingaweb2

# icingacli setup token create

# su -c"mkdir -m 2770 /etc/icingaweb2;chgrp icingaweb2 /etc/icingaweb2;head -c 12 /dev/urandom | base64 | tee /etc/icingaweb2/setup.token;chmod 0660 /etc/icingaweb2/setup.token;"

 

然后将乱码贴到页面上

 

模块部分全勾,然后会提示the phpconfig 'date.timezone' is not defined

 

# vi/etc/php5/apache2/php.ini

 

date.timezone= Asia/Shanghai   (默认是注释掉的)

 

:wq

# service httpd restart

 

再点击refresh即可(其它***提示可忽略)——Database——将数据库、用户名等补上,勾上Skip Validation——设置管理账号及密码

 

如果提示没有icingaweb_user表,就手动创建下吧,命令如下:

  • use icinga2;

  • create table icingaweb_user (name varchar(64) not null,activetinyint(1) not null,password_hash varbinary(255) not null,ctime timestamp,mtimetimestamp);

 

如果页面显示“icinga is currently notup and running” ,一是看/etc/icinga2/features-enabled/下是否有ido-mysql.conf,如果没有从/etc/icinga2/features-available/处链接过来即可;二是看/var/log/icinga2/icinga2.log提示

 

 

 

添加主机:

 

# cd /etc/icinga2/conf.d/

# vi shhudson.conf

 

object Host"hudson15" {

  import "generic-host"

  address = "10.0.0.2"

  vars.os = "Linux Servers"

  vars.sla = "24x7"

}

:wq

# chown icinga:icinga shhudson.conf

# service icinga2 restart 

 

此时页面上就会显示“hudson15”主机

 

添加主机组:

 

# cd /etc/icinga2/conf.d/

# vi groups.conf

 

object HostGroup"shhudson" {

  display_name = "shhudson"

  assign where host.vars.os =="shhudson"

}

:wq

# service icinga2 restart

 

此时页面上就会显示“shhudson”主机组

 

 

 

安装nrpe(管理多台主机)

 

# rpm -i nagios-plugins-nrpe-2.14-1.el6.rf.x86_64.rpm(需先下载好)

 

此时会生成/usr/lib64/nagios/plugins/check_nrpe

 

# /usr/lib64/nagios/plugins/check_nrpe-H 10.0.1.57   (显示NRPE v2.12即为正常,前提是客户端已安装nrpe插件)

 

 

配置nrpe

 

说明:空间大小以MB为单位,KMB1000MB1GB),MMB1000000MB(即1TB


另check_mem.pl需额外下载插件使用(步骤略)

 

# vi /etc/icinga2/conf.d/templates.conf

templateCheckCommand "nrpe-common" {

  import "plugin-check-command"

  command = [ PluginDir +"/check_nrpe" ]

  arguments = {

  "-H" = "$nrpe_address$"

  "-p" = "$nrpe_port$"

  "-c" = "$nrpe_command$"

  "-a" = {

       value = "$nrpe_args$"

       repeat_key = false

       order = 1

}

}

  vars.nrpe_address = "$address$"

  vars.nrpe_port = 5666

}

 

objectCheckCommand "nrpe-disk" {

   import "nrpe-common"

   vars.nrpe_command = "check_disk"

}

 

objectCheckCommand "nrpe-load" {

   import "nrpe-common"

   vars.nrpe_command = "check_load"

}

 

objectCheckCommand "nrpe-users" {

   import "nrpe-common"

   vars.nrpe_command = "check_users"

}

:wq

 

# vi/etc/icinga2/conf.d/services.conf

 

applyService "nrpe-disk" {

  import "generic-service"

  check_command = "nrpe-disk"

  assign where host.address

}

 

apply Service"nrpe_load" {

  import "generic-service"

  check_command = "nrpe-load"

  assign where host.address

}

 

applyService "nrpe_users" {

  import "generic-service"

  check_command = "nrpe-users"

  assign where host.address

}

:wq

 

# vi /etc/icinga2/conf.d/shhudson.conf

object Host"hudson15" {

  import "generic-host"

  address = "10.0.0.2"

  vars.os = "Linux Servers"

  vars.sla = "24x7"

}

 

:wq

# service icinga2restart

 

 

命令使用:

# /usr/lib64/nagios/plugins/check_nrpe -H tjandroid03 -c check_disk -a 10,20

 

 

客户端安装nrpe插件:

 

Ubuntu

 

# useradd -s /sbin/nologin -M nagios
# apt-get install nagios-nrpe-server nagios-plugins
编辑nrpe配置文件
# vi /etc/nagios/nrpe.cfg

allowed_hosts=127.0.0.1,10.0.0.232   (默认为allowed_hosts=127.0.0.1)

dont_blame_nrpe=1
:wq

启动nrpe
# service nagios-nrpe-server start

 

 

Redhat:

 

# rpm –iperl-Crypt-DES perl-NET-SNMP fping perl-Digest-SHA1 perl-Digest-HMACperl-Socket6  (需要下载,有的本地yum里有)

# rpm –inagios-plugins-1.4.16-1.el6.rf.x86_64.rpm

# rpm –inagios-nrpe-2.14-1.el6.rf.x86_64.rpm  (需要下载)

# vi /etc/nagios/nrpe.cfg

allowed_hosts=127.0.0.1,10.0.0.232   (默认为allowed_hosts=127.0.0.1)

dont_blame_nrpe=1
:wq

启动nrpe
# service nrpe start

 

记得开防火墙端口(199、5666,即snmp和nrpe)

# vi /etc/sysconfig/iptables

 

-A INPUT–p tcp –dport 199 –j ACCEPT

-A INPUT–p tcp –dport 5666 –j ACCEPT

:wq

# service iptables restart

 

 

安装pnp4nagios

 

下载网址:https://github.com/Icinga/icinagweb2-module-pnp4ngaios

 

下载后解压并改名为pnp4nagios,剪切到/usr/share/icingaweb2/modules/

重启icinga2后,到页面——Configuration——Modules——pnp4nagios——enable

 

下载pnp4nagios rpm

 

# rpm –i pnp4nagios –nodeps

# rpm –i perl-rrdtool –nodeps

 

安装后会自动生成/etc/httpd/conf.d/pnp4ngaios.conf  (如果不设置用户、密码,可在此处取消)

 

主配置文件路径:/etc/pnp4ngaios

 

还有1路径:/usr/share/nagios/html/pnp4ngios  (实际web路径)

 

# vi/etc/pnp4nagios/npcd.cfg

 

User  = icinga

Group =icinga

Perfdata_spool_dir=/var/spool/icinga2/perfdata

:wq

 

 

# vi/etc/icinga2/conf.d/templates.conf

 

template Host "pnp-hst" {

   action_url ="/pnp4nagios/graph?host=$HOSTNAME$'rel='/pnp4nagios/popup?host=$HOSTNAME$&srv=_HOST_"

}

 

template Service "pnp-svc" {

   action_url ="/pnp4nagios/graph?host=$HOSTNAME$&srv=$SERVICEDESC$'rel='/pnp4nagios/popup?host=$HOSTNAME$&srv=$SERVICEDES$"

}

 

 

template Host "generic-host" {

  max_check_attempts = 3

  check_interval = 1m

  retry_interval = 30s

  check_command = "hostalive"

  import "pnp-hst"

}

 

template Service "generic-service" {

  max_check_attempts = 5

  check_interval = 1m

  retry_interval = 30s

  import "pnp-svc"

}

:wq


# chown icinga /var/lig/pnp4nagios

 

# icinga2 feature enable perfdata

 

# service httpd restart

# service npcd restart

# service icinga2 restart

 

 

可先访问下http://ip/pnp4ngaios是否正常,不能正常显示的话就看httpdlog

 

 

发报警邮件

说明:默认为30分钟发一次

 

# vi/etc/icinga2/conf.d/users.conf

 

Email = zhi.yang@ming.com

:wq

 

# vi /etc/icinga2/conf.d/shhudson.conf

object Host"hudson15" {

  import "generic-host"

  address = "10.0.0.2"

  vars.os = "Linux Servers"

  vars.sla = "24x7"

  vars.notification[“mail”] = {

   groups = [ “icingaadmins” ]

}

}

:wq

 

# service icinga2 restart

 

# vi/etc/postfix/main.cf

 

Relayhost= 10.0.1.5    (公司的邮箱服务器)

:wq

 

# service postfix restart

 

可手动发邮件验证下:

# mail –s“aa” zhi.yang@ming.com < aa

 

# cat/var/log/maillog

 

调整发邮件级别:

 

# vi/etc/icinga2/conf.d/templates.conf

 

调整states部分即可

:wq

 

可以对user进行定制(多邮件人通知):


# vi /etc/icinga2/conf.d/users.conf


object User "bj"

 import "generic-user"

 states = [ OK,Critical]  (此处对报警类型也可定制)

 email = "zhi.yang@ming.com,ming.yang@ming.com"  (此处可以写多人)

:wq


# vi /etc/icinga2/conf.d/shhudson.conf

object Host"hudson15" {

  import "generic-host"

  address = "10.0.0.2"

  vars.os = "Linux Servers"

  vars.sla = "24x7"

  vars.notification[“mail”] = {

  users = [ “bj” ]    (多user中间用“,”隔开)

}

}

:wq

 




 

监控存储(check-netapp-ng.pl):

 

下载网址:https://github.com/ranl/monitor-utils/blob/master/nagios/check-netapp-ng.pl

 

# mv check-netapp-ng.pl/usr/lib64/nagios/plugins/

# chmod +x /usr/lib64/nagios/plugins/check-netapp-ng.pl

 

使用:

 

卷:

# /usr/lib64/nagios/plugins/check-netapp-ng.pl–H 10.0.0.3 –C public –T DISKUSED –vol /vol/Backup –w 90 –c 95

 

整体状态:

# /usr/lib64/nagios/plugins/check-netapp-ng.pl–H 10.0.0.3 –C public –T GLOBALSTATUS

 

CPU:

# /usr/lib64/nagios/plugins/check-netapp-ng.pl–H 10.0.0.3 -C public -T CPULOAD –w 90 –c 95




icinga2监控存储整体状态(单个卷超过98%会报警的):

 

# vi/etc/icinga2/conf.d/templates.conf

 

objectCheckCommand "check-netapp" {

  import "plugin-check-command"

  command = [ PluginDir +"/check-netapp-ng.pl" ]

  arguments = {

  "-H" = "$address$"

  "-C" = "$snmp$"

  "-T" = "$checktype$"

  "-w" = "$warn$"

  "-c" = "$crit$"

}

}

:wq

 

# vi/etc/icinga2/conf.d/services.conf

 

applyService "check_netapp" {

  import "generic-service"

  check_command = "check-netapp"

  vars.snmp="public"

  vars.checktype="GLOBALSTATUS"

  vars.vol="/vol/Backup/"

  assign where host.vars.os =="netapp"

}

:wq

 

# vi/etc/icinga2/conf.d/netapp.conf

 

objectHost "shnas7" {

  import "generic-host"

  address = "10.0.1.21"

  vars.os = "netapp"

  vars.sla = "24x7"

  vars.notification["mail"] = {

  groups = [ "icingaadmins" ]

}

}

:wq

 

# chownicinga:icinga /etc/icinga2/conf.d/netapp.conf

# service icinga2 restart

 


监控windows主机:


需要借助3个插件:check_snmp_storage.pl、check_snmp_memory.pl、check_snmp_load.pl


下载网址:

http://nagios.manubulon.com/check_snmp_load.pl

https://exchange.nagios.org/directory/Plugins/Network-Protocols/SNMP/Simple-snmp-memory-check/details

https://github.com/dnsmichi/manubulon-snmp/blob/master/plugins/check_snmp_storage.pl



使用:


# ./check_snmp_load.pl -H 10.0.0.3 -C public -w 80 -c 90

# ./check_snmp_memory.pl -H 10.0.0.3 -C public -w 80 -c 90

# ./check_snmp_storage.pl -H 10.0.0.3 -C public -m D: -w 80 -c 90


# vi/etc/icinga2/conf.d/templates.conf

 

objectCheckCommand "check-win-disk" {

  import "plugin-check-command"

  command = [ PluginDir +"/check_snmp_storage.pl" ]

  arguments = {

  "-H" = "$address$"

  "-C" = "$snmp$"

  "-m" = "$disk$"

  "-w" = "$warn$"

  "-c" = "$crit$"

 "-f" = {

         set_if = "$perf$"

    }

}

}


objectCheckCommand "check-win-mem" {

  import "plugin-check-command"

  command = [ PluginDir +"/check_snmp_memory.pl" ]

  arguments = {

  "-H" = "$address$"

  "-C" = "$snmp$"

  "-w" = "$warn$"

  "-c" = "$crit$"

 "-f" = {

         set_if = "$perf$"

    }

}

}


objectCheckCommand "check-win-load" {

  import "plugin-check-command"

  command = [ PluginDir +"/check_snmp_load.pl" ]

  arguments = {

  "-H" = "$address$"

  "-C" = "$snmp$"

  "-w" = "$warn$"

  "-c" = "$crit$"

 "-f" = {

         set_if = "$perf$"

    }

}

}

:wq


# vi /etc/icinga2/conf.d/services.conf

 

applyService "check_win_disk" {

  import "generic-service"

  check_command = "check-win-disk"

  vars.snmp="public"

  vars.disk="C:"

  vars.warn="80"

  vars.crit="90"

  vars.perf = true

  assign where host.vars.os =="shwin"

}


apply Service "check_win_load" {

  import "generic-service"

  check_command = "check-win-load"

  vars.snmp="public"

  vars.warn="80"

  vars.crit="90"

  vars.perf = true

  assign where host.vars.os == "shwin"

}


apply Service "check_win_mem" {

  import "generic-service"

  check_command = "check-win-mem"

  vars.snmp="public"

  vars.warn="80"

  vars.crit="90"

  vars.perf = true

  assign where host.vars.os == "shwin"

}


:wq


# vi /etc/icinga2/conf.d/shwin.conf

object Host"shwin" {

  import "generic-host"

  address = "10.0.0.3"

  vars.os = "shwin"

  vars.sla = "24x7"

  vars.notification[“mail”] = {

  users = [ “bj”,“aa” ]    (多user中间用“,”隔开)

}

}

:wq


# chown icinga:icinga /etc/icinga2/conf.d/shwin.conf


修改groups.conf略


# service icinga restart



windows安装snmp


控制面板——程序和功能——打开或关闭windows功能——勾选SNMP——开始——搜索——输入服务——确保SNMP service是启动状态——双击——安全——添加社区“public”(此处可改)——确认防火墙关闭

本文转自linux博客51CTO博客,原文链接http://blog.51cto.com/yangzhiming/1729991如需转载请自行联系原作者


yangzhimingg

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
6月前
|
安全 Linux 网络安全
如何在 VM 虚拟机中安装 Red Hat Enterprise Linux 9.3 操作系统保姆级教程(附链接)
如何在 VM 虚拟机中安装 Red Hat Enterprise Linux 9.3 操作系统保姆级教程(附链接)
|
存储 关系型数据库 MySQL
Red Hat 安装MySQL 8.0与 Navicat
Red Hat 安装 MySQL 8.0 1、更新软件包列表 在添加 MySQL 存储库后,运行以下命令以更新软件包列表: sudo yum update 2、安装MySQL服务器和客户端 执行以下命令安装MySQL 8.0服务器和客户端软件包: sudo yum install -y mysql-server 3、启动MySQL服务 安装完成后,MySQL 服务器应该已经自动启动。如果没有启动,您可以运行以下命令手动启动服务: sudo systemctl start mysqld 启用 MySQL 服务的开机启动,可以运行以下命令: sudo systemctl enable mysqld
261 1
|
20天前
|
消息中间件 Linux RocketMQ
在Red Hat Enterprise Linux 9上使用Docker快速安装并部署
通过以上步骤,你可以在Red Hat Enterprise Linux 9上使用Docker快速安装并部署RocketMQ。这种方法不仅简化了安装过程,还提供了一个灵活的环境来管理和扩展消息队列系统。RocketMQ作为一款高性能的分布式消息系统,通过Docker可以实现快速部署和高效管理。
48 2
|
21天前
|
消息中间件 Linux RocketMQ
在Red Hat Enterprise Linux 9上使用Docker快速安装并部署
通过以上步骤,你可以在Red Hat Enterprise Linux 9上使用Docker快速安装并部署RocketMQ。这种方法不仅简化了安装过程,还提供了一个灵活的环境来管理和扩展消息队列系统。RocketMQ作为一款高性能的分布式消息系统,通过Docker可以实现快速部署和高效管理。
31 3
|
6月前
|
Linux Docker 容器
Red Hat系列Docker安装与移除
Docker 安装 添加 Docker 官方 YUM 源 sudo yum-config-manager --add-repo=https://download.docker.com/linux/centos/docker-ce.repo 安装 Docker Engine sudo yum install -y docker-ce docker-ce-cli containerd.io 启动 Docker 服务并设置开机自启 sudo systemctl start docker sudo systemctl enable docker 验证 Docker 安装 docker --versio
205 0
|
存储 Java Linux
Red Hat 安装JDK与IntelliJ IDEA
YUM是基于Red Hat的Linux发行版的一个强大而用户友好的包管理工具。轻松地管理软件包,无需手动配置环境变量,也不必担心解决依赖关系。它从远程存储库获取软件包,并处理安装过程,使其非常方便。YUM在维护系统稳定性和正常运行方面扮演着关键角色,通过有效地管理软件包更新和依赖关系。
145 5
|
关系型数据库 Linux 数据库
百度搜索:蓝易云【Redhat Linux9上安装DB2【详解】】
注意事项: - 安装过程中需要注意所选的软件包版本和系统依赖。 - 在创建 DB2 用户和组时,可以使用自己的用户名和组名,但需要与后续操作一致。 - 在配置环境变量时,需要注意所填写的路径是否正确,否则会导致启动 DB2 失败。 - 在启动 DB2 时,需要以 DB2 用户身份进行操作,否则会提示权限不足。
106 0
|
网络协议 关系型数据库 MySQL
Red Hat enterprise linux 5 -mysql安装步骤
Red Hat enterprise linux 5 -mysql安装步骤
|
编解码 Java Linux
linux【redhat&ubuntu】下ffmpeg-3.1安装编译及视频转码
这篇是几年前整理的老文章了,当时在调研流视频推送及播放相关技术,并在项目中应用,使用到ffmpeg,所以整理了这篇文章,但并未发布。最近又有相关的技术需求,所以整理出来,作为一个新的开始。
300 0
|
存储 缓存 运维
运维 --- Nginx介绍和在CentOS/Redhat下安装
运维 --- Nginx介绍和在CentOS/Redhat下安装
运维 --- Nginx介绍和在CentOS/Redhat下安装

推荐镜像

更多