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月前
|
Unix Shell Linux
赞!优雅的Python多环境管理神器!易上手易操作!
赞!优雅的Python多环境管理神器!易上手易操作!
|
2月前
|
存储 Java C语言
【python】——使用嵌套列表实现游戏角色管理
【python】——使用嵌套列表实现游戏角色管理
35 0
|
4月前
|
API 数据库 Python
Python 教程之 Django(8)在 Django 管理界面中渲染模型
Python 教程之 Django(8)在 Django 管理界面中渲染模型
24 0
Python 教程之 Django(8)在 Django 管理界面中渲染模型
|
7天前
|
监控 Python
Python监控主机是否存活,并发报警邮件
Python监控主机是否存活,并发报警邮件
|
12天前
|
SQL 安全 Go
如何在 Python 中进行 Web 应用程序的安全性管理,例如防止 SQL 注入?
在Python Web开发中,确保应用安全至关重要,主要防范SQL注入、XSS和CSRF攻击。措施包括:使用参数化查询或ORM防止SQL注入;过滤与转义用户输入抵御XSS;添加CSRF令牌抵挡CSRF;启用HTTPS保障数据传输安全;实现强身份验证和授权系统;智能处理错误信息;定期更新及审计以修复漏洞;严格输入验证;并培训开发者提升安全意识。持续关注和改进是保证安全的关键。
20 0
|
2月前
|
SQL 安全 测试技术
如何在 Python 中进行 Web 应用程序的安全性管理,例如防止 SQL 注入?
如何在 Python 中进行 Web 应用程序的安全性管理,例如防止 SQL 注入?
15 0
|
2月前
|
存储 算法 Java
如何使用 Python 管理内存和避免内存泄漏?
如何使用 Python 管理内存和避免内存泄漏?
102 35
|
2月前
|
Python
如何在Python中创建和管理线程?
如何在Python中创建和管理线程?
22 6
|
3月前
|
监控 安全 网络安全
局域网管理监控的远程访问控制:利用SSH和Python实现安全管理
在当今数字化时代,局域网管理监控对于确保网络安全至关重要。远程访问控制是一项关键任务,通过利用SSH(Secure Shell)和Python编程语言,我们可以实现更加安全的管理方法。本文将介绍如何使用这两者结合,为局域网管理提供可靠的远程访问控制。
193 1
|
4月前
|
人工智能 数据挖掘 Python
Python模块与包的管理与使用
Python作为一种广泛应用的编程语言,模块与包的管理与使用是其核心特性之一。本文将介绍Python中模块与包的概念,以及如何进行有效的管理和利用,帮助读者更好地理解和运用Python编程。