笔记zabbix

常用系统监控命令
一般企业做监控的目的:实时报告系统状态,提前发现系统的问题。
监控的资源可以分为:共有数据(HTTP、FTP等)和私有数据(CPU、内存、 进程数等)。
监控软件可以使用:系统自带的命令、Cacti监控系统、Nagios监控系统、 Zabbix监控系统。
查看内存信息
]# free // 查看内存信息
]# free | awk '/Mem/{print $4}' // 查看剩余内存容量
查看交换分区信息
]# swapon -s // 查看交换分区信息
查看磁盘信息
]# df // 查看所有磁盘的使用率
]# df | awk '/\/$/{print $5}' // 查看根分区的利用率
查看CPU平均负载
]# uptime // 查看CPU负载(1,5,15分钟)
]# uptime |awk '{print $NF}' // 仅查看CPU的15分钟平均负载
查看网卡信息
]# ifconfig eth0
]# ifconfig eth0 |awk '/inet /{print $2}' // 查看IP地址信息
]# ifconfig eth0 |awk '/RX p/{print $5}' // 网卡接受数据包流量
]# ifconfig eth0 |awk '/TX p/{print $5}' // 网卡发送数据包流量
查看端口信息
]# ss -ntulp // 查看本机监听的所有端口
//-n以数字显示端口号
//-t显示tcp连接
//-u显示udp连接
//-p显示监听端口对应的程序名称
查看网络连接信息
]# ss -antup // 查看所有的网络连接信息
//-a查看所有连接状态信息
部署Zabbix监控平台
拓扑规划
Zabbixsever eth1:192.168.2.5
Zabbixclient_web1 eth1:192.168.2.100
Zabbixclient_web2 eth1:192.168.2.200
部署监控服务器
安装LNMP环境
// Zabbix监控管理控制台需要通过Web页面展示出来,并且还需要使用 MySQL来存储数据,因此需要先为Zabbix准备基础LNMP环境。

]# yum -y install gcc pcre-devel openssl-devel
]# tar -xf nginx-1.12.2.tar.gz
]# cd nginx-1.12.2
nginx-1.12.2]# ./configure --with-http_ssl_module
nginx-1.12.2]# make && make install
]# yum -y install php php-mysql mariadb mariadb-devel mariadb-server
]# yum -y install php-fpm-5.4.16-42.el7.x86_64.rpm
//注意,php-fpm这个软件包在lnmp_soft/目录下
修改Nginx配置文件
// 配置Nginx支持PHP动态网站,因为有大量PHP脚本需要执行,因此 还需要开启Nginx的各种fastcgi缓存,加速PHP脚本的执行速度。

]# vim /usr/local/nginx/conf/nginx.conf
… …
http{
… …
fastcgi_buffers 8 16k; // 缓存php生成的页面内容,8个16k
fastcgi_buffer_size 32k; // 缓存php生产的头部信息
fastcgi_connect_timeout 300; // 连接PHP的超时时间
fastcgi_send_timeout 300; // 发送请求的超时时间
fastcgi_read_timeout 300; //读取请求的超时时间
location ~ .php$ {
root html;
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
include fastcgi.conf;
} // 实现动静分离,动态网站
启动服务
// 启动Nginx、PHP-FPM、MariaDB服务,关闭SELinux与防火墙。

]# systemctl start mariadb
]# systemctl start php-fpm
]# ln -s /usr/local/nginx/sbin/nginx /sbin/nginx
]# nginx

]# firewall-cmd --set-default-zone=trusted
]# setenforce 0
客户端测试LNMP环境
// 服务器创建PHP测试页面,浏览器访问页面测试网页连通性。

]# vim /usr/local/nginx/html/test.php
<?php
$i=33;
echo $i;
?>
]# curl http://192.168.2.5/test.php

部署监控服务器Zabbix Server
源码安装Zabbix Server
// 多数源码包都是需要依赖包的,zabbix也一样,源码编译前需要先安装 相关依赖包。

先安装3个依赖包

]# yum -y install net-snmp-devel //监控交换机、路由器这种网络设备
]# yum -y install curl-devel //监控公共设备(http、ftp等)
lnmp_soft]# yum -y install

libevent-devel-2.0.21-4.el7.x86_64.rpm // 驱动
//注意libevent-devel这个软件包在lnmp_soft目录下有提供

再安装源码包

lnmp_soft]# tar -xf zabbix-3.4.4.tar.gz
lnmp_soft]# cd zabbix-3.4.4/
zabbix-3.4.4]# ./configure --enable-server \

--enable-proxy --enable-agent --with-mysql=/usr/bin/mysql_config \
--with-net-snmp --with-libcurl

