一. 项目背景

监控异地局域网主机(主机内有物联5G卡 可以单方面向特定的云服务器传输信息)这里采用 zabbix 5xx系列 agent2 -6.2 版本 主动模式,即客户端向服务端注册。
 

二. 部署服务端

2.1 安装docker

#01 安装docker
# step 1: 安装必要的一些系统工具
sudo yum install -y yum-utils device-mapper-persistent-data lvm2
# Step 2: 添加软件源信息
sudo yum-config-manager --add-repo https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
# Step 3
sudo sed -i 's+download.docker.com+mirrors.aliyun.com/docker-ce+' /etc/yum.repos.d/docker-ce.repo
# Step 4: 更新并安装Docker-CE
sudo yum makecache fast
sudo yum -y install docker-ce
# Step 4: 开启Docker服务
sudo service docker start #02 设置镜像加速
sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{
"registry-mirrors": ["https://9akof579.mirror.aliyuncs.com"]
}
EOF
sudo systemctl daemon-reload
sudo systemctl restart docker
 
  1. 安装docker-compose
  #01 下载docker-compose
curl -L https://get.daocloud.io/docker/compose/releases/download/1.29.1/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose #02 给docker-compose目录授权 s
udo chmod +x /usr/local/bin/docker-compose #03 查看一下version 显示有版本号那就说明安装成功了
docker-compose version
  1. 部署服务


#01 创建数据目录
mkdir -p /opt/zabbix
cd /opt/zabbix/ #02 docker-compose 文件
[root@centos7 zabbix]# cat docker-compose.yml
version: '3' services:
zabbix-web-nginx-mysql:
image: zabbix/zabbix-web-nginx-mysql:centos-5.2-latest
restart: always
environment:
- DB_SERVER_HOST=zabbix-mysql
- MYSQL_DATABASE=zabbix
- MYSQL_USER=zabbix
- MYSQL_PASSWORD=zabbix
- MYSQL_ROOT_PASSWORD=123qwe
- ZBX_SERVER_HOST=zabbix-server-mysql
ports:
- 8080:8080
volumes:
- /etc/localtime:/etc/localtime
- /opt/zabbix/fonts/DejaVuSans.ttf:/usr/share/zabbix/assets/fonts/DejaVuSans.ttf
networks:
- zbx_net
depends_on:
- zabbix-server-mysql
- zabbix-mysql
zabbix-mysql:
image: mysql:8.0.23
restart: always
ports:
- 3306:3306
environment:
- MYSQL_DATABASE=zabbix
- MYSQL_USER=zabbix
- MYSQL_PASSWORD=zabbix
- MYSQL_ROOT_PASSWORD=123qwe
command:
- mysqld
- --default-authentication-plugin=mysql_native_password
- --character-set-server=utf8
- --collation-server=utf8_bin
volumes:
- /etc/localtime:/etc/localtime
- /opt/zabbix/db:/var/lib/mysql
networks:
- zbx_net
zabbix-java-gateway:
image: zabbix/zabbix-java-gateway:centos-5.2-latest
restart: always
volumes:
- /etc/localtime:/etc/localtime
networks:
- zbx_net
zabbix-server-mysql:
image: zabbix/zabbix-server-mysql:centos-5.2-latest
restart: always
volumes:
- zabbix-server-vol:/etc/zabbix
- /opt/zabbix/alertscripts:/usr/lib/zabbix/alertscripts
- /etc/localtime:/etc/localtime
ports:
- 10051:10051
environment:
- DB_SERVER_HOST=zabbix-mysql
- MYSQL_DATABASE=zabbix
- MYSQL_USER=zabbix
- MYSQL_PASSWORD=zabbix
- MYSQL_ROOT_PASSWORD=123qwe
- ZBX_JAVAGATEWAY=zabbix-java-gateway
- ZBX_JAVAGATEWAY_ENABLE=true
- ZBX_JAVAGATEWAYPORT=10052
depends_on:
- zabbix-mysql
networks:
- zbx_net
zabbix-agent:
image: zabbix/zabbix-agent:centos-5.2-latest
restart: always
ports:
- 10050:10050
environment:
- ZBX_HOSTNAME=Zabbix server
- ZBX_SERVER_HOST=zabbix-server-mysql
- ZBX_SERVER_PORT=10051
networks:
- zbx_net networks:
zbx_net:
driver: bridge volumes:
zabbix-server-vol: #03 创建目录
mkdir alertscripts db fonts #04 安装中文语言包
cd fonts
wget https://dl.cactifans.com/zabbix_docker/msty.ttf
mv msty.ttf DejaVuSans.ttf #05 启动服务
docker-compose up -d

