python写的批量操作远程主机脚本(命令执行,上传、下载文件)

最近在学习python,借助fabric模块写了个批量操作服务器的脚本,在此分享给大家,如有不足之处,欢迎大家指正

准备工作:

安装python 2.6.5:

yum -y install readline*

tar xf Python-2.6.5.tar.bz2

cd Python-2.6.5

将目录下Modules/Setup.dist文件中"readline readline.c -lreadline -ltermcap"行前的注释去掉

编译安装:

./configure --enable-shared

make -j8 && make install

安装setuptools

tar xf setuptools-0.6c11.tar.gz

cd setuptools-0.6c11

python setup.py install

安装fabric

执行安装时,软件会自动从网上查找依赖的安装包并进行安装

tar xf fabric-0.9rc2.tar.gz

cd goosemo-fabric-1eacbf2

python setup.py install

############################################################################

pyssh脚本:

#!/usr/bin/env python
# -*- coding: utf-8 -*-

#####################################################
# Author: mayulin – [email protected]
# Last modified: 2011-04-28 12:27
# Filename: pssh.py
#####################################################

from fabric.api import env,run,put,get
from os import path
from re import findall
from sys import argv
from fabric.context_managers import hide
from time import sleep

USER=‘root‘
HOST,IP_LIST=[],[]
PORT=‘22‘
PRI_KEY,PASSWORD,CMD,uSRC,uDST,dSRC,dDST=‘‘,‘‘,‘‘,‘‘,‘‘,‘‘,‘‘
timeout=1

for i in range(1,len(argv)+1):
    if argv[i-1] == ‘-h‘ or len(argv)==1:
            print """
            USAGE:
       -u [user]       Use this argument to specify the user,default is ‘root‘
       -H [host]       The host that you want to connect
       -f [file]       The file content multiple ip address you want to connect
       -P [port]       The ssh port,default is 22
       -p [pwd|file]   You can specify password or a priviate key file to connect the host
       -c [command]    The command you want the host(s) to run
       -U [src,dst]    The local file that you want to upload to the remote host(s)
       -D [src,dst]    The remote file that you want to download to the local host
       -t [timeout]    The program running timeout,default is 1(s)
       -h              Print this help screen
            """

if argv[i-1] == ‘-u‘:
            USER=argv[i]
            env.user=‘%s‘%(USER)
    else:
            env.user=‘%s‘%(USER)
    if argv[i-1] == ‘-H‘:
        arg=findall(‘(\d+\.\d+\.\d+\.\d+|\s+\.{3,4})‘,argv[i])
        for j in arg:
            if type(j).__name__ !=‘NoneType‘:
                HOST.append(j)
            else:
                print ‘The HostIP input error‘
    if argv[i-1] == ‘-P‘:
        PORT=argv[i]
    if argv[i-1] == ‘-f‘:
        if path.isfile(‘%s‘%(argv[i])) == True:
            IP_LIST=open(‘%s‘%(argv[i]),‘r‘).readlines()
    if argv[i-1] == ‘-p‘:
        if path.isfile(argv[i]) == True:
            PRI_KEY=argv[i]
            env.key_filename=‘%s‘%(PRI_KEY)
        else:
            PASSWORD=argv[i]
            env.password=‘%s‘%(PASSWORD)
    if argv[i-1] == ‘-c‘:
        CMD=argv[i]
    if argv[i-1]==‘-t‘:                                                                                       
        timeout=argv[i]

SLP=‘sleep %s‘%(timeout)

if argv[i-1] == ‘-U‘:
        x=src=argv[i].split(‘,‘)
        uSRC=x[0]
        uDST=x[1]

if argv[i-1] == ‘-D‘:
        y=src=argv[i].split(‘,‘)
        dSRC=y[0]
        dDST=y[1]

else:
    IP_PORT=[]
    if len(IP_LIST)!=0:
        for k in IP_LIST:
            IP_PORT.append(k.strip()+‘:‘+PORT)
    if len(HOST)!=0:
        for k in HOST:
            IP_PORT.append(k.strip()+‘:‘+PORT)
if CMD != ‘‘:
    def command():
            with hide(‘running‘):
                run("%s;%s" %(CMD,SLP))
    for ip in IP_PORT:
        env.host_string=ip

print "Execute command : \"%s\" at Host : %s" %(CMD,ip.split(‘:‘)[0])
        print "-------------------------------------------------"
        command()
        print "-------------------------------------------------"
    
if uSRC and uDST !=‘‘:
    def upload():
        with hide(‘running‘):
            put("%s" %(uSRC),"%s" %(uDST))
    for ip in IP_PORT:
            env.host_string=ip
            print "Upload local file : \"%s\" to Host : %s \"%s\"" %(uSRC,ip.split(‘:‘)[0],uDST)
            print "-------------------------------------------------"
            upload()
            print "-------------------------------------------------"
            
