我是靠谱客的博主 幸福纸鹤,最近开发中收集的这篇文章主要介绍使用 Zabbix + Grafana 搭建服务器监控系统,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

搭建 Linux 服务器监控的目的是防止以下现象:自己有一台阿里云服务器内存是 2g 的 , 多开一些软件就会把内存和 CPU 使用率弄的很高,最终导致服务器卡死。

所以基于这个痛点,想知道当前的 CPU 和内存是多少。阿里云 ECS 控制台中也提供对服务器的监控 , 但是为了学习 Linux 服务器监控系统 , 还是打算自己搭建一套。

当然 Linux 服务器监控也有很多,Zabbix 是一个基于 Web 界面的提供分布式系统监视以及网络监视功能的企业级的开源解决方案。

所以基于 Zabbix+Grafana 打造服务器监控系统。

Zabbix

模块介绍

  • Zabbix Server: 负责接收 agent 发送的报告信息的核心组件,所有配置,统计数据及操作数据均由其组织进行。

  • Zabbix Agent: 部署在被监控主机上,负责收集本地数据发往 Server 端或 Proxy 端。

  • Database Storage:用户存储所有配置信息,以及存储由 Zabbix Server 收集到的数据。

  • Web Interface:Zabbix 的 GUI 接口,通常与 Server 运行在同一台主机上。

  • Zabbix Proxy:常用于分布监控环境中,代理 Server 收集部分被监控的监控数据并统一发往 Server 端。

原理介绍

Agent 安装在被监控的主机上,Agent 负责定期收集客户端本地各项数据,并发送至 Zabbix Server 端,Zabbix Server 收到数据,将数据存储到数据库中,用户基于 Zabbix WEB 可以看到数据在前端展现图像。

当 Zabbix 监控某个具体的项目,改项目会设置一个触发器阈值,当被监控的指标超过该触发器设定的阈值,会进行一些必要的动作,动作包括:发送信息(邮件、微信、短信)、发送命令(SHELL 命令、Reboot、Restart、Install 等)。

环境安装

Zabbix 需要 zabbix-server、zabbix-agent、mysql。其中 mysql 已经在本机安装了,在 dockercompose 文件中
写上对应的 host、user、pwd 即可。

在 MySQL 中创建 Zabbix 数据库 , 为了后期储存数据使用。

使用 Docker 安装 zabbix,dockercompose 文件如下:

version: '2'
services:
zabbix-server-service:
image: monitoringartist/zabbix-xxl:3.2.6
container_name: zabbix-server-service
restart: always
ports:
- "8081:80"
environment:
- ZS_DBHost=192.168.1.103
- ZS_DBUser=root
- ZS_DBPassword=123321
zabbix-agent-a:
image: zabbix/zabbix-agent:ubuntu-3.2.6
links:
- zabbix-server-service:zabbixserverhost
container_name: zabbix-agent-a
restart: always
depends_on:
- zabbix-server-service
environment:
- ZBX_HOSTNAME=zabbix-agent-service-a
- ZBX_SERVER_HOST=zabbixserverhost
zabbix-agent-b:
image: zabbix/zabbix-agent:ubuntu-3.2.6
links:
- zabbix-server-service:zabbixserverhost
container_name: zabbix-agent-b
restart: always
depends_on:
- zabbix-server-service
environment:
- ZBX_HOSTNAME=zabbix-agent-service-b
- ZBX_SERVER_HOST=zabbixserverhost

启动命令:

docker-compose up -d

查看日志命令:

docker logs -f zabbix-server-service

大概启动后 1 到 2 分钟登录 zabbix web 地址 http://127.0.0.1:80801, 出现如下页面说明安装成功。

在这里插入图片描述

默认账号:Admin,密码:zabbix,登录后出现如下页面。

在这里插入图片描述

配置

修改语言

默认的语言是英文的 , 点击头像后展示修改语言选项 , 选择中文并且更新即可。

在这里插入图片描述

zabbix-agent 配置

之前配置两个 zabbix-agent-a 和 zabbix-agent-b,所以要添加两个 zabbix-agent 来采集数据并发送给 zabbix-server。

在配置,选择主机,创建主机。

在这里插入图片描述

配置 zabbix-agent 需要其容器内的 ip 地址 , 可以通过
docker exec -it zabbix-agent-b ip addr 命令查看。

