Python和Shell脚本实现轻量级监控接口

 更新时间:2025年08月18日 09:40:33   作者:网罗开发  
这篇文章主要介绍了如何通过 Python 和 Shell 脚本快速实现接口监控,自动读取接口列表,批量检测接口返回状态和耗时,并最终生成一份清晰的可视化报告,希望对大家有所帮助

在日常运维和开发工作中,我们经常会遇到这样一个问题:系统上线之后,需要验证几十甚至上百个接口是否都能正常访问。手动一个一个去点、去测,不仅效率低,而且容易漏掉关键接口。特别是在微服务架构下,接口数量庞大,接口的健康状况直接决定了服务是否稳定。

本文将介绍如何通过 Python 和 Shell 脚本快速实现接口监控,自动读取接口列表,批量检测接口返回状态和耗时,并最终生成一份清晰的可视化报告(支持 Markdown 或 HTML 格式)。这样你就能在最短时间内确认接口是否健康,而不是盯着浏览器或 Postman 一次次重复操作。

引言

随着微服务、API 网关、容器化部署的普及,一个完整的应用系统可能依赖几十个甚至上百个 REST API 接口。每次上线之后,团队都要花费时间确认接口是否正常响应,尤其是在跨环境(开发、测试、生产)部署时,这种验证工作不可或缺。
传统做法是开发手工用浏览器打开、用 Postman 点接口,或者通过 curl 一条条执行。这种方式效率很低,而且不可持续。理想的方式应该是:

  • 批量读取接口地址
  • 自动检测接口是否存活、返回码和响应时间
  • 把结果生成报告,一目了然

接下来,我们就来一步步构建一个这样的轻量化解决方案。

用 Python 快速实现接口监控

读取接口列表

通常我们会把接口集中放在一个文本文件里,比如 urls.txt

https://api.example.com/health
https://api.example.com/v1/user
https://api.example.com/v1/order

每一行代表一个待检测的接口。

核心脚本实现

下面的 Python 脚本使用 requests 来检测接口,记录返回的状态码和耗时,并把结果写入一个 Markdown 报告文件。

import requests
import time
from datetime import datetime

def check_url(url):
    try:
        start = time.time()
        response = requests.get(url, timeout=5)
        duration = round((time.time() - start) * 1000, 2)  # 毫秒
        return response.status_code, duration
    except Exception as e:
        return None, None

def main():
    # 读取接口列表
    with open("urls.txt", "r") as f:
        urls = [line.strip() for line in f if line.strip()]

    # 生成报告文件
    report_name = f"report_{datetime.now().strftime('%Y%m%d_%H%M%S')}.md"
    with open(report_name, "w") as report:
        report.write("| URL | Status | Response Time (ms) |\n")
        report.write("| --- | ------ | ------------------ |\n")
        for url in urls:
            status, duration = check_url(url)
            if status:
                report.write(f"| {url} | {status} | {duration} |\n")
            else:
                report.write(f"| {url} | Error | - |\n")
    print(f"接口检测完成,结果保存在 {report_name}")

if __name__ == "__main__":
    main()

代码解析

  • check_url:负责单个接口检测,返回状态码和耗时。
  • urls.txt:统一管理所有待检测接口。
  • report_xxx.md:自动生成 Markdown 格式的检测结果,方便阅读或上传到 GitLab/GitHub。

示例输出

| URL | Status | Response Time (ms) |
| --- | ------ | ------------------ |
| https://api.example.com/health | 200 | 120.35 |
| https://api.example.com/v1/user | 200 | 220.11 |
| https://api.example.com/v1/order | Error | - |

用 Shell 脚本实现极简版本

有些时候,Python 环境不方便直接部署,这时可以用一个简单的 Shell 脚本加 curl 来实现:

#!/bin/bash

input="urls.txt"
output="report_$(date +%Y%m%d_%H%M%S).md"

echo "| URL | Status | Time (ms) |" > $output
echo "| --- | ------ | --------- |" >> $output

while IFS= read -r url
do
    if [ -n "$url" ]; then
        start=$(date +%s%3N)
        status=$(curl -o /dev/null -s -w "%{http_code}" "$url")
        end=$(date +%s%3N)
        duration=$((end-start))
        
        if [ "$status" -eq 200 ]; then
            echo "| $url | $status | $duration |" >> $output
        else
            echo "| $url | $status | $duration |" >> $output
        fi
    fi
done < "$input"

