目录一、Zabbix 简介1.监控功能2.Zabbix 工作原理3.Zabbix 组件4.Zabbix 进程二、使用 Zabbix 配置自定义监控项1.安装 Zabbix2.开启自定
Zabbix 可以用来监控各种网络参数,来保证服务器和系统的安全运行。并且 Zabbix 还提供了灵活的通知机制,以此来让系统管理员快速定位/解决存在的各种问题。是一个基于 Web 界面提供的分布式系统监控以及网络监控功能的企业级开源解决方案。
1)监控对象
2)主机性能指标监控
首先,我们需要在被监控的主机上安装 Agent 软件,用来收集当前服务器的各项数据信息,并发送给监控端,当监控端接收到 Agent 发送过来的信息后,会将数据存储到数据库中,接着通过 WEB 界面来将数据在前端页面上进行展示和绘图。
这里 Agent 收集数据分为 主动和被动 两种模式:
Zabbix 默认使用的模式为被动模式,也就是说当我们需要监控的主机数量较多时,可能会影响到监控端的性能。因为监控端会定时的通过连接客户端的端口进行数据收集,所以我们可以 选择性的配置部分主机为主动模式,来减少监控端的性能压力。
组件 | 作用 |
---|---|
Zabbix Server | 用于接收 Agent 发送过来的信息,所有的配置、数据统计、数据操作都是由它组织进行 |
Database Storage | 用于存储所有的配置信息以及收集的数据信息 |
Web Interface | Zabbix 的 GUI 接口,可以用于界面展示(一般和 Server 运行在用一台主机上) |
Agent | 用于采集本地的数据信息,也就是所谓的被监控端 |
Proxy | 可选组件,通常用于分布式监控架构;相当于是一个代理的 Server,用来收集 Agent 部分数据,并转发给监控端 |
因为 Zabbix 并不能直接监控Java 应用,所以在 Zabbix 2.0 后推出 Java_Gateway
代理进程,使我们可以监控 Java 应用。
Docker-compose
方式安装,物理安装可以看我前面写的这篇文章:传送门1)安装 Docker
[root@Zabbix ~]# wget -O /etc/yum.repos.d/Centos-Base.repo Http://mirrors.aliyun.com/repo/Centos-7.repo
[root@Zabbix ~]# yum -y install epel-release
[root@Zabbix ~]# yum -y install yum-utils device-mapper-persistent-data lvm2
[root@Zabbix ~]# yum-config-manager \
--add-repo \
https://download.docker.com/linux/centos/docker-ce.repo
[root@Zabbix ~]# yum -y install docker-ce-19.03.12 docker-ce-cli-19.03.12
[root@Zabbix ~]# systemctl enable docker --now
2)安装 Docker-Compose
[root@Zabbix ~]# wget "https://GitHub.com/docker/compose/releases/download/v2.3.2/docker-compose-$(uname -s)-$(uname -m)" -O /usr/local/bin/docker-compose
[root@Zabbix ~]# chmod +x /usr/local/bin/docker-compose
[root@Zabbix ~]# docker-compose --version
3)安装 Agent
[root@Zabbix ~]# rpm -ivh http://repo.zabbix.com/zabbix/5.4/rhel/7/x86_64/zabbix-agent-5.4.8-1.el7.x86_64.rpm
[root@Zabbix ~]# egrep -v '^$|#' zabbix_agentd.conf
PidFile=/var/run/zabbix/zabbix_agentd.pid
LogFile=/var/log/zabbix/zabbix_agentd.log
LogFileSize=0
Server=127.0.0.1
ServerActive=127.0.0.1
Hostname=Zabbix server
Include=/etc/zabbix/zabbix_agentd.d/*.conf
[root@Zabbix ~]# systemctl enable zabbix-agent --now
4)安装 Zabbix
[root@Zabbix ~]# mkdir -p /app/zabbix
[root@Zabbix ~]# cd /app/zabbix/
[root@Zabbix zabbix]# cat <<END > docker-compose.yml
version: "3"
services:
Mysql-server:
image: mysql:5.7
ports:
- "3306:3306"
volumes:
- "/app/mysql:/var/lib/mysql" # 配置数据卷 (防止监控数据丢失)
environment:
MYSQL_ROOT_PASSWord: 123123
TZ: Asia/Shanghai
command: --character-set-server=utf8 --collation-server=utf8_bin
restart: always
zabbix-server:
image: zabbix/zabbix-server-mysql:5.4.8-centos
environment:
DB_SERVER_HOST: 127.0.0.1
DB_SERVER_PORT: 3306
MYSQL_DATABASE: zabbix
MYSQL_USER: root
MYSQL_PASSWORD: 123123
TZ: Asia/Shanghai
depends_on:
- mysql-server
restart: always
network_mode: "host" # 使用主机网络
zabbix-web:
image: zabbix/zabbix-web-nginx-mysql:5.4.8-centos
ports:
- "8000:8080" # Zabbix WebUI 映射端口
volumes: # 当在 Web 界面配置成中文后,监控界面会出现乱码
- "./simkai.ttf:/usr/share/zabbix/assets/fonts/DejaVuSans.ttf"
environment:
DB_SERVER_HOST: mysql-server
DB_SERVER_PORT: 3306
MYSQL_DATABASE: zabbix
MYSQL_USER: root
MYSQL_PASSWORD: 123123
TZ: Asia/Shanghai
ZBX_SERVER_HOST: 192.168.1.1
depends_on:
- mysql-server
- zabbix-server
restart: always
END
[root@Zabbix zabbix]# docker-compose up -d
[root@Zabbix zabbix]# docker-compose ps
simkai.ttf
字体,你们可以在自己电脑上的这个 C:\Windows\Fonts
路径找到。5)验证:http://192.168.1.1:8000
(账号:Admin/zabbix
)
zabbix server is not running: the infORMation displayed may not be current
报错;docker-compose
文件中的 ZBX_SERVER_HOST
变量配置的值不是 Zabbix Server 的 IP 地址导致的。我上面报错是为了让你们看下效果,如果你们出现如上配置,按照我的配置修改即可。
配置中文
[root@Zabbix ~]# echo "UnsafeUserParameters=1" >> /etc/zabbix/zabbix_agentd.conf
[root@Zabbix ~]# yum -y install nginx
[root@Zabbix ~]# cat <<END > /etc/nginx/conf.d/status.conf
server {
listen 80;
server_name 127.0.0.1;
location /status {
stub_status on;
allow 127.0.0.1;
allow 192.168.1.0/24;
deny all;
}
}
END
1)编写自定义监控脚本
[root@Zabbix ~]# mkdir /etc/zabbix/scripts
[root@Zabbix ~]# vim /etc/zabbix/scripts/nginx_status.sh
#!/bin/bash
HOST="127.0.0.1"
PORT="80"
# 监控 Nginx 进程是否存在
function Ping {
/sbin/pidof nginx | wc -l
}
# 监控 Nginx 状态信息
function Active {
/usr/bin/curl "http://$HOST:$PORT/status" 2> /dev/null | grep "Active" | awk '{print $NF}'
}
function Reading {
/usr/bin/curl "http://$HOST:$PORT/status" 2> /dev/null | grep "Reading" | awk '{print $2}'
}
function Writing {
/usr/bin/curl "http://$HOST:$PORT/status" 2> /dev/null | grep "Writing" | awk '{print $4}'
}
function Waiting {
/usr/bin/curl "http://$HOST:$PORT/status" 2> /dev/null | grep "Waiting" | awk '{print $6}'
}
function Server {
/usr/bin/curl "http://$HOST:$PORT/status" 2> /dev/null | awk NR==3 | awk '{print $1}'
}
function Accepts {
/usr/bin/curl "http://$HOST:$PORT/status" 2> /dev/null | awk NR==3 | awk '{print $2}'
}
function Requests {
/usr/bin/curl "http://$HOST:$PORT/status" 2> /dev/null | awk NR==3 | awk '{print $3}'
}
# 执行 function
$1
[root@Zabbix ~]# chmod +x /etc/zabbix/scripts/nginx_status.sh
2)定义监控脚本
[root@Zabbix ~]# cat <<"END" > /etc/zabbix/zabbix_agentd.d/nginx_status.conf
UserParameter=nginx.status[*],/etc/zabbix/scripts/nginx_status.sh $1
END
[root@Zabbix ~]# systemctl restart zabbix-agent
3)验证
[root@Zabbix ~]# docker exec -it zabbix-zabbix-server-1 /bin/bash
创建模板
创建应用集
创建监控项
因为在我们的监控脚本中,一共定义了 8 个监控项,所以我们上面也要创建 8 个监控项,重复上面操作,创建出对应的即可。
给我们的监控项创建图形
将 Nginx 模板加入到主机中
查看监控图
其实 Zabbix 的自定义监控项就是由 key/value
的形式组成。即,我们只需要把要监控的数据定义成一个 value
,key
里面的值就是我们想要监控的数据,那么也就是说,当我们定时的查找这个 key
对应的值,便可以得到监控数据。
到此这篇关于使用 Docker 安装 Zabbix,并配置自定义监控项的文章就介绍到这了,更多相关Docker 安装 Zabbix配置自定义监控项内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
--结束END--
本文标题: 使用 Docker安装 Zabbix并配置自定义监控项的过程详解
本文链接: https://lsjlt.com/news/145620.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0