python实现主机批量管理

简介:

 在日常的运维工作中批量对主机的是很常见的,市面上也有许多主机批量管理的软件,但有时候这些软件并不能完全的满足我们的需求。python中刚好提供了关于主机批量管理的模块,今天就让我们来看看如何利用python实现主机批量管理


python提供主机批量管理的模块主要有三个paramiko、fabric与pexpect,今天我们主要说的是paramiko模块,paramiko模块是第三方模块

安装:pip install paramiko或者yum install python-paramiko如果都安装失败的话可以使用源码安装

源码包下载地址:https://github.com/paramiko/paramiko/archive/master.zip


常用操作:

ssh = paramiko.SSHClient() //实例化,ssh会话类

ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())   //第一次连接自动回答为yes

ssh.connect('服务器ip',端口,'用户名','密码')     //连接服务器

stdin,stdout,stderr = ssh.exec_command("命令")      //执行命令,标准输出,命令成功返回,命令失败返回

ssh.close()                         //关闭连接



上传、下载:

get_put = paramiko.Transport((ip,port)) //服务器ip和端口(使用SFTP时使用)

get_put.connect(username="root", password="123.com")    //连接服务器,用户名和密码

sftp = paramiko.SFTPClient.from_transport(get_put)     //使用SFTP协议


sftp.put(需要上传的文件,上传文件保存的位置)              //上传

sftp.get(下载文件的位置, 下载保存的位置)  //下载



主机批量管理:

#!/usr/bin/python

#-*- coding: utf-8 -*-


import paramiko

import os


def Connect(ip='127.0.0.1',Port=22,user='root',pwd='123.com'):

    ssh = paramiko.SSHClient()

    ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())

    ssh.connect(hostname=ip, port=Port, username=user, password=pwd)    #连接服务器

    return ssh                                      #返回服务器句柄



def IP_ADD(ip):                      #判断用户输入的是一个地址还是地址范围

    __ip = ip.split('--')

    if len(__ip) == 2:                          #如果是地址范围

        ip_add = __ip[0]                        #取出ip

        ip_range = int(__ip[1])                 #取出ip的最大值

        host_ip_split = ip_add.split('.')       #将ip以.分隔为4段

        host_ip = int(host_ip_split.pop())      #取出ip的最小值

        ip_3 = '.'.join(host_ip_split)+'.'   #将已经去除了ip的最小值的剩余部分重新拼接


        host_add_range =  range(host_ip,ip_range+1)     #生成连接ip的范围

        add_pool = []

        for i in host_add_range:

            add = ip_3+str(i)                    #拼接为合法的ip地址

            add_pool.append(add)                 #生成地址池

        return add_pool                          #返回地址池


    elif len(__ip) == 1:                         #如果输入的为单个地址

        valid_ip = __ip[0]

        ip_value = valid_ip.split('.')[0:4]      #检测ip的合法性

        [ int(i) for i in ip_value ]


        return __ip                                 #返回地址



if __name__ == '__main__':

    os.system('clear')

    Fa = True


    while Fa:

        ip = raw_input('请输入一个ip地址或一个地址范围: ')

        exclude_ip = raw_input('请输入要排除的地址: ')

        try:

            ip_list = IP_ADD(ip)           #将用户输入的ip交给函数处理


            if exclude_ip.strip():          #判断用户是否要排除地址池中的地址

                exclude_add = exclude_ip.split(',')   #定义排除格式

                [ ip_list.remove(i) for i in exclude_add ]  #排除ip地址

            Fa = False                               #退出循环


        except:

            print '\033[31m地址格式错误\033[0m'

            print '''例:

                    127.0.0.1            对单台主机执行操作

                    127.0.0.1--254         对一个地址范围的主机执行操作

                    127.0.0.8,127.0.0.10     排除地址池中的地址

                  '''

            continue


    print '\033[31m输入script_exit退出程序\033[0m'

    while True:

        shell_comd = raw_input('请输入执行的命令: ')        #执行的命令


        if shell_comd == 'script_exit':

            break



        for i in ip_list:                           #循环地址池

            try:

                comd = Connect(ip=i)                #连接服务器

                stdin, stdout, stderr = comd.exec_command(shell_comd)   #执行命令


                stderr = stderr.read()      #命令正确执行的结果

                stdout = stdout.read()      #命令错误执行的命令


                if stdout:

                    print '\033[31m++++++++++++%s+++++++++++\033[0m'%i  

                    #那台服务器执行的命令

                    print stdout

                else:

                    print '\033[31m++++++++++++%s+++++++++++\033[0m'%i

                    print stderr


            except:

                print '\033[31m%s连接失败\033[0m' %i


paramiko还可以实现文件批量下载和批量上传,原理和批量执行命令基本一样。

本文转自  红尘世间  51CTO博客,原文链接:http://blog.51cto.com/hongchen99/1910100

相关文章
|
2月前
|
网络安全 Python
Python编程--目标IP地址段主机指定端口状态扫描
Python编程--目标IP地址段主机指定端口状态扫描
58 1
|
5月前
|
数据挖掘 Python
🚀告别繁琐!Python I/O管理实战,文件读写效率飙升的秘密
【7月更文挑战第29天】在 Python 编程中,高效的文件 I/O 对性能至关重要。
51 4
|
5月前
|
数据挖掘 数据处理 Python
🔍深入Python系统编程腹地:文件系统操作与I/O管理,打造高效数据处理流水线
【7月更文挑战第29天】深入Python系统编程腹地:文件系统操作与I/O管理,打造高效数据处理流水线
41 3
|
5月前
|
安全 数据安全/隐私保护 Python
|
5月前
|
JSON 监控 开发者
Python I/O管理新篇章:优化你的程序,让数据流动更顺畅
【7月更文挑战第30天】在数据驱动时代, Python I/O操作效率至关重要。理解I/O瓶颈,使用缓冲技术(如调整`open`的`buffering`参数),并发与异步I/O(借助`asyncio`),高效序列化(json, msgpack),及监控调试(cProfile)能显著提升性能。示例展示了缓冲读取和异步文件操作的最佳实践。不断学习可助开发者优化数据流。
70 2
|
5月前
|
API Python
Python高手修炼手册:精通文件系统操作,掌控I/O管理,提升编程效率
【7月更文挑战第30天】在 Python 编程中, 文件系统操作与 I/O 管理是连接程序与数据的关键。初学者常因路径错误和权限问题受挫, 而高手能自如管理文件。传统 `os` 和 `os.path` 模块易出错, `pathlib` 提供了更直观的对象导向 API。I/O 方面, 同步操作会阻塞程序, 异步 (如使用 `aiofiles`) 则能大幅提升并发能力。真正的高手不仅掌握 API, 更能预见性能瓶颈并优化代码, 实现高效与优雅。
45 1
|
6月前
|
监控 算法 Java
Python中管理内存
Python中管理内存
|
6月前
|
监控 算法 Java
使用Python的垃圾回收机制来管理内存
使用Python的垃圾回收机制来管理内存
|
6月前
|
Python
Python中有效地使用global和globals()来管理全局变量
Python中有效地使用global和globals()来管理全局变量