[toc]
#

Linux监控平台介绍

常见的有 cacti、nagios、zabbix、smokeping、open-falcon等等。

cacti、smokeping偏向于基础监控,成图非常漂亮。

cacti、nagios、zabbix服务端监控中心,需要php环境支持,其中zabbix和cacti都需要mysql作为数据存储,这几款监控软件均有web操作界面。

nagios不用存储历史数据,注重服务或者监控项的状态。

zabbix优势:

zabbix会获取服务或者监控项目的数据,会把数据记录到数据库里,从而可以成图,可以增加配置节点,增加具体的监控节点,可以配置报警阈值等,所以为什么如此流行其原因就在此,尤其是我们可以很方面的使用鼠标就可以完成一系列的操作,定义规则等。

open-falcon为小米公司开发,开源后受到诸多大公司和运维工程师的追捧,适合大企业,滴滴、360、新浪微博、京东等大公司在使用这款监控软件,值得研究。

二、 zabbix 监控介绍:

C/S架构(被监控的server需要安装监控软件,既可以主动连接客户端,也可以被动的让客户端推送自己的状态),基于C++开发,监控中心支持web界面配置和管理。

单server节点可以支持上万台客户端(可支持同时上万台的server监控,并发量高,如果超过一定的量,性能可能会降低,但是我们可以增加Proxy代理点来充当监控服务器来减轻压力)

  • 最新版本3.4,官方文档https://www.zabbix.com/manuals

5个组件

  • [ ] zabbix-server 监控中心,接收客户端上报信息,负责配置、统计、操作数据。

  • [ ] 数据存储 存放数据,比如mysql。

  • [ ] web界面 也叫web UI,在web界面下操作配置是zabbix简单易用的主要原因。

  • [ ] zabbix-proxy 可选组件,它可以代替zabbix-server的功能,减轻server的压力。

  • [ ] zabbix-agent 客户端软件,负责采集各个监控服务或项目的数据,并上报。

zabbix监控流程图

三、Zabbix监控安装与部署

3.1 下载所需的zabbix的yum源

官方下载地址:
https://www.zabbix.com/download

下载yum扩展源并安装

[root@xavi ~]# wget http://repo.zabbix.com/zabbix/3.2/rhel/7/x86_64/zabbix-release-3.2-1.el7.noarch.rpm
[root@xavi ~]# rpm -ivh http://repo.zabbix.com/zabbix/3.2/rhel/7/x86_64/zabbix-release-3.2-1.el7.noarch.rpm

查看

[root@xavi ~]# cat /etc/yum.repos.d/ 按两次tab键
CentOS7-Base-163.repo  CentOS-Debuginfo.repo  CentOS-Media.repo      CentOS-Vault.repo      epel-testing.repo
CentOS-CR.repo         CentOS-fasttrack.repo  CentOS-Sources.repo    epel.repo              zabbix.repo
  • 查看安装文件
[root@xavi ~]# cat /etc/yum.repos.d/zabbix.repo
[zabbix]
name=Zabbix Official Repository - $basearch
baseurl=http://repo.zabbix.com/zabbix/3.2/rhel/7/$basearch/
enabled=1
gpgcheck=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-ZABBIX-A14FE591

[zabbix-non-supported]
name=Zabbix Official Repository non-supported - $basearch 
baseurl=http://repo.zabbix.com/non-supported/rhel/7/$basearch/
enabled=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-ZABBIX
gpgcheck=1

安装相关安装包,会连带安装httpd和php

[root@xavi ~]# yum install -y zabbix-agent zabbix-get zabbix-server-mysql zabbix-web zabbix-web-mysql 

安装mysql(两种方法,①yum安装 ②编译mysql安装<安装LAMP的时候>):

# yum install -y mysql mysql-server mysql-devel 

# systemctl start mysqld

# ps aux | grep mysql //若未启动,可开启

mysql启动报错,查看日志

# systemctl start mysql 报错
# less /data/mysql/xavilinux.err 查看错误日志
# ls -l /data/mysql/ 查看MySQL下的文件权限
# chown -R mysql:mysql /data/mysql/
复制后再次启动

3.2 编辑mysql配置文件

[root@xavi ~]# vim /etc/my.cnf
character_set_server = utf8

如果不添加此值,后期zabbix的web界面改成中文后会出现问题。

重启mysqld服务

[root@xavi ~]# /etc/init.d/mysqld start
Starting MySQL... SUCCESS!

进入mysql命令行,创建zabbix库和用户

(这个就类似于之前创建wordpress,discuz站点一样的,其实zabbix也是一个php写的web监控站点)

[root@xavi ~]# mysql -uroot -pxavilinux
mysql> create database zabbix character set utf8;
Query OK, 1 row affected (0.00 sec)

mysql> grant all on zabbix.* to 'zabbix'@'127.0.0.1' identified by 'xavi-zabbix';
Query OK, 0 rows affected (0.00 sec)