在这里插入图片描述

在创建页面填写其 ip 和选择群组 , 点击保存即可。

在这里插入图片描述

此时添加了两台 zabbix-agent。

在这里插入图片描述

另外还需要给 zabbix-agent 配置监控模版 , 在模版中选择 Template OS Linux 并且添加即可。

在这里插入图片描述

配置模版完成后 , 在主机列表中 ZBX 显示绿色说明添加完成。

在这里插入图片描述

添加监控数据

在首页仪表盘上 , 选择常用的图形。

在这里插入图片描述

在创建页面选择 zabbix-agent-server-b 主机和 cpu jumps 监控项。

在这里插入图片描述

监控数据可以控制缩放比例和时间段。

在这里插入图片描述

Grafana

简介

grafana 是一个跨平台的开源的度量分析和可视化工具 , 可以通过将采集的数据查询然后可视化的展示。

配置

安装 grafana

可以使用 grafana 展示 zabbix 的数据 , 制作图表展示。

使用 docker 启动 grafana。

1、docker run -d --name=grafana2 -p 7777:3000 -v /var/lib/grafana:/var/lib/grafana grafana/grafana:3.0.4

启动镜像完成后 , 等大概 1 到 2 分钟 , 在浏览器访问:http://127.0.0.1:7777。 默认账号和密码都是 admin。

在这里插入图片描述

安装 zabbix 插件

安装 zabbix 插件 , 进入 grafana 容器执行如下命令

docker exec -it grafana /bin/bash 进入容器
grafana-cli plugins install alexanderzobnin-zabbix-app
docker restart grafana 重启容器

在插件中的 app 中 , 出现 zabbix 说明 zabbix 插件安装成功。

在这里插入图片描述

在这里插入图片描述

zabbix 数据源

在 Data Sources 中新增一个数据源。

在这里插入图片描述

数据源配置:type=Zabbix、url、Zabbix 的账号、Zabbix 的密码。

url 格式为:http://ip:8081/api_jsonrpc.php

在这里插入图片描述

grafana 面板

在 Dashboards 中新建一个面板。

在这里插入图片描述

把 Panel data source 数据源改成 zabbix 数据源。

可用内存设置面板中参数如下:

Group=Linux servers (这个参数在 zabbix 设置过)

Host=zabbix-agent-service-a

Application=Memory

Item=Available memory

在这里插入图片描述

grafana 使用模版

在 https://grafana.com/dashboards 中提供很多第三方模版 , 使用 Dashboard Servers Linux 这个模版

在这里插入图片描述

复制模版的 id

在这里插入图片描述

配置模版信息

在这里插入图片描述

最终在一个面板中展示了当前 CPU、内存等,相对原始的数据展示更加直观。

在这里插入图片描述

结语

Linux 服务器监控在实际工作中大部分是运维的工作,随着测试工程师的职责越来越广了,测试运维这个岗位也会在以后的工作中慢慢展开。

另外像测试组自己的服务器和在压测中使用的压测机器,也可以搭建监控系统来监控数据。

参考文章

  • Zabbix 官方文档
    https://www.zabbix.com/documentation/3.4/zh/manual/quickstart/login

  • Docker 实战之二:zabbix 监控其他机器
    https://blog.csdn.net/bbwangj/article/details/80786623

  • Docker 部署 ELK、grafana、zabbix
    https://blog.51cto.com/zhanghy/2300633

  • Grafana + Zabbix — 部署分布式监控系统
    https://www.cnblogs.com/yyhh/p/4792830.html#l02

  • Docker 运行 grafana 与 zabbix 结合
    https://cloud.tencent.com/info/6969106dee9ecb7eaca02744c94a0614.html

  • Zabbix server+agent+proxy 搭建性能监控平台
    https://blog.csdn.net/zha6476003/article/details/80562860

  • Grafana 插件
    https://grafana.com/plugins/alexanderzobnin-zabbix-app/installation

  • Grafana 模版
    https://grafana.com/dashboards?category=zabbix

  • (end)

更多技术文章

最后

以上就是幸福纸鹤为你收集整理的使用 Zabbix + Grafana 搭建服务器监控系统的全部内容,希望文章能够帮你解决使用 Zabbix + Grafana 搭建服务器监控系统所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(56)

评论列表共有 0 条评论

立即
投稿
返回
顶部