多服务器混搭
  操作多个服务器,需要配置多个host
#!/usr/bin/env python
# encoding: utf-8
from fabric.api import *
#操作一致的服务器可以放在一组,同一组的执行同一套操作
env.roledefs = {
'testserver': ['user1@host1:port1',],
'realserver': ['user2@host2:port2', ]
}
#env.password = '这里不要用这种配置了,不可能要求密码都一致的,明文编写也不合适。打通所有ssh行了'
@roles('testserver')
def task1():
run('ls -l | wc -l')
@roles('realserver')
def task2():
run('ls ~/temp/ | wc -l')
def dotask():
execute(task1)
execute(task2)
  结果:
[ken@~/tmp/fab$] fab -f mult.py dotask
[user1@host1:port1] Executing task 'task1'
[user1@host1:port1] run: ls -l | wc -l
[user1@host1:port1] out: 9
[user1@host1:port1] out:
[user2@host2:port2] Executing task 'task2'
[user2@host2:port2] run: ls ~/temp/ | wc -l
[user2@host2:port2] out: 11
[user2@host2:port2] out:
Done.
  扩展
  1.颜色
  可以打印颜色,在查看操作结果信息的时候更为醒目和方便
  from fabric.colors import *
  def show():
  print green('success')
  print red('fail')
  print yellow('yellow')
  #fab -f color.py show
  2.错误和异常
  关于错误处理
  默认,一组命令,上一个命令执行失败后,不会接着往下执行
  失败后也可以进行不一样的处理, 文档
  目前没用到,后续用到再看了
  3.密码管理
  看文档
  更好的密码管理方式,哥比较土,没打通,主要是服务器列表变化频繁,我的处理方式是:
  1.host,user,port,password配置列表,所有的都写在一个文件
  或者直接搞到脚本里,当然这个更........
env.hosts = [
'host1',
'host2'
]
env.passwords = {
'host1': "pwdofhost1",
'host2': "pwdofhost2",
}
或者
env.roledefs = {
'testserver': ['host1', 'host2'],
'realserver': ['host3', ]
}
env.passwords = {
'host1': "pwdofhost1",
'host2': "pwdofhost2",
'host3': "pwdofhost3",
}
  2.根据key解析成map嵌套,放到deploy中
  另外命令其实也可以固化成一个cmds列表的…