实战网络监控Zabbix(1)—— 远程监控主机服务

1. Zabbix 简介
php

        Zabbix 是一个高度集成的网络监控解决方案,能够提供企业级的开源分布式监控解决方案,由一个国外的团队持续维护更新,软件能够自由下载使用,运做团队靠提供收费的技术支持赢利。前端

        官方网站:http://www.zabbix.commysql

   1.1 zabbix模式linux

       Zabbix 经过 C/S 模式采集数据,经过 B/S 模式在 web 端展现和配置。web

      被监控端:主机经过安装 agent 方式采集数据,网络设备经过 SNMP 方式采集数据sql

      Server 端:经过收集 SNMP 和 agent 发送的数据,写入数据库(MySQL,ORACLE 等),再经过 php+apache 在 web 前端展现。数据库

   1.2 Zabbix 运行条件:apache

      Server:Zabbix Server 需运 行在 LAMP( Linux+Apache+Mysql+PHP)环 境下( 或者LNMP),对硬件要求低vim

     Agent:目前已有的 agent 基本支持市面常见的 OS,包含 Linux、HPUX、Solaris、Sun、windowswindows

     SNMP:支持各种常见的网络设备

wKioL1gTG4bQDEfoAAOSyU71uvg759.png

2.优劣势

    优势:

        开源,无软件成本投入

        Server 对设备性能要求低

        支持设备多,自带多种监控模板

        支持分布式集中管理,有自动发现功能,能够实现自动化监控

        开放式接口,扩展性强,插件编写容易

        当监控的 item 比较多服务器队列比较大时能够采用被动状态,被监控客户端主动从server 端去下载须要监控的 item 而后取数据上传到 server 端。这种方式对服务器的负载比较小。

        Api 的支持,方便与其余系统结合

    缺点:

        需在被监控主机上安装 agent,全部数据都存在数据库里,产生的数据据很大,瓶颈主要在数据库。


实验环境:

    物理主机    redhat7.0 内核版本 3.10.0-123.el7.x86_64

    虚拟机    redhat6.5 内核版本 2.6.32-431.el6.x86_64

        服务器端: server1.example.com    172.25.254.1

        客户端:    server2.example.com    172.25.254.2

    所需软件包:

zabbix-2.4.5-1.el6.x86_64.rpm

zabbix-server-2.4.5-1.el6.x86_64.rpm

zabbix-server-mysql-2.4.5-1.el6.x86_64.rpm

zabbix-web-2.4.5-1.el6.noarch.rpm

zabbix-web-mysql-2.4.5-1.el6.noarch.rpm

zabbix-agent-2.4.5-1.el6.x86_64.rpm

fping-2.4b2-16.el6.x86_64.rpm

iksemel-1.4-2.el6.x86_64.rpm

iksemel-utils-1.4-2.el6.x86_64.rpm

php-mbstring-5.3.3-26.el6.x86_64.rpm

php-bcmath-5.3.3-26.el6.x86_64.rpm



一.服务器端配置

Zabbix 须要 lamp 环境:

wKioL1gTHfCB0mEdAAAMgsf_bZc038.png

1. 安装 zabbix 所需软件包

zabbix-2.4.5-1.el6.x86_64.rpm

zabbix-server-2.4.5-1.el6.x86_64.rpm

zabbix-server-mysql-2.4.5-1.el6.x86_64.rpm

zabbix-web-2.4.5-1.el6.noarch.rpm

zabbix-web-mysql-2.4.5-1.el6.noarch.rpm

zabbix-agent-2.4.5-1.el6.x86_64.rpm

fping-2.4b2-16.el6.x86_64.rpm

iksemel-1.4-2.el6.x86_64.rpm

iksemel-utils-1.4-2.el6.x86_64.rpm

php-mbstring-5.3.3-26.el6.x86_64.rpm

php-bcmath-5.3.3-26.el6.x86_64.rpm

wKioL1gTHpqyQJFjAABTANt5w6w562.png

2. 配置 mysql 数据库

# service mysqld start

# mysql

mysql> create database zabbix character set utf8 collate utf8_bin;

mysql> grant all privileges on zabbix.* to zabbix@localhost identified by 'willis';

mysql> quit;

# cd /usr/share/doc/zabbix-server-mysql-2.4.5/create

# mysql -uzabbix -pwestos zabbix < schema.sql

## stop here if you are creating database for Zabbix proxy ##

# mysql -uzabbix -pwestos zabbix < p_w_picpaths.sql

# mysql -uzabbix -pwestos zabbix < data.sql

wKiom1gTH8jR4OgOAAA4rXTM07M272.png

wKiom1gTH8eRf28wAAA4GT0vGlg457.png

wKiom1gTIHujuDvAAAA2dJuU2cg592.png

3. 配置 zabbix server

[root@server1 create]# vim /etc/zabbix/zabbix_server.conf 

72    DBHost=localhost

82    DBName=zabbix

106  DBPassword=willis

163  StartTrappers=10

wKioL1gVfhyjNme1AAANlxvDH00810.png

wKiom1gVfhyS1Q9CAAAiIS9xYmI557.png

wKiom1gVkH-R5cv2AAAUGbSX1xE962.png

4. 配置 php

[root@server1 conf.d]# vim /etc/php.ini 

 946 date.timezone = Asia/Shanghai

[root@server1 conf.d]# pwd

/etc/httpd/conf.d

[root@server1 conf.d]# vim zabbix.conf 

 13     php_value max_execution_time 300

 14     php_value memory_limit 128M

 15     php_value post_max_size 16M

 16     php_value upload_max_filesize 2M

 17     php_value max_input_time 300

 18     php_value date.timezone Asia/Shanghai

