python实现主机批量管理

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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还可以实现文件批量下载和批量上传,原理和批量执行命令基本一样。

本文出自 “自动化运维” 博客,请务必保留此出处http://hongchen99.blog.51cto.com/12534281/1910100

以上是关于python实现主机批量管理的主要内容,如果未能解决你的问题,请参考以下文章

Python开发程序:简单主机批量管理工具

第十八章 Python批量管理主机(paramikofabric与pexpect)

python 使用paramiko, pymysql实现批量管理服务器

Python简单主机批量管理工具

[ Python - 13 ] 批量管理主机必备模块

python运维之使用python进行批量管理主机