echo "接口检测完成,结果保存在 $output"

核心逻辑

  • curl 获取接口响应状态码。
  • 计算时间差作为响应时长。
  • 输出 Markdown 格式结果。

应用场景举例

场景一:服务上线前的批量验证

开发完成后要上线新版本,可以先在测试环境跑一遍检测脚本,确保所有接口返回 200,再推进到生产。

示例:

python check_api.py

得到报告后,可以快速交给 QA 或运维确认。

场景二:定时健康检查

通过 cron 或 CI/CD 配合脚本定时执行,把接口状态报告每天生成一次。

这样可以快速发现某个接口挂掉的情况,而不是等用户反馈。

示例 crontab -e 配置:

0 * * * * python /home/user/check_api.py

表示每小时执行一次。

场景三:上线后灰度验证

在灰度发布过程中,可以只把部分接口地址放进 urls_gray.txt,运行检测脚本,快速确认新版本健康。

QA 环节

Q1:能不能直接生成 HTML 报告?

可以。把 Markdown 转换成 HTML 非常容易,Python 中可以用 markdown 库,或者直接输出 HTML 表格。

Q2:如果接口需要鉴权怎么办?

可以在 requests.get()curl 中加上 Header,比如带上 Token。

Q3:能不能同时检测并发请求?

完全可以,用 Python 的 concurrent.futures 或者 asyncio 实现异步检测,可以大幅度提升检测速度。

总结

本文展示了如何用 Python 和 Shell 脚本快速实现一套接口监控方案,解决了部署后需要手动逐一验证接口的问题。方案的关键点在于:

  • 接口集中管理,批量检测。
  • 检测结果可视化(Markdown/HTML)。
  • 可结合 CI/CD 或定时任务,实现自动化。

这种方案非常适合微服务架构下的日常运维,既轻量又实用,不需要额外引入复杂的监控平台,就能在第一时间发现接口问题。

到此这篇关于Python和Shell脚本实现轻量级监控接口的文章就介绍到这了,更多相关Python监控接口内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Python编程学习之如何判断3个数的大小

    Python编程学习之如何判断3个数的大小

    这篇文章主要给大家介绍了关于Python编程学习之如何判断3个数的大小的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Python具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-08-08
  • 对django 2.x版本中models.ForeignKey()外键说明介绍

    对django 2.x版本中models.ForeignKey()外键说明介绍

    这篇文章主要介绍了对django 2.x版本中models.ForeignKey()外键说明介绍,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-03-03
  • Python上传package到Pypi(代码简单)

    Python上传package到Pypi(代码简单)

    这篇文章主要介绍了Python上传package到Pypi(代码简单)的相关资料,需要的朋友可以参考下
    2016-02-02
  • python opencv 找出图像中的最大轮廓并填充(生成mask)

    python opencv 找出图像中的最大轮廓并填充(生成mask)

    这篇文章主要介绍了python opencv 找出图像中的最大轮廓并填充(生成mask),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-03-03
  • 示例详解python中的排序

    示例详解python中的排序

    本文详细介绍了如何使用Python实现两组数据的纵向排序,包括开发思想、开发流程和代码示例,感兴趣的朋友一起看看吧
    2024-12-12
  • 详解python中__name__的意义以及作用

    详解python中__name__的意义以及作用

    这篇文章主要介绍了详解python中__name__的意义以及作用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-08-08
  • python2.7和NLTK安装详细教程

    python2.7和NLTK安装详细教程

    这篇文章主要为大家详细介绍了python2.7和NLTK安装详细教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-09-09
  • 如何一键升级Python所有包

    如何一键升级Python所有包

    这篇文章主要介绍了如何一键升级Python所有包,帮助大家更好的理解和使用python,感兴趣的朋友可以了解下
    2020-11-11
  • Win10 GPU运算环境搭建(CUDA10.0+Cudnn 7.6.5+pytroch1.2+tensorflow1.14.0)

    Win10 GPU运算环境搭建(CUDA10.0+Cudnn 7.6.5+pytroch1.2+tensorflow1.

    熟悉深度学习的人都知道,深度学习是需要训练的,本文主要介绍了Win10 GPU运算环境搭建,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-09-09
  • python使用scapy模块实现ping扫描的过程详解

    python使用scapy模块实现ping扫描的过程详解

    这篇文章主要介绍了python使用scapy模块实现ping扫描的过程详解,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-01-01

最新评论