python批量连接服务器检查容器是否正常

 更新时间:2024年01月12日 11:03:46   作者:碧莲城  python进阶测试  
在生产中,我们可能有很多项目或者很多环境,可能会部署在几百上千的服务器里面,我们该怎么定时去监控这些服务器里面的容器服务器是否正常呢,本文就来为大家讲解

引言

在生产中,我们可能有很多项目或者很多环境。可能会部署在几百上千的服务器里面。我们该怎么定时去监控这些服务器里面的容器服务器是否正常呢?

python监控docke容器是否正常运行中

下面我用python写了一个程序,可以直接去监控docke容器是否正常运行中:

# -*- coding: utf-8 -*-
import paramiko   # 导入paramiko 模块用于,SSH连接
# 定义一个名为server_list的字典,包含多个服务器的信息
sever_list = {
    '服务器1': ['192.168.1.1', 'root', '密码', 19005],
    '服务器2': ['116.168.10.253', 'root', '9997d9898LdJ', 22]
}
def traceback_methon(n):
    import traceback
    for key, values in sever_list.items():
        server, username, password, port = values  # 使用解构将值分别赋给五个变量
        try:
            ssh = paramiko.SSHClient()
            ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
            ssh.connect(server, username=username, password=password, port=port)  # 用户名和密码进行连接
            try:
                stdin, stdout, stderr = ssh.exec_command(
                    'docker ps --filter "status=exited" --filter "status=paused" --filter "status=removing" --filter "status=dead" --format "{{.ID}} {{.Names}} {{.Status}}"')  # 执行一个命令
            except paramiko.SSHException:
                print('命令执行失败:SSH协议异常')
                traceback.print_exc()  # 打印详细的错误信息
                continue
            except Exception:
                print('命令执行失败:其他异常')
                traceback.print_exc()  # 打印详细的错误信息
                continue
            for line in stdout:
                if line is not None or line != '':
                    print(str(n) + '、 ' + key + " " + server + " 该容器有问题 " + " >> " + line.strip('\n'))  # 打印输出结果
                else:
                    print(str(n) + '、 ' + key + '没有停止、暂停、迁移、死亡 的容器,')
                n = n + 1
        except paramiko.AuthenticationException:
            print('连接失败:认证失败')
            traceback.print_exc()  # 打印详细的错误信息
            continue
        except paramiko.SSHException:
            print('连接失败:SSH协议异常')
            traceback.print_exc()  # 打印详细的错误信息
            continue
        except Exception:
            print('连接失败:其他异常')
            traceback.print_exc()  # 打印详细的错误信息
            continue
paramiko_methon()

上面这段代码是一个Python脚本,用于通过SSH连接到一组服务器,并使用Docker命令检查每个服务器上是否有已停止、暂停、正在被移除或已死亡的容器。

代码解析

下面是代码的详细解释:

定义traceback_methon函数

这个函数是为了跟踪和输出异常信息。它接受一个参数n
遍历服务器列表:
对于sever_list字典中的每一项,代码执行以下操作:

  • 解构赋值:从字典值中提取出IP地址、用户名、密码和端口,并分别赋值给server,username,password,port变量。

  • 尝试建立SSH连接:使用paramiko.SSHClient()创建一个SSH客户端,并设置缺少主机密钥策略为自动添加。然后尝试使用给定的用户名和密码进行连接。

  • 执行Docker命令:如果SSH连接成功,代码将尝试执行一个Docker命令来查找具有特定状态的容器。它使用exec_command方法执行命令,并捕获标准输入、输出和错误输出。

  • 处理输出:对于每个服务器的输出,检查是否包含非空行。如果包含非空行,则打印出有关问题的容器信息;否则,打印出没有问题的容器信息。同时,递增n的值。

  • 处理异常:如果在尝试建立SSH连接或执行Docker命令时出现异常,代码将捕获异常并打印相应的错误消息。同时,继续处理下一个服务器。

异常处理

对于不同的异常情况(如认证失败、SSH协议异常等),代码会捕获它们并打印相应的错误消息。

让我们运行上面的程序脚本:

根据下方的结果。我们可以很清楚的看到哪个服务器的容器有问题,输出了容器ID、容器名称、容器状态。

后续我们还可以进行对这个 脚本优化,可进行持续集成Jenkins,发送邮件,发送钉钉和企业微信机器人等操作。

以上就是python批量连接服务器检查容器是否正常的详细内容,更多关于python服务器容器检查的资料请关注脚本之家其它相关文章!

相关文章

  • PyTorch Tensor创建实现

    PyTorch Tensor创建实现

    本文主要介绍了PyTorch Tensor创建实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-06-06
  • Python实现PDF文档高效转换为HTML文件的完整指南

    Python实现PDF文档高效转换为HTML文件的完整指南

    在数字化办公场景中,PDF因其格式固定、跨平台兼容性强成为文档分发的主流格式,但有时也需要将PDF转换为HTML,下面我们就使用Python实现这一功能吧
    2025-11-11
  • 使用Python操作MySQL的一些基本方法

    使用Python操作MySQL的一些基本方法

    这篇文章主要介绍了使用Python操作MySQL的一些基本方法,Python+MySQL也是服务器端快速开发的一种绝佳搭配方案,需要的朋友可以参考下
    2015-08-08
  • 详解Python变量与注释高级用法

    详解Python变量与注释高级用法

    变量与注释是表达作者思想的基础,他们对代码质量的贡献母庸质疑,这篇文章主要介绍了Python变量与注释高级用法,需要的朋友可以参考下
    2022-08-08
  • 基于matlab atan2函数解析

    基于matlab atan2函数解析

    这篇文章主要介绍了matlab atan2函数解析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-09-09
  • Python数组拼接np.concatenate实现过程

    Python数组拼接np.concatenate实现过程

    这篇文章主要介绍了Python数组拼接np.concatenate实现过程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-04-04
  • python中[,a::b]的使用

    python中[,a::b]的使用

    本文通过实例详细介绍了Python中如何使用[a::b]语法来对数组进行切片操作,包括不同步长b对数组索引的影响,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧
    2026-03-03
  • Python selenium的这三种等待方式一定要会!

    Python selenium的这三种等待方式一定要会!

    今天给大家带来的是关于Python的相关知识,文章围绕着selenium三种等待方式展开,文中有非常详细的介绍,需要的朋友可以参考下
    2021-06-06
  • django manage.py扩展自定义命令方法

    django manage.py扩展自定义命令方法

    今天小编就为大家分享一篇django manage.py扩展自定义命令方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-05-05
  • Python实现API开发的详细教程

    Python实现API开发的详细教程

    在现代软件开发中,API扮演着至关重要的角色,API接口用于不同软件组件之间的通信和数据交换,实现了系统之间的互操作性,Python作为一种简单易用且功能强大的编程语言,广泛应用于API接口的开发,本文将详细介绍如何使用Python开发API接口,需要的朋友可以参考下
    2024-12-12

最新评论