if dSRC and dDST !=‘‘:
    def download():
        with hide(‘running‘):
            get("%s" %(dSRC),"%s" %(dDST))
    for ip in IP_PORT:
        env.host_string=ip
            print "Download remote file : \"%s\" from Host : %s to local \"%s\"" %(dSRC,ip.split(‘:‘)[0],dDST)
            print "-------------------------------------------------"
            download()
            print "-------------------------------------------------"
 

###########################################################################################

脚本执行效果:

显示帮助:

在多个远程主机上执行shell命令:

将远程主机上的文件下载到本地目录:

将本地文件上传到多个远程主机上

原文地址:https://www.cnblogs.com/xwcbx/p/12549291.html

时间: 2024-08-11 07:49:57

python写的批量操作远程主机脚本(命令执行,上传、下载文件)的相关文章

python3 实现堡垒机功能(并发执行命令及上传下载文件)

转载请注明出处,欢迎提出宝贵意见,谢谢! 功能介绍: 1.主机分组 登录后显示分组主机及主机数量 选择主机组后显示该主机组下所有主机信息,主机名及IP显示输入选择:1.执行命令利用线程并发组内所有主机同时执行命令,并将结果,返回格式为:----------------------host1------------------ ----------------------host2------------------ ----------------------host3-------------

python 实现ssh远程执行命令 上传下载文件

使用密码远程执行命令 [[email protected] script]# cat daramiko_ssh.py  #!/usr/bin/env python #_*_coding:utf-8 _*_ __author__ = 'gaogd' import paramiko import sys,os host = sys.argv[1] user = 'root' password = 'ddfasdsasda2015' cmd = sys.argv[2] s = paramiko.SSH

2.1.5基础之命令行链接ftp dos中的ftp上传下载文件

Windows命令行batcmd脚本的应用之自动备份 异地备份2.1.5基础之命令行链接ftp dos中的ftp上传下载文件 讲解环境 VMware Workstation 12 桌面虚拟计算机软件创建虚拟机安装操作系统:http://edu.51cto.com/course/10007.html PC1:192.168.1.201 远程地址:192.168.100.100:2001 windows service2008 pc1 Admin111FTP虚拟用户 fileaa fileaaPC2

Linux上传下载文件快捷命令

远程链接Linux(如SecrueCRT),要上传文件很下载文件到Linux服务器,只需要使用sz或者rz命令即可快速下载和上传文件了. 使用方法: 1.首先确保Linux服务器系统中安装了lrzsz安装包,如果没有这需要安装,推荐安装方式:yum install lrzsz  . 注: (如果已经安装了则可忽略此步骤) 2.sz用法: 下载一个文件:sz filename 下载多个文件:sz filename1 filename2 下载dir目录下的所有文件,不包含dir下的文件夹:sz di

在linux命令行利用SecureCRT上传下载文件

一般来说,linux服务器大多是通过ssh客户端来进行远程的登陆和管理的,使用ssh登陆linux主机以后,如何能够快速的和本地机器进行文件的交互呢,也就是上传和下载文件到服务器和本地?与ssh有关的两个命令可以提供很方便的操作:    sz:将选定的文件发送(send)到本地机器    rz:运行该命令会弹出一个文件选择窗口,从本地选择文件上传到服务器(receive) rz,sz是便是Linux/Unix同Windows进行ZModem文件传输的命令行工具 windows端需要支持ZMode

老男孩教育每日一题-第95天-shell脚本知识点:书写脚本完成ftp上传下载

题目 日常工作中经常用到FTP,进行文件的共享与下载,单对于有些不熟悉FTP命令行人员使用FTP进行共享文件管理,是一件很头疼的事.而且FTP如果有些文件需要每天定时进行上传或下载,人为重复相同工作也是没有意义的因此如何编写自动下载或上传FTP文件脚本? 答案参考: 1. ftpput.sh 上传文件到ftp脚本 #!/bin/sh         #FileName:ftpput.sh     #Function:从本地客户端向ftp服务器上传一个文件       #Version:V0.1 

使用scp命令,远程上传下载文件/文件夹

1.从服务器下载文件 scp [email protected]:/path/filename /local/path例如: scp [email protected]:/ygf/data/data.txt /desktop/ygf   把117.50.20.56上的/ygf/data/data.txt 的文件下载到/desktop/ygf目录中 2.上传本地文件到服务器 scp /local/path/local_filename [email protected]:/path例如: scp

python实现ftp上传下载文件

#!/usr/bin/env python # encoding: utf-8 __author__ = "pwy" ''' 上传:上传文件并备份到其他目录 下载:下载文件,并删除远端文件 ''' from ftplib import FTP from time import sleep import os,datetime,logging from shutil import move HOST = "192.168.1.221" USER = "sxi

Hadoop Shell命令(基于linux操作系统上传下载文件到hdfs文件系统基本命令学习)

Apache-->hadoop的官网文档命令学习:http://hadoop.apache.org/docs/r1.0.4/cn/hdfs_shell.html FS Shell 调用文件系统(FS)Shell命令应使用 bin/hadoop fs <args>的形式. 所有的的FS shell命令使用URI路径作为参数.URI格式是scheme://authority/path.对HDFS文件系统,scheme是hdfs,对本地文件系统,scheme是file.其中scheme和aut