3.启动检查

  1. 浏览器访问 主机IP+8080端口 默认账户密码:Admin zabbix
  2. 系统语言汉化(图一)
  3. 我们要修改一下配置,将ip更换为容器名称,不然会检测不到(图二,删除IP 换成 dns名称加端口)

 
 

4.自动发现

 

三. 客户端配置

3.1 安装agent2

## 监控客户端服务器
1) 安装服务 并修改配置文件
yum install -y zabbix-agent2
# 由于网络原因 这里选择wget安装
wget https://mirrors.tuna.tsinghua.edu.cn/zabbix/zabbix/5.0/rhel/7/x86_64/zabbix-agent2-5.0.13-1.el7.x86_64.rpm
yum localinstall -y zabbix-agent2-5.0.13-1.el7.x86_64.rpm 2) 修改systemctl管理的单元文件
# 修改agent2配置文件,修改如下,填写zabbix-server主机ip和主机名
[root@centos7 zabbix]# egrep -v '^#|^$' /etc/zabbix/zabbix_agent2.conf
PidFile=/var/run/zabbix/zabbix_agent2.pid
LogFile=/var/log/zabbix/zabbix_agent2.log
LogFileSize=0
Server=192.168.5.249 # 服务端ip
ServerActive=192.168.5.249 # 服务端ip
Hostname=
HostnameItem=system.hostname # 客户端主机名
HostMetadataItem=system.uname # 客户端系统信息
Include=/etc/zabbix/zabbix_agent2.d/*.conf
ControlSocket=/tmp/agent.soc 3)重启服务
[root@db01 ~]$ systemctl restart zabbix-agent2.service 4)服务端去验证
zabbix_get -s 10.0.0.7 -p 10050 -k 'agent.ping'

3.2 页面验证

 
 
监控 nginx 11种状态
 
#  tcp的11种状态每种状态的数量 

1) 需要的命令
root@web01 ~]# netstat -tna
[root@web01 ~]# netstat -tna | awk '{print $NF}' | sort | uniq -c | sort -rn | awk 'BEGIN{print "TCP状态 \t","连接数量"} {print $2"\t",$1} ' |column -t
TCP状态 连接数量
LISTEN 11
TIME_WAIT 10
SYN_SENT 1
State 1
ESTABLISHED 1
established) 1
 

四. MQQT 协议收集消息


##注意
MQQT服务器为中转服务器,即客户端和服务端都订阅该服务器
1)zabbix服务端
2)zabbix客户端
3)mqqt服务器 #01 安装MQTT服务器(mosquitto)
1) 安装编译环境
yum install gcc-c++ cmake openssl-devel -y 2)下载mosquitto
wget http://mosquitto.org/files/source/mosquitto-1.6.8.tar.gz 3)解压 编译 安装
echo "解压"
tar -zxvf mosquitto-1.6.8.tar.gz
echo "进入mosquitto-1.6.8"cd mosquitto-1.6.8
echo "编译"
make
echo "安装"
sudo make install 4)修改链接路径,重新加载动态链接库
sudo ln -s /usr/local/lib/libmosquitto.so.1 /usr/lib/libmosquitto.so.1
sudo ldconfig 5)创建配置文件 和用户 用户组
cp /etc/mosquitto/mosquitto.conf.example /etc/mosquitto/mosquitto.conf
sudo groupadd mosquitto
sudo useradd -g mosquitto mosquitto -s /sbin/nologin 6) 启动、查看、关闭程序
echo "运行程序"
mosquitto -c /etc/mosquitto/mosquitto.conf -d
echo "ps查看"
ps -aux | grep mosquitto
echo "关闭程序"kill -9 $(pidof mosquitto) 7)本地简单测试
# 打开一个订阅者
mosquitto_sub -t topic # 打开一个发布者
mosquitto_pub -t topic -m "发布内容" https://zhuanlan.zhihu.com/p/164930347
  • Python 实现订阅和发布

##订阅
# -*- coding: utf-8 -*-
import paho.mqtt.client as mqtt def on_connect(client, userdata, flags, rc):
print("Connected with result code: " + str(rc)) def on_message(client, userdata, msg):
print(msg.topic + " " + str(msg.payload)) client = mqtt.Client()
#设置用户名和密码
# client.username_pw_set("mosquitto", "mosquitto")
client.on_connect = on_connect
client.on_message = on_message
#client.on_disconnect = on_disconnect
#连接 IP port keepalive
client.connect('101.200.170.7', 1833, 600)
#订阅的 topic
client.subscribe('test', qos=0)
client.loop_forever() ###发布
# -*- coding: utf-8 -*-
import paho.mqtt.client as mqtt def on_connect(client, userdata, flags, rc):
print("Connected with result code: " + str(rc)) def on_message(client, userdata, msg):
print(msg.topic + " " + str(msg.payload)) client = mqtt.Client()
#设置用户名和密码
#client.username_pw_set("mosquitto", "mosquitto")
client.on_connect = on_connect
client.on_message = on_message
#连接 IP port keepalive
client.connect('101.200.170.7', 1833, 600)
#发布 topic 内容
client.publish('test', payload='111ing', qos=0)
 
  • 添加监控项

#01 监控项参数 mqtt.get["tcp://192.168.5.249:1833","test"] mqqt服务器地址和端口:"tcp://192.168.5.249:1833"
topic 名称:test (自定义 需要先创建订阅) 例如:mosquitto_sub -t topic

 
  • 图示

 
 
 
 
 

Zabbix MQQT协议监控 loT设备的更多相关文章

  1. zabbix snmp 协议监控 dell iRDAC

    转摘:http://blog.csdn.net/wanglei_storage/article/details/52789921 http://blog.csdn.net/wanglei_storag ...

  2. 技巧:结合Zabbix与SNMP监控嵌入式设备

    在如何利用Zabbix监控网络设备三篇文章的前两篇中,我们介绍了如何通过Zabbix代理监控网络设备.但有些设备无法安装Zabbix代理,需要采用其他方法监控.需要考虑无法安装软件的嵌入式设备或应用程 ...

  3. 在ZABBIX平台上通过SNMP协议监控网络设备

    在ZABBIX平台上通过SNMP协议监控网络设备 方法一:自动发现监控项 ZABBIX自带模板Template SNMP Interfaces中有"自动发现规则"这一选项,在主机选 ...

  4. zabbix基于SNMP 协议监控路由器

    zabbix基于SNMP 协议监控路由器 步骤 步骤超级方便. 1. 路由器上开启snmp 2. 确保外网能訪问到 3. 用snmpwalk測试 4. 加入zabbix主机,SNMP interfac ...

  5. 转:ZABBIX监控H3C设备的CPU和内存使用率

      由于最近监控的H3C路由器经常出现死机现象,SNMP获取不到数据,后面检查发现是CPU使用率过高,直接导致无法处理SNMP请求,所以需求来了,怎样通过SNMP监控H3C路由器的CPU和内存使用率? ...

  6. 自学Zabbix11.1 Zabbix 配置SNMP监控

    点击返回:自学Zabbix之路 点击返回:自学Zabbix4.0之路 点击返回:自学zabbix集锦 自学Zabbix11.1 Zabbix 配置SNMP监控 1. 概述 zabbix采集数据方式: ...

  7. zabbix 配置SNMP监控

    什么是SNMP? 简单网络管理协议(SNMP),由一组网络管理的标准组成,包含一个应用层协议(application layer protocol).数据库模型(database schema)和一组 ...

  8. 【Zabbix】分布式监控系统Zabbix【一】

    一.Zabbix功能及特性简介 Zabbix可以获取cpu,内存,网卡,磁盘,日志等信息 1.Zabbix数据收集方式: a.Agent客户端(Agent客户端支持多平台部署) b.如果是无法安装客户 ...

  9. Zabbix企业级开源监控解决方案

    Zabbix企业级开源监控解决方案 目录 Zabbix企业级开源监控解决方案 一.Zabbix 1. 监控系统的必要性 2. 监控软件的作用 3. Zabbix的定义 4. Zabbix的监控原理 5 ...

  10. zabbix之1监控概念

    1.通过通用的snmp监控,无需代理端 2.通过snmp代理 snmp代理的工作原理:在被监控端设置代理,代理不断的获取本地数据,而管理端定期通过代理获取监控数据. snmp目前有v1,v2,v3三种 ...

随机推荐

  1. 微信小程序-页面生命周期方法

    在经过上一篇文章的介绍之后,我们知道了大体的生命周期在什么时候执行,这次主要是以代码的形式来展示一下具体的阶段执行什么生命周期方法. 首先我们编写一个代码可以从首页跳转到日志页面: <!--in ...

  2. 强化学习从基础到进阶-案例与实践[1]:强化学习概述、序列决策、动作空间定义、策略价值函数、探索与利用、Gym强化学习实验

    强化学习从基础到进阶-案例与实践[1]:强化学习概述.序列决策.动作空间定义.策略价值函数.探索与利用.Gym强化学习实验 1.1 强化学习概述 强化学习(reinforcement learning ...

  3. 人工智能创新挑战赛:海洋气象预测Baseline[4]完整版(TensorFlow、torch版本)含数据转化、模型构建、MLP、TCNN+RNN、LSTM模型训练以及预测

    人工智能创新挑战赛:海洋气象预测Baseline[4]完整版(TensorFlow.torch版本)含数据转化.模型构建.MLP.TCNN+RNN.LSTM模型训练以及预测 1.赛题简介 项目链接以及 ...

  4. 【二】Latex入门使用、常见指令

    参考链接:https://blog.csdn.net/cocoonyang/article/details/78036326 \documentclass[12pt, a4paper]{article ...

  5. 【CAS学习一】CAS服务端部署

    公司要做单点登录系统,网上搜了一下目前主流方案是CAS,故部署一个试试看. 1.下载 因为最近出现log4j2远程代码执行漏洞,尽量选择新版本已修复此漏洞的,故CAS选择6.4版本.打包部署依赖JDK ...

  6. Word-批量导出Word中的图片

    当我们需要把Word文件中的图片保存起来,你是如何导出Word图片呢?右键一张张保存图片吗?这效率太低了.如果文档中有大量的图片,这个方法会浪费很多时间. 下面给大家分享word如何批量导出图片的技巧 ...

  7. Windows上同时使用有线网络及无线网络连接配置

    由于公司搬到了新的办公地点,公司内部只有内网,当需要连接互联网查询资料时只能切换网络,非常麻烦.所以为了能够同时连接连接公司内网,又能够访问互联网,这里介绍如何同时连接无线和有线. 有线网络:10.3 ...

  8. python使用pandas库读写excel文件

    操作系统 : Windows 10_x64 Python 版本 : 3.9.2_x64 平时工作中会遇到Excel数据处理的问题,这里简单介绍下怎么使用python的pandas库读写Excel文件. ...

  9. C# 二十年语法变迁之 C# 7参考

    C# 二十年语法变迁之 C# 7参考 https://benbowen.blog/post/two_decades_of_csharp_iii/ 自从 C# 于 2000 年推出以来,该语言的规模已经 ...

  10. NC16619 [NOIP2008]传球游戏

    题目链接 题目 题目描述 上体育课的时候,小蛮的老师经常带着同学们一起做游戏.这次,老师带着同学们一起做传球游戏. 游戏规则是这样的:n个同学站成一个圆圈,其中的一个同学手里拿着一个球,当老师吹哨子时 ...