python 学习分享-实战篇类 Fabric 主机管理程序开发
# 类 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 主机管理程序开发的更多相关文章
- python作业类Fabric主机管理程序开发(第九周)
作业需求: 1. 运行程序列出主机组或者主机列表 2. 选择指定主机或主机组 3. 选择让主机或者主机组执行命令或者向其传输文件(上传/下载) 4. 充分使用多线程或多进程 5. 不同主机的用户名密码 ...
- python10作业思路及源码:类Fabric主机管理程序开发(仅供参考)
类Fabric主机管理程序开发 一,作业要求 1, 运行程序列出主机组或者主机列表(已完成) 2,选择指定主机或主机组(已完成) 3,选择主机或主机组传送文件(上传/下载)(已完成) 4,充分使用多线 ...
- 类 Fabric 主机管理程序开发
类 Fabric 主机管理程序开发:1. 运行程序列出主机组或者主机列表2. 选择指定主机或主机组3. 选择让主机或者主机组执行命令或者向其传输文件(上传/下载4. 充分使用多线程或多进程5. 不同主 ...
- python 学习分享-实战篇选课系统
# 角色:学校.学员.课程.讲师 # 要求: # 1. 创建北京.上海 2 所学校 # 2. 创建linux , python , go 3个课程 , linux\py 在北京开, go 在上海开 # ...
- python 学习分享-实战篇高级的ftp
#server代码 import socketserver,os,hashlib Base_paht = os.path.dirname(os.path.dirname(os.path.abspath ...
- python 学习分享-实战篇简单的ftp
import socket import os import time import pickle Basedb = os.path.dirname(os.path.dirname(os.path.a ...
- python 学习分享-实战篇增删改查作业
一大波函数来袭 作业要求: 1本次作业通过空格及逗号,将文件拆分成列表,在通过判断add.del.update.select等关键字,来判断用户执行的是哪种命令,根据不同的命令调用不同的函数去处理. ...
- python第五十二天---第九周作业 类 Fabric 主机管理程序
类 Fabric 主机管理程序开发:1. 运行程序列出主机组或者主机列表2. 选择指定主机或主机组3. 选择让主机或者主机组执行命令或者向其传输文件(上传/下载)4. 充分使用多线程或多进程5. 不同 ...
- python 学习分享-函数篇
函数是组织好的,可重复使用的,用来实现单一,或相关联功能的代码段. 函数能提高应用的模块性,和代码的重复利用率.你已经知道Python提供了许多内建函数,比如print().但你也可以自己创建函数,这 ...
随机推荐
- bzoj2568 比特集合
Description 比特集合是一种抽象数据类型(Abstract Data Type) ,其包含一个集合S,并支持如下几种操作: INS M : 将元素 M 插入到集合S中: DEL M : 将集 ...
- unixbench安装及使用
unixbench 是一个用于測试 unix 系统性能的工具.也是一个比較通用的 benchmark, 此測试的目的是对类Unix 系统提供一个主要的性能指示,非常多測试用于系统性能的不同方面,这些測 ...
- 2017.11.4 JavaWeb-----基于JavaBean+JSP求任意两数代数和(改进的在JSP页面中无JSP脚本代码的)+网页计数器JavaBean的设计与使用
修改后的JSP中不含有JSP脚本代码这使得JSP程序的清晰性.简单 1.设计JavaBean 的Add.java 类 package beans; public class Add { private ...
- C# 变量与常量
变量表示存储位置,变量必须有确定的数据类型.C#的类型安全的含义之一就是确保变量的存储位置容纳着合适的类型.可以将C#中的变量分为静态变量,实例变量,传值参数,引用参数,输出参数,数组参数和本地变量共 ...
- Java - 静态内部类
Java语言允许在类中再定义类,这种在其它类内部定义的类就叫内部类.内部类又分为:常规内部类.局部内部类.匿名内部类和静态嵌套类四种. 1.静态内部类定义 静态内部类,定义在类中,任何方法外,用sta ...
- 利用sysbench进行MySQL OLTP基准测试
Preface In order to know clearly about the real performance threshold of database server,we ...
- 执行pip命令时遇到 Fatal error in launcher: Unable to create process using '"'
电脑同时安装了python-2.7.13跟python-3.6.1,安装时勾选了pip,环境变量也已经配置好. 为了方便运行,同时修改了可执行文件为 python2和python3.此时在cmd命令行 ...
- 在React Native中集成热更新
最近,在项目DYTT集成了热更新,简单来说,就是不用重新下载安装包即可达到更新应用的目的,也不算教程吧,这里记录一下. 1.热更新方案 目前网上大概有两个比较广泛的方式,分别是 react-nativ ...
- Centos6.8安装python3.6
1.目的简介: centos默认使用的是python 2.6.6,而python的2.x 和 3.x 是两个不兼容的版本,到目前的python发展,都已经过渡到了python 3.x,所以需要手动将p ...
- 【转载】C#批量插入数据到Sqlserver中的三种方式
引用:https://m.jb51.net/show/99543 这篇文章主要为大家详细介绍了C#批量插入数据到Sqlserver中的三种方式,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 本篇, ...