Python fabric实践操作
前面学习了理论,下面该练练手了。两台机器:10.1.6.186、10.1.6.159。fabric部署在10.1.6.186上面。
1 执行一个简单的task任务,显示两台机器的/home/guol/目录下的文件
|
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
|
#!/usr/bin/pythonfrom fabric.api import *from fabric.context_managers import *env.hosts=['10.1.6.186','10.1.6.159']env.password='xxxxxx'def task1(): with cd('/home/guol'): run('ls -l')##结果root@vm11:/tmp# fab task1[10.1.6.186] Executing task 'task1'[10.1.6.186] run: ls -l[10.1.6.186] out: total 0[10.1.6.186] out: -rw-r--r-- 1 root root 0 Dec 21 13:32 186-local[10.1.6.186] out: [10.1.6.159] Executing task 'task1'[10.1.6.159] run: ls -l[10.1.6.159] out: total 0[10.1.6.159] out: -rw-r--r-- 1 root root 0 Dec 21 13:32 159-remote[10.1.6.159] out: Done.Disconnecting from 10.1.6.159... done.Disconnecting from 10.1.6.186... done. |
2 执行和1相同的任务,不过排除掉10.1.6.159这台机器
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
#!/usr/bin/pythonfrom fabric.api import *from fabric.context_managers import *env.hosts=['10.1.6.186','10.1.6.159']env.password='xxxxxx'env.exclude_hosts=['10.1.6.159']def task1(): with cd('/home/guol'): run('ls -l')##执行root@vm11:/tmp# fab task1[10.1.6.186] Executing task 'task1'[10.1.6.186] run: ls -l[10.1.6.186] out: total 0[10.1.6.186] out: -rw-r--r-- 1 root root 0 Dec 21 13:32 186-local[10.1.6.186] out: Done.Disconnecting from 10.1.6.186... done. |
3 执行和2相同任务,再增加一个task2,并且把taskN伪装成meta任务执行
|
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
|
#!/usr/bin/pythonfrom fabric.api import *from fabric.colors import *from fabric.context_managers import *env.hosts=['10.1.6.186','10.1.6.159']env.password='xxxxxx'env.exclude_hosts=['10.1.6.159']def task1(): with cd('/home/guol'): run('ls -l')def task2(): print(green("I'm fabric"))def deploy(): execute(task1) execute(task2)##执行root@vm11:/tmp# fab deploy[10.1.6.186] Executing task 'deploy'[10.1.6.186] Executing task 'task1'[10.1.6.186] run: ls -l[10.1.6.186] out: total 0[10.1.6.186] out: -rw-r--r-- 1 root root 0 Dec 21 13:32 186-local[10.1.6.186] out: [10.1.6.186] Executing task 'task2'I'm fabricDone.Disconnecting from 10.1.6.186... done. |
4 不同的机器执行不同的task
|
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
|
#!/usr/bin/pythonfrom fabric.api import *from fabric.colors import *from fabric.context_managers import *env.roledefs={'web1':['10.1.6.186'],'web2':['10.1.6.159']}env.password='xxxxxx'@roles('web1')def task1(): with cd('/home/guol'): run('ls -l')@roles('web2')def task2(): print(green("I'm fabric"))def deploy(): execute(task1) execute(task2)##执行root@vm11:/tmp# fab deploy[10.1.6.186] Executing task 'task1'[10.1.6.186] run: ls -l[10.1.6.186] out: total 0[10.1.6.186] out: -rw-r--r-- 1 root root 0 Dec 21 13:32 186-local[10.1.6.186] out: [10.1.6.159] Executing task 'task2'I'm fabricDone.Disconnecting from 10.1.6.186... done. |
5 把159的/home/guol/159-remote拉取到186的 /home/guol/目录下
|
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
|
#!/usr/bin/pythonfrom fabric.api import *from fabric.colors import *from fabric.context_managers import *env.hosts=['10.1.6.159']env.password='xxxxxx'def task1(): print(green("I'm 186 /home/guol/")) local('ls -l /home/guol')def task2(): print(green("I'm get 159's 159-remote file to 186")) get('/home/guol/159-remote','/home/guol') print(yellow("I'm 186 /home/guol/")) local('ls -l /home/guol')def deploy(): execute(task1) execute(task2)##执行root@vm11:/tmp# fab deploy[10.1.6.159] Executing task 'deploy'[10.1.6.159] Executing task 'task1'I'm 186 /home/guol/[localhost] local: ls -l /home/guoltotal 0-rw-r--r-- 1 root root 0 Dec 21 13:32 186-local[10.1.6.159] Executing task 'task2'I'm get 159's 159-remote file to 186[10.1.6.159] download: /home/guol/159-remote <- /home/guol/159-remoteI'm 186 /home/guol/[localhost] local: ls -l /home/guoltotal 0-rw-r--r-- 1 root root 0 Dec 21 14:28 159-remote-rw-r--r-- 1 root root 0 Dec 21 13:32 186-localDone.Disconnecting from 10.1.6.159... done. |
6 把186的/home/guol/ 186-local推送到159的 /home/guol/目录下
|
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
|
#!/usr/bin/pythonfrom fabric.api import *from fabric.colors import *from fabric.context_managers import *env.hosts=['10.1.6.159']env.password='xxxxxx'def task1(): print(green("I'm 159 /home/guol/")) with cd('/home/guol'): run('ls -l')def task2(): print(green("I'm put 186's 186-local file to 159")) put('/home/guol/186-local','/home/guol') print(yellow("I'm 159 /home/guol/")) with cd('/home/guol'): run('ls -l')def deploy(): execute(task1) execute(task2)##执行root@vm11:/tmp# fab deploy[10.1.6.159] Executing task 'deploy'[10.1.6.159] Executing task 'task1'I'm 159 /home/guol/[10.1.6.159] run: ls -l[10.1.6.159] out: total 0[10.1.6.159] out: -rw-r--r-- 1 root root 0 Dec 21 13:32 159-remote[10.1.6.159] out: [10.1.6.159] Executing task 'task2'I'm put 186's 186-local file to 159[10.1.6.159] put: /home/guol/186-local -> /home/guol/186-localI'm 159 /home/guol/[10.1.6.159] run: ls -l[10.1.6.159] out: total 0[10.1.6.159] out: -rw-r--r-- 1 root root 0 Dec 21 13:32 159-remote[10.1.6.159] out: -rw-r--r-- 1 root root 0 Dec 21 14:33 186-local[10.1.6.159] out: Done.Disconnecting from 10.1.6.159... done. |
7 在186上打开一个159的交互式的shell
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
#!/usr/bin/pythonfrom fabric.api import *from fabric.colors import *from fabric.context_managers import *env.hosts=['10.1.6.159']env.password='xxxxxx'def task3(): open_shell("ifconfig eth0|grep '10.1.6.159'")def deploy(): execute(task3)##执行root@vm11:/tmp# fab deploy[10.1.6.159] Executing task 'deploy'[10.1.6.159] Executing task 'task3'Welcome to Ubuntu 12.10 (GNU/Linux 3.5.0-17-generic x86_64)Last login: Fri Dec 21 14:39:39 2012 from 10.1.6.186ifconfig eth0|grep '10.1.6.159'root@vm12:~# ifconfig eth0|grep '10.1.6.159' inet addr:10.1.6.159 Bcast:10.1.6.255 Mask:255.255.255.0 |
Python fabric实践操作的更多相关文章
- python fabric远程操作和部署
博客迁往:新地址(点击直达) 新博客使用markdown维护,线下有版本号库,自己写的所以会定时更新同步.同一时候提供更好的导航和阅读体验 csdn对markdown支持不好.所以旧版不会花时间进行同 ...
- python新手 实践操作 作业
#有如下值集合 [11,22,33,44,55,66,77,88,99],将所有大于 66 的值保存至字典的第一个key中,将小于 66 的值保存至第二个key的值中.即: {'k1': 大于66的所 ...
- Python Fabric远程自动部署简介
Fabric是一个Python(2.5-2.7)库,用于简化使用SSH的应用程序部署或系统管理任务. 它提供的操作包括:执行本地或远程shell命令,上传/下载文件,以及其他辅助功能,如提示用户输入. ...
- Python入门经典. 以解决计算问题为导向的Python编程实践
Python入门经典. 以解决计算问题为导向的Python编程实践(高清版)PDF 百度网盘 链接:https://pan.baidu.com/s/1juLsew8UiOErRheQPOuTaw 提取 ...
- Python 最佳实践指南 2018 学习笔记
基础信息 版本 Python 2.7 Python 3.x Python2.7 版本在 2020 年后不再提供支持,建议新手使用 3.x 版本进行学习 实现 CPython:Python的标准实现: ...
- 使用python fabric搭建RHEL 7.2大数据基础环境以及部分优化
1.使用python fabric进行Linux基础配置 使用python,可以让任何事情高效起来,包括运维工作,fabric正式这样一套基于python2的类库,它执行本地或远程shell命令提供了 ...
- <读书笔记>001-以解决问题为导向的python编程实践
以解决问题为导向的python编程实践 0.第0章:计算机科学 思考:计算机科学是否为计算机编程的简称? 编程的困难点:1.同时做2件事(编程语言的语法.语义+利用其解决问题) 2.什么是好程序(解 ...
- Python Fabric模块详解
Python Fabric模块详解 什么是Fabric? 简单介绍一下: Fabric是一个Python的库和命令行工具,用来提高基于SSH的应用部署和系统管理效率. 再具体点介绍一下,Fabri ...
- 后端程序员之路 6、Python fabric
直接写shell固然也很好,但是用python来写脚本,也是美滋滋.fabric是一个封装部署.多机操作等功能的python库. Welcome to Fabric! - Fabric documen ...
随机推荐
- adjustResize和adjustPan的比较
在下面的描述中,编辑框的maxLine都设定为10. 在信息列表界面中,编辑框在RelativeLayout中定义.编辑框上边(above)的列表组件的高度不会缩小为0,导致显示出现一点问题. 当信息 ...
- C语言中的随意跳转
C语言中有一个很不常用的头文件:setjmp.h. 这个头文件是C语言底层实现的,不像math.h里面的函数都是纯C语言实现的. setjmp.h包含两个函数: longjmp 跳转到某个位置 set ...
- 事务的四个属性ACID
事务四大特征:原子性,一致性,隔离性和持久性. 1. 原子性(Atomicity) 一个原子事务要么完整执行,要么干脆不执行.这意味着,工作单元中的每项任务都必须正确执行.如果有任一任务执行失败,则整 ...
- Centos 安装GIT 1.7.1
在Linux上安装Git 1.首先,你可以试着输入git,看看系统有没有安装Git: git 2.安装GIT https://git-scm.com/download/linux yum instal ...
- Swift 构造与析构
前言 与 OC 一样,Swift 中也存在构造和析构过程.不同的是,OC 中的构造方法和析构方法只是普通的方法,而 Swift 中构造器和析构器是一种特殊的结构. 1.构造器 在 Swift 中,类或 ...
- Win7 安装 MongoDB
MongoDB 下载 MongoDB 提供了可用于 32 位和 64 位系统的预编译二进制包,你可以从MongoDB官网下载安装,MongoDB 预编译二进制包下载地址:https://www.mon ...
- [转]Http Message结构学习总结
最近做的东西需要更深入地了解Http协议,故死磕了一下RFC2616-HTTP/1.1协议,主要是了解Http Message结构及每部分含义,在此总结一下,写一个模拟发送HTTP请求的工具,由于时间 ...
- VB高效导入Excel2003和Excel2007文件到MSHFlexGrid控件显示
1.VB高效导入Excel2003和Excel2007文件到MSHFlexGrid控件显示 2.以前也有Excel导入通用功能,但速度有些慢一会把两种实现方式都提供出为参考对比. 一.原通用导入exc ...
- springcloud中概念辨析
1 什么是微服务? 微服务架构是一种架构模式或者一种架构风格,他提倡将单一应用程序划分成一组小的服务,每个服务运行在独立进程中,服务之间相互协调.相互配合.服务之间采用轻量级的通信机制(一般是基于HT ...
- MarkDown 使用指南
https://frankbing.gitbooks.io/markdown/content/