导入zabbix数据库

[root@xavi ~]# cd /usr/share/doc/zabbix-server-mysql-3.2.11/

[root@xavi zabbix-server-mysql-3.2.11]# ls
AUTHORS  ChangeLog  COPYING  create.sql.gz  NEWS  README

[root@xavi zabbix-server-mysql-3.2.11]# gzip -d create.sql.gz //解压
[root@xavi zabbix-server-mysql-3.2.11]# ls
AUTHORS  ChangeLog  COPYING  create.sql  NEWS  README
[root@xavi zabbix-server-mysql-3.2.11]# mysql -uroot -pxavilinux zabbix < create.sql
//导入数据库
Warning: Using a password on the command line interface can be insecure.

3.3 启动zabbix-server,和httpd服务

如果之前有配置nginx,或者tomcat(配置了80端口)服务一定要先停掉。不然启动httpd会报错

[root@xavi ~]# systemctl start zabbix-server
[root@xavi ~]# systemctl start httpd
Job for httpd.service failed because the control process exited with error code. See "systemctl status httpd.service" and "journalctl -xe" for details.

通过端口查找,发现被java(tomcat)占用了80端口

[root@xavi ~]# lsof -i:80
COMMAND  PID USER   FD   TYPE DEVICE SIZE/OFF NODE NAME
java    2594 root   49u  IPv6  26769      0t0  TCP *:http (LISTEN)

关闭tomcat

[root@xavi ~]# /usr/local/tomcat/bin/shutdown.sh
Using CATALINA_BASE:   /usr/local/tomcat
Using CATALINA_HOME:   /usr/local/tomcat
Using CATALINA_TMPDIR: /usr/local/tomcat/temp
Using JRE_HOME:        /usr/local/jdk1.8
Using CLASSPATH:       /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar
[root@xavi ~]# lsof -i:80
[root@xavi ~]#  systemctl start httpd

配置开机启动:

[root@xavi ~]# systemctl enable httpd
Created symlink from /etc/systemd/system/multi-user.target.wants/httpd.service to /usr/lib/systemd/system/httpd.service.
[root@xavi ~]# systemctl enable zabbix-server
Created symlink from /etc/systemd/system/multi-user.target.wants/zabbix-server.service to /usr/lib/systemd/system/zabbix-server.service.

3.4 查看zabbix的日志,发现虽启动zabbix但未连接mysql

[root@xavi ~]# ps aux |grep zabbix
zabbix    10131  0.0  0.1 258216  3472 ?        S    15:44   0:00 /usr/sbin/zabbix_server -c /etc/zabbix/zabbix_server.conf
root      11441  0.0  0.0 112684   976 pts/0    S+   17:21   0:00 grep --color=auto zabbix
[root@xavi ~]# less /var/log/zabbix/zabbix_server.log

5. 重新编辑配置zabbix:

[root@xavi ~]# vim /etc/zabbix/zabbix_server.conf 
//修改或增加
DBHost=127.0.0.1    //在DBName=zabbix上面增加
(在此写的是本地的mysql,但是线上的环境一般都有指定的mysql地址)

DBUser=zabbix
DBPassword=xavi-zabbix     //在DBuser下面增加,要和之前mysql配置的用户密码一致

再次重启zabbix

# systemctl restart zabbix-server
[root@xavi ~]# !ps
ps aux |grep zabbix
zabbix    11552  0.0  0.2 258396  4144 ?        S    17:30   0:00 /usr/sbin/zabbix_server -c /etc/zabbix/zabbix_server.conf
zabbix    11554  0.0  0.1 258396  2492 ?        S    17:30   0:00 /usr/sbin/zabbix_server: configuration syncer [waiting 60 sec for processes]
zabbix    11555  0.0  0.1 258396  2696 ?        S    17:30   0:00 /usr/sbin/zabbix_server: db watchdog [synced alerts config in 0.012630 sec, idle 60 sec]
zabbix    11556  0.0  0.2 365328  5192 ?        S    17:30   0:00 /usr/sbin/zabbix_server: poller #1 [got 0 values in 0.000009 sec, idle 5 sec]
zabbix    11557  0.0  0.2 365328  5192 ?        S    17:30   0:00 /usr/sbin/zabbix_server: poller #2 [got 0 values in 0.000007 sec, idle 5 sec]
zabbix    11558  0.0  0.2 365328  5192 ?        S    17:30   0:00 /usr/sbin/zabbix_server: poller #3 [got 0 values in 0.000014 sec, idle 5 sec]
zabbix    11559  0.0  0.2 365328  5192 ?        S    17:30   0:00 /usr/sbin/zabbix_server: poller #4 [got 0 values in 0.000007 sec, idle 5 sec]
zabbix    11560  0.0  0.2 365328  5192 ?        S    17:30   0:00 /usr/sbin/zabbix_server: poller #5 [got 0 values in 0.000010 sec, idle 5 sec]
zabbix    11561  0.0  0.2 365328  5192 ?        S    17:30   0:00 /usr/sbin/zabbix_server: unreachable poller #1 [got 0 values in 0.000013 sec, idle 5 sec]
zabbix    11562  0.0  0.1 258396  3596 ?        S    17:30   0:00 /usr/sbin/zabbix_server: trapper #1 [processed data in 0.000000 sec, waiting for connection]
zabbix    11563  0.0  0.1 258396  3596 ?        S    17:30   0:00 /usr/sbin/zabbix_server: trapper #2 [processed data in 0.000000 sec, waiting for connection]

