玩蛇网提供最新Python编程技术信息以及Python资源下载!

python fabric批量管理多台server执行方法问题

如下所示(port是可以这么写的,目录不行),进入不同主机时自动进入到不同目录,执行xxx。对不同的server传入不同的路径,执行xxx。 谢谢!
env.hosts = [test@server1:path_to_dir_1, test@se rver2:path_to_dir_2 ,......]
def xxx():
pass

在我之前的项目是以全局配置项的形式来实现的,为每个host定义自己的work_dir等变量

host_configs = {
    "ip1": {
        "work_dir": path1
    },
    "ip2": {
        "work_dir": path2
    },
}

然后在fabric的task方法中通过env['host']作为key,去host_configs中去读取相应的work_dir信息,并执行相应操作

@task
def some_task():
    with cd(host_configs[env['host']]['work_dir']):
        do_some_stuff

fabric是可以对主机进行分组的,就像下边这个

from fabric import hosts,run
@hosts('host1', 'host2')
def mytask():
 run('ls /var/www')

或者这个

from fabric.api import run, roles

env.roledefs = {
    'db': ['db1', 'db2'],
    'web': ['web1', 'web2', 'web3'],
}

@roles('db')
def do():.
    pass

@roles('web')
def do():
    pass

看下官方文档,就都清楚了。

玩蛇网文章,转载请注明出处和文章网址:https://www.iplaypy.com/wenda/wd20248.html

相关文章 Recommend

玩蛇网Python互助QQ群,欢迎加入-->: 106381465 玩蛇网Python新手群
修订日期:2017年05月19日 - 15时16分21秒 发布自玩蛇网

您现在的位置: 玩蛇网首页 > Python问题解答 > 正文内容
我要分享到:

必知PYTHON教程 Must Know PYTHON Tutorials

必知PYTHON模块 Must Know PYTHON Modules