// --enable-server安装部署zabbix服务器端软件
// --enable-agent安装部署zabbix被监控端软件
// --enable-proxy安装部署zabbix代理相关软件
// --with-mysql配置mysql_config路径
// --with-net-snmp允许zabbix通过snmp协议监控其他设备
// --with-libcurl安装相关curl库文件,这样zabbix就可以通过curl连接 http等服务,测试被监控主机服务的状态
zabbix-3.4.4]# make && make install

初始化Zabbix
// 创建数据库,上线Zabbix的Web页面

]# mysql
mysql> create database zabbix character set utf8;
// 创建数据库,支持中文字符集
mysql> grant all on zabbix.* to zabbix@'localhost' identified by 'zabbix';
// 创建可以访问数据库的账户与密码
]# cd lnmp_soft/zabbix-3.4.4/database/mysql/
mysql]# mysql -uzabbix -pzabbix zabbix < schema.sql
mysql]# mysql -uzabbix -pzabbix zabbix < images.sql
mysql]# mysql -uzabbix -pzabbix zabbix < data.sql
// 刚刚创建是空数据库,zabbix源码包目录下,有提前准备好的数据
// 使用mysql导入这些数据即可(注意导入顺序)

修改Zabbix_server配置文件,设置数据库相关参数,启动Zabbix_server服务
]# vim /usr/local/etc/zabbix_server.conf
DBHost=localhost
// 数据库主机,默认该行被注释
DBName=zabbix
// 设置数据库名称

DBPassword=zabbix
// 设置数据库密码,默认该行被注释
LogFile=/tmp/zabbix_server.log
// 设置日志,仅查看以下即可

]# useradd -s /sbin/nologin zabbix // 不创建用户无法启动服务

zabbix_server // 启动服务

]# ss -ntulp |grep zabbix_server // 确认连接状态,端口10051

提示:如果是因为配置文件不对,导致服务无法启动时,不要重复执行zabbix_agentd,一定要先使用killall zabbix_agentd关闭服务后,再重新启动一次。

浏览器访问Zabbix_server服务器的Web页面
]# firefox http://192.168.2.5/index.php
// 第一次访问,初始化PHP页面会检查计算机环境是否满足要求,如 果不满足会给出修改建议。
// 默认会提示PHP的配置不满足环境要求,需要修改PHP配置文件。
修改PHP配置文件,根据错误提示,满足Zabbix_server的Web环境要求
// php-bcmath和php-mbstring都在lnmp_soft目录下有提供软件包。

]# yum -y install php-gd php-xml
]# yum install php-bcmath-5.4.16-42.el7.x86_64.rpm
]# yum install php-mbstring-5.4.16-42.el7.x86_64.rpm
]# vim /etc/php.ini
date.timezone = Asia/Shanghai // 设置时区
max_execution_time = 300 // 最大执行时间,秒
post_max_size = 32M // POST数据最大容量
max_input_time = 300 // 服务器接收数据的时间限制
memory_limit = 128M // 内存容量限制
]# systemctl restart php-fpm

修改完PHP配置文件后,再次使用浏览器访问服务器,则会有提示信息。
// 都显示ok,这里有一个PHP LDAP是warning状态是没有问题的!

在初始化数据库页面,填写数据库相关参数
笔记zabbix

// 密码也是zabbix
笔记zabbix
在登陆页面,使用用户(admin)和密码(zabbix)登陆

// 登陆后设置语言环境为中文

部署被监控主机Zabbix Agent
源码安装Zabbix agent软件
// 在2.100和2.200做相同操作(以zabbixclient_web1为例)。
[root@zabbixclient_web1 ~]# useradd -s /sbin/nologin zabbix
]# yum -y install gcc pcre-devel
]# tar -xf zabbix-3.4.4.tar.gz
]# cd zabbix-3.4.4/
zabbix-3.4.4]# ./configure --enable-agent
zabbix-3.4.4]# make && make install
修改agent配置文件,启动Agent
]# vim /usr/local/etc/zabbix_agentd.conf
Server=127.0.0.1,192.168.2.5
// 谁可以监控本机(被动监控模式)

ServerActive=127.0.0.1,192.168.2.5
// 谁可以监控本机(主动监控模式)
Hostname=zabbix_client_zabbixclient_web1 // 被监控端自己的主机名
EnableRemoteCommands=1
//监控异常后,是否允许服务器远程过来执行命令,如重启某个服务
UnsafeUserParameters=1 // 是否允许自定义key监控

