# 类 Fabric 主机管理程序开发:
# 1. 运行程序列出主机组或者主机列表
# 2. 选择指定主机或主机组
# 3. 选择让主机或者主机组执行命令或者向其传输文件(上传/下载)
# 4. 充分使用多线程或多进程
# 5. 不同主机的用户名密码、端口可以不同
import paramiko,threading,pickle,os Base_path = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
config_path = Base_path +'/core/config'
#主机配置信息管理
list_host = [{'host':'192.168.117.236','port':22,'user':'ubuntu1','password':'ubuntu1','group':1},
{'host':'192.168.117.237','port':22,'user':'ubuntu2','password':'ubuntu2','group':1},
{'host':'192.168.117.239','port':22,'user':'ubuntu3','password':'ubuntu3','group':2},
{'host':'192.168.117.240','port':22,'user':'aaa','password':'bbb','group':2}]
def pickle_dump(path,file):
#存入配置文件
with open(path,'wb') as f:
pickle.dump(file,f)
#pickle_dump(config_path,list_host)
def pickle_load(path):
#取出配置文件
with open(path,'rb') as f:
list_host_new = pickle.load(f)
return list_host_new
# list_host_new = pickle_load(config_path)
# print(list_host_new) class Paramiko_sshd(object):
#sshd类
def __init__(self,host,port,user,password):
self.host = host
self.port = port
self.user = user
self.password = password def sshd_command(self,command):
#ssh远程主机执行命令,并返回结果
try:
ssh_client = paramiko.SSHClient()
ssh_client.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh_client.connect(self.host,self.port,self.user,self.password)
std_in,std_out,std_err = ssh_client.exec_command(command)
print(self.host.center(30,'*'))
print(command.upper().center(30,'='))
for line in std_out:
print(line.strip('\n'))
ssh_client.close()
except Exception as e:
print(e)
def sshd_upload_file(self,server_path,local_path):
#上传文件
try:
t = paramiko.Transport((self.host,self.port))
t.connect(username=self.user,password=self.password)
sftp = paramiko.SFTPClient.from_transport(t)
sftp.put(local_path,server_path)
t.close()
print(self.host.center(30, '*'))
print('上传成功')
except Exception as e:
print(e)
def sshd_down_file(self,server_path,local_path):
#下载文件
try:
t = paramiko.Transport((self.host, self.port))
t.connect(username=self.user, password=self.password)
sftp = paramiko.SFTPClient.from_transport(t)
sftp.get(server_path, local_path)
t.close()
print(self.host.center(30, '*'))
print('下载成功')
except Exception as e:
print(e)
def help():
#帮助信息
command_option = input('''
*************请选择***********
1.执行命令
2.上传文件
3.下载文件
4.返回
5.退出程序
''').strip()
return command_option def review():
while 1:
#展示界面
list_host_new = pickle_load(config_path)
host_group_1 = []
host_group_2 = []
for line in list_host_new:
if line['group'] == 1:
host_group_1.append(line)
else:
host_group_2.append(line)
print('group-1'.center(30,'='))
for line_1 in host_group_1:
print('host:',line_1['host'],'port:',line_1['port'])
print('group-2'.center(30,'='))
for line_2 in host_group_2:
print('host:',line_2['host'],'port:',line_2['port']) group_select = input('请输入您要操作的主机组:\033[1;35m group-1 \033[0m | \033[1;35m group-2 \033[0m '
'或输入\033[1;35mexit\033[0m退出程序 ==>').strip()
if group_select in ['group-1','group-2']:
if group_select == 'group-1': #增加中间变量,来确定是对组一操作还是对组二进行操作
group_sure = host_group_1
else:
group_sure = host_group_2
while 1:
command_option = help()
if command_option == '':
command = input('请输入执行的命令:').strip()
for line_3 in group_sure:
sshd = Paramiko_sshd(line_3['host'],line_3['port'],line_3['user'],line_3['password'])
t = threading.Thread(target=sshd.sshd_command,args=(command,))
t.start()
t.join() elif command_option == '':
server_path = input('请输入上传到的服务器目录:').strip()
local_path = input('请输入本地文件目录:').strip()
for line_3 in group_sure:
sshd = Paramiko_sshd(line_3['host'],line_3['port'],line_3['user'],line_3['password'])
t = threading.Thread(target=sshd.sshd_upload_file,args=(server_path,local_path,))
t.start()
t.join() elif command_option == '':
server_path = input('请输入下载的服务器目录文件路径:').strip()
local_path = input('请输入存放到本地的路径:').strip()
for line_3 in group_sure:
sshd = Paramiko_sshd(line_3['host'],line_3['port'],line_3['user'],line_3['password'])
t = threading.Thread(target=sshd.sshd_down_file,args=(server_path,local_path,))
t.start()
t.join()
elif command_option == '':
break
elif command_option == '':
exit()
else:
print('%s为非法命令,请重新输入!'%command_option)
elif group_select == 'exit':
break
else:
print('%s为非法命令,请重新输入!'%group_select) if __name__ =='__main__':
review()