我们会看到有很多的zabbix子进程。

监听的端口为:10051

3.5 安装配置zabbix web界面

在浏览器输入
http://192.168.72.130/zabbix/

第二页在 Check of pre-requisites如果发现错误就必须设置一下,提示php的timezone没有设置。

vim /etc/php.ini    //搜索timezone配置即可

date.timezone = Asia/Shanghai

重启一下,让配置生效:

systemctl restart httpd

3.6 第一次登入界面,初始用户名Admin 密码zabbix

修改原始密码

退出后,重新登入

四、zabbix客户端安装配置

4.1 下载安装

下载指定版本:

wget http://repo.zabbix.com/zabbix/3.2/rhel/7/x86_64/zabbix-release-3.2-1.el7.noarch.rpm

安装zabbix的yum扩展源:

rpm -ivh http://repo.zabbix.com/zabbix/3.2/rhel/7/x86_64/zabbix-release-3.2-1.el7.noarch.rpm

client端仅仅只需要安装服务:

yum install -y zabbix-agent

4.2 配置zabbix

[root@xavi-002 ~]# vim /etc/zabbix/zabbix_agentd.conf 
//增加如下配置:

Server=127.0.0.1 修改为 Server=192.168.72.130 //定义监控服务端的ip(被动模式)

ServerActive=127.0.0.1 修改为 ServerActive=192.168.72.130 //定义监控服务端的ip(主动模式:客户端主动上报自己的状态给server端)

Hostname=Zabbix server修改为Hostname=xavi-002 //这是自定义的主机名,一个是让自己容易分别监控的是哪台主机,第二个是服务器可以识别

4.3 启动服务并查看zabbix进程以及端口

[root@xavi-002 ~]# vim /etc/zabbix/zabbix_agentd.conf 
[root@xavi-002 ~]# systemctl start zabbix-agent
[root@xavi-002 ~]# ps aux |grep zabbix
zabbix     8617  0.0  0.1  82732  1304 ?        S    19:51   0:00 /usr/sbin/zabbix_agentd -c /etc/zabbix/zabbix_agentd.conf
zabbix     8618  0.0  0.1  82732  1320 ?        S    19:51   0:00 /usr/sbin/zabbix_agentd: collector [idle 1 sec]
zabbix     8619  0.0  0.1  82732  1860 ?        S    19:51   0:00 /usr/sbin/zabbix_agentd: listener #1 [waiting for connection]
zabbix     8620  0.0  0.1  82732  1860 ?        S    19:51   0:00 /usr/sbin/zabbix_agentd: listener #2 [waiting for connection]
zabbix     8621  0.0  0.1  82732  1860 ?        S    19:51   0:00 /usr/sbin/zabbix_agentd: listener #3 [waiting for connection]
zabbix     8622  0.0  0.2  82864  2240 ?        S    19:51   0:00 /usr/sbin/zabbix_agentd: active checks #1 [idle 1 sec]
root       8625  0.0  0.0 112664   972 pts/0    R+   19:51   0:00 grep --color=auto zabbix

[root@xavi-002 ~]# netstat -lntp
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address           Foreign Address         State       PID/Program name    
tcp        0      0 0.0.0.0:111             0.0.0.0:*               LISTEN      1/systemd           
tcp        0      0 192.168.122.1:53        0.0.0.0:*               LISTEN      1416/dnsmasq        
tcp        0      0 0.0.0.0:22              0.0.0.0:*               LISTEN      948/sshd            
tcp        0      0 127.0.0.1:631           0.0.0.0:*               LISTEN      941/cupsd           
tcp        0      0 127.0.0.1:25            0.0.0.0:*               LISTEN      1415/master         
tcp        0      0 0.0.0.0:10050           0.0.0.0:*               LISTEN      8617/zabbix_agentd  
tcp6       0      0 :::111                  :::*                    LISTEN      1/systemd           
tcp6       0      0 :::22                   :::*                    LISTEN      948/sshd            
tcp6       0      0 ::1:631                 :::*                    LISTEN      941/cupsd           
tcp6       0      0 ::1:25                  :::*                    LISTEN      1415/master         
tcp6       0      0 :::10050                :::*                    LISTEN      8617/zabbix_agentd  

五、Zabbix忘记Admin密码如何做

  • 这样就可以登入新密码了