Python 系统管理利器Fabric

简介:

一、简介

Fabric是基于Python 2.5及以上版本实现的SSH命令行工具,简化了SSH了应用程序部署及系统管理任务,它提供了系统基础的操作组件,可以实现本地或远程shell命令,包括命令执行文件上传下载及完整执行日志输出等功能。Fabric在paramiko的基础上做了更高一层的封装,操作起来会更简单.


Fabric官方文档:http://www.fabfile.org/

API文档:http://docs.fabfile.org/en/1.10/

基础案例文档:http://docs.fabfile.org/en/1.10/tutorial.html

Fabric中文文档:http://fabric-docs-cn.readthedocs.org/zh_CN/latest/


二、安装

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
(1) 安装epel源
rpm -ivh http: //dl .fedoraproject.org /pub/epel/6/x86_64/epel-release-6-8 .noarch.rpm
sed  -i  's/^#//'  /etc/yum .repos.d /epel .repo
sed  -i  's/mirrorlist/#mirrorlist/'  /etc/yum .repos.d /epel .repo
 
(2)安装依赖包
yum  install  gcc gcc-c++ python-devel openssl-devel openssl zlin zlib-devel -y
 
(3)安装pip
yum  install  python-pip -y
 
(4)安装fabric
pip  install  fabric
 
(5)测试fabric是否安装正确
python -c  'import fabric'


三、Fabric的应用

注意事项:fab命令引用默认文件名为fabfile.py,如果使用非默认文件名称,则需要通过-f来执行,如

fab -H 192.168.1.100,192.168.1.105 -f host_type.py host_type

如果管理机与目标主机未配置秘钥认证信任,将会提示输入目标主机对应账号登录密码。

fab作为fabric程序的命令行入口,提供了丰富的参数调用


工作中的应用场景:由于目前我们用的都是云平台,比如阿里云、腾讯云、之前还用过一段时间的ucloud等等,用起来效果还是挺好的,有时候为了更方便的管理,对系统进行优化,安装一些agent(zabbix,saltstack,network等),这个时候我们就可以用fabric进行操作,感觉效果挺好的。

由于fabric是单线程工作的,之前我想将其改成多线程,但是没有成功,如果有朋友应该怎么修改,也请麻烦告诉我一声,谢谢啦,多交朋友多脉圈,哈哈


在这里分享一个febric的脚本

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
#!/usr/bin/env python
#encoding: utf-8
 
from fabric.api  import  *  
from fabric.colors  import  *
from fabric.context_managers  import  *  
from fabric.contrib.console  import  confirm  
import  os
   
#定义目标主机信息  
env .user= 'root'  
env .hosts=[ '192.168.0.141' ,]  
env .password= 'redhat'  
 
#定义目录结构
LocalDir =  "/home/saltroot/gameroot"
RemoteDir =  "/home/saltclient/gameroot/"
LocalFile = os.path. join (LocalDir, "script.tar.gz" )
RemoteFile = os.path. join (RemoteDir, "script.tar.gz" )
  
#打包文件  
def tar_task():  
     with lcd(LocalDir):  
         local ( "tar -zcf script.tar.gz script" )  
   
#上传文件  
def put_task():  
     run( "mkdir -p %s"  % RemoteDir)
     with settings(warn_only=True):        #put上传出现异常时继续执行,非终止
         result = put(LocalFile,RemoteFile)  
     if  result.failed and not confirm( "put file failed, Continue[Y/N]?" ):  
         abort( "Aborting file put task!" )    #出现异常时,确认是否继续,(Y继续)
   
#校对文件  
def check_task():  
     with settings(warn_only=True):  
         lmd5= local ( "md5sum %s"  % LocalFile,capture=True). split ( ' ' )[0]  
         rmd5=run( "md5sum %s"  % RemoteFile). split ( ' ' )[0]  
     if  lmd5==rmd5:                #对比本地及远程文件的md5信息
         print yellow( "OK" )
     else :  
         print red( "ERROR" )
 
#初始化
def agent_task():
     with  cd (RemoteDir):
         run( "tar -zxf script.tar.gz" )
         with  cd ( "script/" ):
             run( "./init.sh" )
 
#4个功能一起实现  
@task                          #限定只有go函数对fab可见
def go():  
     print yellow( "program start ..." )
     tar_task()  
     put_task()  
     check_task()  
     agent_task()
     print green( "program sucessful ..." )
 
     
############################################
# 命令执行方式
# fab go
# 额外的命令
# @roles('new') 
# def show():
#    print green('success')
#    print red('fail')
#    print yellow('yellow')
#定义业务角色
#env.user='root'  
#env.roledefs = {
#    'new': ['192.168.0.100',],
#    'ios': ['192.168.0.130','192.168.0.101'],
#    'Andorid': ['192.168.0.200', '192.168.0.201', '192.168.0.230']
#}
#
#env.passwords = {
#    'root@192.168.0.100:22': 'redhat',
#    'root@192.168.0.120:22': 'redhat'
#}
############################################




     本文转自zys467754239 51CTO博客,原文链接:http://blog.51cto.com/467754239/1692077,如需转载请自行联系原作者