python 学习分享-实战篇类 Fabric 主机管理程序开发的更多相关文章

  1. python作业类Fabric主机管理程序开发(第九周)

    作业需求: 1. 运行程序列出主机组或者主机列表 2. 选择指定主机或主机组 3. 选择让主机或者主机组执行命令或者向其传输文件(上传/下载) 4. 充分使用多线程或多进程 5. 不同主机的用户名密码 ...

  2. python10作业思路及源码:类Fabric主机管理程序开发(仅供参考)

    类Fabric主机管理程序开发 一,作业要求 1, 运行程序列出主机组或者主机列表(已完成) 2,选择指定主机或主机组(已完成) 3,选择主机或主机组传送文件(上传/下载)(已完成) 4,充分使用多线 ...

  3. 类 Fabric 主机管理程序开发

    类 Fabric 主机管理程序开发:1. 运行程序列出主机组或者主机列表2. 选择指定主机或主机组3. 选择让主机或者主机组执行命令或者向其传输文件(上传/下载4. 充分使用多线程或多进程5. 不同主 ...

  4. python 学习分享-实战篇选课系统

    # 角色:学校.学员.课程.讲师 # 要求: # 1. 创建北京.上海 2 所学校 # 2. 创建linux , python , go 3个课程 , linux\py 在北京开, go 在上海开 # ...

  5. python 学习分享-实战篇高级的ftp

    #server代码 import socketserver,os,hashlib Base_paht = os.path.dirname(os.path.dirname(os.path.abspath ...

  6. python 学习分享-实战篇简单的ftp

    import socket import os import time import pickle Basedb = os.path.dirname(os.path.dirname(os.path.a ...

  7. python 学习分享-实战篇增删改查作业

    一大波函数来袭 作业要求: 1本次作业通过空格及逗号,将文件拆分成列表,在通过判断add.del.update.select等关键字,来判断用户执行的是哪种命令,根据不同的命令调用不同的函数去处理. ...

  8. python第五十二天---第九周作业 类 Fabric 主机管理程序

    类 Fabric 主机管理程序开发:1. 运行程序列出主机组或者主机列表2. 选择指定主机或主机组3. 选择让主机或者主机组执行命令或者向其传输文件(上传/下载)4. 充分使用多线程或多进程5. 不同 ...

  9. python 学习分享-函数篇

    函数是组织好的,可重复使用的,用来实现单一,或相关联功能的代码段. 函数能提高应用的模块性,和代码的重复利用率.你已经知道Python提供了许多内建函数,比如print().但你也可以自己创建函数,这 ...

随机推荐

  1. 矩阵连乘的相乘次数(ZOJ1094)

    题目链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=94 解题报告: 1.数据结构: ///矩阵行数和列数 struct N ...

  2. jQuery 效率提升建议

    jQuery简洁通用的方法集把编码者从繁重的工作中解脱出来,也拉低了进入javascript的门槛,初学者对浏览器兼容性一无所知的情况下,几行代码就可以写出超炫的特效.网上有一篇文章转载比较泛滥,已经 ...

  3. 2017.9.14 HTML学习总结---超链接标签图片标签

    2.4 超链接标签 定义:它是指从一个对象指向另一个对象的指针,它可以是网页中的一段文字  也可以是一张图片,以实现从一个页面到另一个页面的跳转. 格式:<a href="url&qu ...

  4. 修改SecureCRT默认会话字符集

    修改SecureCRT默认会话字符集 1.找到SecureCRT配置文件 Default.ini 2.修改Default修改为UTF-8 将S:"Output Transformer Nam ...

  5. java多线程同步以及线程间通信详解&消费者生产者模式&死锁&Thread.join()(多线程编程之二)

    本篇我们将讨论以下知识点: 1.线程同步问题的产生 什么是线程同步问题,我们先来看一段卖票系统的代码,然后再分析这个问题: package com.zejian.test; /** * @author ...

  6. 使用session处理用户搜索后数据的上一页和下一页跳转

    搜索语句界面: /*单一检索:此处为一个下拉列表的检索*/ if(isset($_POST['submit']) && $_POST['submit'] == '点击搜索') { if ...

  7. Java的“Goto”与标签

    goto在Java中是一个保留字,但在语言中并没有用到它:Java没有goto.但是,Java也能完成一些类似于跳转的操作,主要是依靠:标签. 为什么要使用标签 在迭代语句中,我们可以使用break和 ...

  8. Spring MVC 接收前端参数的方式

    方式一: 普通方式接收 1 @RequestMapping("/index") 2 public String getUserName(String username) { 3 S ...

  9. Rsync备份服务部署

    1 Rsync服务器架构规划 在搭建服务之前需要做以下规划设计,其中包括:主机规划表.主机IP地址规划表.主机架构图.主机hosts解析以及linux主机基础优化等 1.1 主机规划表 服务器说明 数 ...

  10. Python基本数据类型及使用

    # 基本数据类型分类 - int 整数 - float 小数 - bool 布尔值 - str 字符串 ## int 整数 - 包括正整数和负整数 - 与java.c等语言相比并没有位数限制,理论上可 ...