拷贝启动脚本(非必须操作,可选做),有启动脚本可以方便管理服务,启动与关闭服务。启动脚本位于zabbix源码目录下。
zabbix-3.4.4]# cd misc/init.d/fedora/core
zabbix-3.4.4]# cp zabbix_agentd /etc/init.d/
zabbix-3.4.4]# /etc/init.d/zabbix_agentd start|stop|status|restart

配置及使用Zabbix监控系统
// 通过Zabbix监控平台,添加被监控zabbixclient_web1主机 (192.168.2.100)并链接监控模板即可,Zabbix默认模板就可以监控 CPU、内存、进程、网络、磁盘等项目。

添加监控主机
// 主机是Zabbix监控的基础,Zabbix所有监控都是基于Host主机。

添加被监控Linux主机
使用火狐浏览器登录http://192.168.2.5,通过Configuration(配置)-->Hosts(主机)-->Create Host(创建主机)添加被监控Linux主机。
添加被监控主机时,需要根据提示输入被监控Linux主机的主机名称(最好与电脑的主机名一致,但也允许不一致)、主机组、IP地址等参数。
笔记zabbix

为被监控主机添加监控模板
Zabbix通过监控模板来对监控对象实施具体的监控功能,根据模板来定义需要监控哪些数据,对于Linux服务器的监控,Zabbix已经内置了相关的模板(Template OS Linux),选择模板并链接到主机即可。
笔记zabbix

查看监控数据
查看监控数据
登录Zabbix Web控制台,点击Monitoring(监控中)—> Latest data(最新数据),正过滤器中填写过滤条件,根据监控组和监控主机选择需要查看哪些监控数据。
笔记zabbix

查看监控图形
// 找到需要监控的数据后,可以点击后面的Graph查看监控图形

自定义Zabbix监控项目
被监控主机创建自定义key(在192.168.2.100操作)
创建自定义key
// 自定义的key文件一般存储在/usr/local/etc/zabbix_agentd.conf.d/目录,这里还需要修改zabbix_agentd.conf文件,允许自定义监控key,来读取该目录下的所有文件 。

]# vim /usr/local/etc/zabbix_agentd.conf
Include=/usr/local/etc/zabbix_agentd.conf.d/ // 加载配置文件目录
]# cd /usr/local/etc/zabbix_agentd.conf.d/
zabbix_agentd.conf.d]# vim count.line.passwd
UserParameter=count.line.passwd,wc -l /etc/passwd | awk '{print $1} '
// 自定义key语法格式为:UserParameter=自定义key名称,命令。

测试自定义key是否正常工作
]# killall zabbix_agentd
]# zabbix_agentd //重启agent服务
]# zabbix_get -s 127.0.0.1 -k count.line.passwd
注意:如zabbix_get命令执行错误,提示Check access restrictions in Zabbix agent configuration,则需要检查agent配置文件是否正确:如下
]# vim /usr/local/etc/zabbix_agentd.conf
Server=127.0.0.1,192.168.2.5
ServerActive=127.0.0.1,192.168.2.5

创建监控模板
添加监控模板
登录Zabbix Web监控控制台,通过Configuration(配置)-->Template(模板)-->Create template(创建模板),填写模板名称,新建模板群组。

创建模板后,默认模板中没有任何应用、项目、触发器、图形等。

创建应用
创建完成模板后,默认模板中没有任何应用、项目、触发器、图形等资源。这里需要点击模板后面的Application(应用集)链接打开创建应用的页面。

点击Application(应用集)后,会刷新出图-16所示页面,在该页面中点击Create application(创建应用集)按钮。

设置应用名称

创建监控项目item(监控项)
与创建应用一样,在模板中还需要创建监控项目,如图-18所示,并在刷新出的新页面中选择Create items(创建监控项)创建项目

接下来,还需要给项目设置名称及对应的自定义key

创建图形
为了后期可以通过图形的方式展示监控数据,还需要在模板中创建图形,设置方法与前面的步骤一致,在监控模板后面点击Graph(图形)即可创建图形,设置监控图形基于什么监控数据

将模板链接到被监控主机
将完整的监控模板制作完成后,就可以将模板链接到主机实现监控功能了。首先找到被监控主机Configuration(配置)-->Hosts(主机)

点击需要的被监控主机链接,打开监控主机设置页面,在Template(模板)页面中选择需要链接到该主机的模板,在此选择刚刚创建的模板count_line.passwd添加即可

查看监控数据图形
点击Monitoring(监控中)-->Craphs(图形),根据需要选择条件,查看监控图形

面试题
从哪些方面优化nginx,怎么样提高nginx性能
优化并发量connection
优化页面压缩gzip
优化头部信息缓存大小
优化数据缓存大小
优化连接时的超时时间
优化发送请求时的超时时间

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章