相关文章
|
18天前
|
机器学习/深度学习 人工智能 算法
猫狗宠物识别系统Python+TensorFlow+人工智能+深度学习+卷积网络算法
宠物识别系统使用Python和TensorFlow搭建卷积神经网络,基于37种常见猫狗数据集训练高精度模型,并保存为h5格式。通过Django框架搭建Web平台,用户上传宠物图片即可识别其名称,提供便捷的宠物识别服务。
200 55
|
2月前
|
机器学习/深度学习 数据采集 供应链
使用Python实现智能食品安全追溯系统的深度学习模型
使用Python实现智能食品安全追溯系统的深度学习模型
69 4
|
6天前
|
存储 缓存 监控
局域网屏幕监控系统中的Python数据结构与算法实现
局域网屏幕监控系统用于实时捕获和监控局域网内多台设备的屏幕内容。本文介绍了一种基于Python双端队列(Deque)实现的滑动窗口数据缓存机制,以处理连续的屏幕帧数据流。通过固定长度的窗口,高效增删数据,确保低延迟显示和存储。该算法适用于数据压缩、异常检测等场景,保证系统在高负载下稳定运行。 本文转载自:https://www.vipshare.com
99 66
|
28天前
|
机器学习/深度学习 人工智能 算法
【宠物识别系统】Python+卷积神经网络算法+深度学习+人工智能+TensorFlow+图像识别
宠物识别系统,本系统使用Python作为主要开发语言,基于TensorFlow搭建卷积神经网络算法,并收集了37种常见的猫狗宠物种类数据集【'阿比西尼亚猫(Abyssinian)', '孟加拉猫(Bengal)', '暹罗猫(Birman)', '孟买猫(Bombay)', '英国短毛猫(British Shorthair)', '埃及猫(Egyptian Mau)', '缅因猫(Maine Coon)', '波斯猫(Persian)', '布偶猫(Ragdoll)', '俄罗斯蓝猫(Russian Blue)', '暹罗猫(Siamese)', '斯芬克斯猫(Sphynx)', '美国斗牛犬
151 29
【宠物识别系统】Python+卷积神经网络算法+深度学习+人工智能+TensorFlow+图像识别
|
8天前
|
存储 算法 Python
文件管理系统中基于 Python 语言的二叉树查找算法探秘
在数字化时代,文件管理系统至关重要。本文探讨了二叉树查找算法在文件管理中的应用,并通过Python代码展示了其实现过程。二叉树是一种非线性数据结构,每个节点最多有两个子节点。通过文件名的字典序构建和查找二叉树,能高效地管理和检索文件。相较于顺序查找,二叉树查找每次比较可排除一半子树,极大提升了查找效率,尤其适用于海量文件管理。Python代码示例包括定义节点类、插入和查找函数,展示了如何快速定位目标文件。二叉树查找算法为文件管理系统的优化提供了有效途径。
39 5
|
29天前
|
机器学习/深度学习 算法 前端开发
基于Python深度学习的果蔬识别系统实现
果蔬识别系统,主要开发语言为Python,基于TensorFlow搭建ResNet卷积神经网络算法模型,通过对12种常见的果蔬('土豆', '圣女果', '大白菜', '大葱', '梨', '胡萝卜', '芒果', '苹果', '西红柿', '韭菜', '香蕉', '黄瓜')图像数据集进行训练,最后得到一个识别精度较高的模型文件。再基于Django框架搭建Web网页端可视化操作界面,以下为项目实现介绍。
39 4
基于Python深度学习的果蔬识别系统实现
|
3月前
|
机器学习/深度学习 传感器 存储
使用 Python 实现智能地震预警系统
使用 Python 实现智能地震预警系统
145 61
|
2月前
|
弹性计算 数据管理 数据库
从零开始构建员工管理系统:Python与SQLite3的完美结合
本文介绍如何使用Python和Tkinter构建一个图形界面的员工管理系统(EMS)。系统包括数据库设计、核心功能实现和图形用户界面创建。主要功能有查询、添加、删除员工信息及统计员工数量。通过本文,你将学会如何结合SQLite数据库进行数据管理,并使用Tkinter创建友好的用户界面。
71 2
从零开始构建员工管理系统:Python与SQLite3的完美结合
|
2月前
|
Python
Python之音乐专辑管理系统
音乐专辑管理系统是一款用于管理和维护音乐专辑信息的应用程序,支持添加、删除、修改和查询专辑详情(如专辑名、艺术家、发行日期及曲目列表)。系统运行需Python 3.x环境,硬件要求较低,适合个人及小型团队使用。
62 4
|
2月前
|
Python
Python实现摇号系统
本文介绍了如何使用Python构建一个简单的摇号系统,包括用户输入、随机抽取、结果展示和日志记录等功能。通过导入`random`、`datetime`和`logging`模块,实现了从参与者名单中随机抽取中奖者,并记录每次摇号的结果,方便后续查看和审计。完整代码示例提供了从功能实现到主程序调用的全过程。
38 2