Fabric实例

Fabric的官网   http://fabric-chs.readthedocs.io/zh_CN/chs/index.html
参考《Python自动化运维 技术与最佳实践》
 

1:查看本地与远程主机信息

#!/usr/bin/python
from fabric.api import *

env.user="lile"
env.hosts=['10.0.0.145','10.0.0.147']
env.password="123456"

#@runs_once
def local_task():
    local('uname -r')
def remote_task():
    with cd("/tmp"):
        run("ls")

 

with 的作用是让后面的表达式的语句继承当前状态,实现“cd /tmp && ls”的效果
上面的remote_task也可表示为:
def remote_task():
      run("cd /tmp" && ls)
 
2:动态的获取远程目录列表
#!/usr/bin/python
from fabric.api import *

env.user="lile"
env.hosts=['10.0.0.145','10.0.0.147']
env.password='123456'

@runs_once
def input_raw():
    return prompt("please input directory name:",default="/home")

def worktask(dirname):
    run("ls " + dirname)

@task
def go():
    getdirname = input_raw()
    worktask(getdirname)
 
prompt 表示获取用户的信息
@task 函数修饰符,表示只有函数标记了,才为fab可调用,非标记的不可用
Fabric实例_第1张图片
 
 若注释掉@task,三个都可见
Fabric实例_第2张图片
 
执行结果为:
Fabric实例_第3张图片
 这里的@runs_once表示只要输入一个,然后所有的主机都是查看这个路径下的东西,画红圈圈的[10.0.0.145]可以不用管。
 
3:上传tomcat,并解压,通过堡垒机的形式
#!/usr/bin/python
from fabric.api import *
from fabric.context_managers import *
from fabric.contrib.console import confirm

env.user="root"
env.gateway="10.0.0.12"
env.hosts=['10.0.0.145','10.0.0.147']
env.passwords={
    '[email protected]:22':'root123456',
    '[email protected]:22':'123456',
    '[email protected]:22':'123456'
}

lpath="/fabric/5/apache-tomcat-8.5.12.tar.gz"
rpath="/tmp/install"

@task
def put_task():
    run('mkdir -p /tmp/install')
    with settings(warn_only=True):
        result = put(lpath,rpath)
    if result.failed and not confirm("put file failed,Continue[Y/N]?"):
        abort("Aborting file put task!")

@task
def tar():
    with cd("/tmp/install"):
        run("tar -zxvf apache-tomcat-8.5.12.tar.gz")

@task
def go():
    put_task()
    tar()
 
这里是通过堡垒机的形式上传本地文件,文件不是放在堡垒机上,而是放在执行此脚本的本地机器上
env.gateway:定义网关IP(也就是中转,堡垒机IP)
env.passwords:设置密码,但是需要设置账户,主机,端口等信息
 

你可能感兴趣的:(Fabric实例)