wKioL1gVfqvx8vZQAAALrogdVP0681.png

wKiom1gVfqvg_7JWAABNRRnBe1E709.png

5. 启动 zabbix server、zabbix agent、httpd

# service httpd start

# service zabbix-server start

# service zabbix-agent start

wKioL1gTIxOjmU4MAAA28wos-7k396.png6. 登录 zabbix web

http://172.25.254.1/zabbix 按照提示完成安装并登录:

wKiom1gTI2bzD_w4AAHwmg1y7xw801.png


wKioL1gTJCPyEXLqAABC4M4Jlr0126.png


wKiom1gTJSGSQqwIAAApxC9T-FI864.png



wKioL1gTJSDAr5RHAABO3qT47YM686.png


wKiom1gTJSCxICwzAAAWQ_maReA597.png


wKioL1gTJZOBY22XAAFWnJfgfMo755.png

Username: Admin

Password: zabbix


wKiom1gVgDnSQ53DAADxZjNFDnw376.png

能够看到 Zabbix server is running 状态值为Yes.服务端部署完成。



二.被监控端配置(server2)

    7. 添加 agent 主机

    7.1在被监控端安装软件包:

zabbix-2.4.5-1.el6.x86_64.rpm

zabbix-agent-2.4.5-1.el6.x86_64.rpm

wKiom1gTJuewdyK7AAAljvh4gTA618.png

    7.2配置 zabbix agent

# vim /etc/zabbix/zabbix_agentd.conf

85      Server=172.25.254.1

126    ServerActive=172.25.254.1

137    Hostname=server2.example.com    #主机名须要有解析

wKioL1gVg9GDMh2iAAAXf4-Lpms932.png

    7.3启动 zabbix agent

[root@server2 zabbix]# /etc/init.d/zabbix-agent restart

wKiom1gVhDeQd0a6AAAhAem0k-c507.png


网页端配置:

 Configuration ->Discovery

wKiom1gVhnqDVQXMAAB5Fvrmyo4593.png

8. 在 zabbix server 上激活 zabbix agent 自动注册功能

点击 Configuration -> Actions ->Auto registration ->Create action 按下图所示设置:

wKiom1gVinyzW3K3AABgHrhmfls898.png


自定义 Action 的名字。

Conditions 选项卡保持默认便可。

Operations 选项卡添加以下:


wKiom1gVinvjJKwkAABkkPWpSw0742.png

Add host:自动注册主机添加到 hosts 列表

Add to host groups:自动注册主机加入 linux servers 组(组名能够自定义)

Link to templates:自动注册主机应用模板 Template OS linux

wKioL1gVi0OweJO3AACbZ-V6j2A697.png


点击 Configuration -> Hosts 能够看到新加的主机:

wKiom1gVjO-BlYF0AABf4zPPusA488.png



三. 添加http服务监控

    Zabbix 的更多功能值得你们一块儿研究和分享。

    来看看 zabbix 是怎样添加服务监控项的,利用 zabbix 自带的监控模版,以 http 服务为例:

wKiom1gVjfOhlCuFAADCGuYNq8M744.png

   点击 Configuration -> Templates 选择须要连接的模版

   也能够在 Configuration -> Hosts -> server2.example.com -> Templates 选择须要的模版

wKiom1gVme7B_sAOAAB1gf6zE7A038.png

这样主机 server2.example.com 的监控项中就出现了 HTTP 服务

wKioL1gVmkrQVIVVAAAhsI7Fz4w026.png


四.监控远程主机Mysql服务

    在/etc/zabbix/zabbix_agentd.d/userparameter_mysql.conf 文件中指定了 zabbix agent 如何获取 mysql服务的各类信息,并在/var/lib/zabbix 目录中新建“.my.cnf”文件,用以指定 zabbix agent 如何登录数据库,默认使用的是 zabbix 用户,能够在 zabbix_server.conf 文件中找到密码。

[root@server2 zabbix]# yum install mysql-server -y

[root@server2 zabbix]# /etc/init.d/mysqld start

[root@server2 zabbix]# mysql_secure_installation   

                                    ###初始化数据库 ,我把数据库密码改为了willis

[root@server2 zabbix]# mkdir /var/lib/zabbix

[root@server2 zabbix]# cp /etc/my.cnf /var/lib/zabbix/.my.cnf

[root@server2 zabbix]# vim /var/lib/zabbix/.my.cnf

wKioL1gVlkaDGREAAAAke3d22S4674.png

[mysql]

host = localhost

user = zabbix

password = willis

socket = /var/lib/mysql/mysql.sock

[mysqladmin]

host = localhost

user = zabbix

password = willis

socket = /var/lib/mysql/mysql.sock

wKiom1gVlpei8A72AAAyodPoteE011.png

监控远程主机的 mysql 服务须要建立 zabbix 用户并受权,本机监控则不须要。

mysql> grant select on *.* to 'zabbix'@'localhost' identified by 'willis';

[root@server2 zabbix]# mysql -uzabbix -pwillis

wKioL1gVmBSg4FrvAAA5zAb1-Wc841.png

[root@server2 zabbix]# /etc/init.d/zabbix-agent restart

Shutting down Zabbix agent:                                [  OK  ]

Starting Zabbix agent:                                     [  OK  ]


连接 mysql 监控模版:


wKiom1gVnEPiiKOzAAB08hH55gg936.png


点击 Configuration -> Hosts -> server2.example.com-> Graphs 能够看到两个新的监控图形

wKioL1gVnJ6hoq5sAAAWiVXwBw4293.png

过一会能够看到监控的图形变化

wKioL1gVnN_weSLmAACaiAaiq4M096.png

相关文章
相关标签/搜索