news 2026/6/25 14:48:34

机房ping监控全国主要城市

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
机房ping监控全国主要城市

前言

当初项目的本意是为了监测中心机房到全国各地(主要是省会与重要城市)的ping速率而创建,目标ip地址是根据某个ip网站爬取,而现在该网站已经下线了,导致目标ip无法获取,再加上所用组件版本已经年久失修,最后是本人懒惰~~,导致项目已经不可用很久了

今年勤奋战胜懒惰,又重新占领高地,想着把该项目重修修缮一遍

开始修缮

更换ip库:放弃了之前的网站,重新找了一份ip地址库,并且会定期更新

部署方式变更:使用docker容器部署,方便部署,

加入更多城市:不但跟踪省会以及重要城市,还有地级市也一并跟踪了

自动更新ip:每3个小时处理不能ping通的ip,并且从ip库找一个可用的ip地址更新

更换最新页面:可以选择使用原生的页面,也可以prometheus+pushgateway+grafana查看更细致的页面

安装

docker volume create idc_ping_monitor_V

docker run -d --name idc_smokeping -p 8001:80 -v idc_ping_monitor_V:/opt -v ./data:/data registry.cn-beijing.aliyuncs.com/wilsonchai/idc_smokeping:v1

docker run -d --name idc_sidecar -v idc_ping_monitor_V:/opt -v ./data/:/data registry.cn-beijing.aliyuncs.com/wilsonchai/idc_sidecar:v1

这里需要注意的是,./data文件存放了所有城市的ping数据,idc_smokeping与idc_sidecar需要共享该目录。如果之前的数据不想要,可直接删除即可

如果有需要推送到pushgateway,那就需要重新配置idc_sidecar

注:prometheus需要idc_ping_monitor启动6分钟之后才会有数据

docker rm -f idc_sidecar

docker run -d --name idc_sidecar -e PUSHGATEWAY_URL=10.22.12.178:9091 -v idc_ping_monitor_V:/opt -v ./data/:/data registry.cn-beijing.aliyuncs.com/wilsonchai/idc_sidecar:v1

编译

如果需要自己编译,也可以进入两个目录分别操作

idc_smokeping

cd smokeping && docker build . -t registry.cn-beijing.aliyuncs.com/wilsonchai/idc_smokeping:v1

idc_sidecar

cd sidecar && docker build . -t registry.cn-beijing.aliyuncs.com/wilsonchai/idc_sidecar:v1

详解

idc_smokeping:使用smokeping作为数据采集端,负责采集到各城市ip的ping数据,存为rrd格式的数据文件,每3分钟采集一次,并且每3小时会应用一次新的城市ip(如果有更新)

idc_sidecar:

使用cron+python脚本,每小时检查城市ip是否能够ping通,如果不能ping通,就立刻在ip库中更换一个

如果配置了环境变量:PUSHGATEWAY_URL,那每3分钟将各个城市的数据采集到pushgateway,从而进入prometheus,方便后续分析

./data:各城市的ping数据存放在宿主机当前目录的./data下面,便于保存、备份或者删除

idc_ping_monitor_V:docker volume,用来存放各城市的ip地址以及ip库

效果

1)原生的效果图

watermarked-idc_monitor_ping_1

2)grafana

watermarked-idc_monitor_ping_2

这里需要注意的是:该panel有2个参数:省份和城市。省份可以选择,由于城市过多(1010个),选择城市的时候需要自行输入

代码仓库

代码地址

最后再来分析一下仓库目录下的代码组成,方便大家使用

▶ tree -L 1

.

├── grafana

├── sidecar

└── smokeping

grafana目录主要存放了grafana的模版文件,需要的时候直接导入进grafana即可

▶ ls -l grafana

total 20

-rw-rw-r-- 1 wilson wilson 18946 11月 5 18:43 全国速率监测(地级市版).json

sidecar目录主要存放了各种操作城市数据相关的脚本

smokeping目录主要存放了smokeping相关的配置文件

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/24 21:34:39

揭秘Docker环境下LangGraph Agent扩展原理:3步实现智能体无缝集成

第一章:揭秘Docker环境下LangGraph Agent扩展原理:3步实现智能体无缝集成在现代AI系统架构中,LangGraph Agent作为可扩展的智能体运行时,能够在Docker容器化环境中实现高效隔离与灵活部署。通过将其核心逻辑封装为微服务&#xff…

作者头像 李华
网站建设 2026/6/25 16:43:08

【高阶运维必修课】:Docker Offload资源释放不彻底的6大根源

第一章:Docker Offload资源释放的核心挑战在现代容器化架构中,Docker Offload机制常用于将部分运行时任务(如网络、存储操作)从主控进程卸载到独立的协处理模块,以提升系统性能与资源利用率。然而,在实际应…

作者头像 李华
网站建设 2026/6/24 17:47:48

【MS-720考试通关秘籍】:深入理解Teams Agent消息流的7个核心技术点

第一章:MS-720考试中Teams Agent消息流的核心定位在准备Microsoft MS-720认证考试时,深入理解Teams Agent消息流的机制是构建高效协作解决方案的关键。该消息流不仅决定了用户与Teams环境之间的交互路径,还直接影响自动化流程、合规性策略以及…

作者头像 李华
网站建设 2026/6/23 21:44:03

多继承与虚基类

多继承派生类的语法格式&#xff1a;class 派生类名 : <继承方式1> 基类名1,<继承方式2> 基类名2,…… { ……//派生类新添加的成员};多继承派生类对象的构造和析构:派生类名(参数表):基类名1(参数表1),基类名2(参数表2),对象成员1(参数表3),对象成员2(参数…

作者头像 李华
网站建设 2026/6/25 7:45:35

电子产品EMC整改:智能化设计工具重塑电磁兼容性优化|南柯电子

在万物互联的智能时代&#xff0c;电子产品的电磁兼容性&#xff08;EMC&#xff09;已成为决定产品市场准入与可靠性的核心指标。从消费电子到工业设备&#xff0c;从新能源汽车到医疗仪器&#xff0c;EMC问题不仅关乎设备自身的稳定运行&#xff0c;更直接影响用户安全与行业…

作者头像 李华
网站建设 2026/6/24 17:26:19

APP自动化第一步:Appium环境搭建

一、安装Appium Python client包 1.直接cmd窗口输入pip install Appium-Python-Client 2.要确保安装匹配版本的selenium和appium 使用命令pip install selenium -U 首先进入网盘下载这三个软件的压缩包 二、安装Appium Server 1.双击打开压缩包Appium 2.双击进行安装。 3.点…

作者头像 李华