Fabric是基于python(2.5-2.7)库和命令行来实现SSH远程应用部署及系统管理的工具,使用它,在批量管理远程主机时,不需要一台一台的输入密码登陆,可以把所以主机的用户名和密码写在一个文件里面来操作,下文中有具体实例。
Fabric的安装 yum install python-setuptools python-dev* pycrypto wget https://pypi.python.org/packages/source/F/Fabric/Fabric-1.10.0.tar.gz --no-check-certificate tar zxvf Fabric-1.10.0.tar.gz cd Fabric-1.10.0 python setup.py install python >>>import fabric #检查安装结果,导入模块没有提示异常,则安装成功
针对不同主机执行不同命令,简单脚本如下:(每个定义的函数都可以当成一个参数来执行) #!/usr/bin/env python from fabric.colors import * from fabric.api import * env.user = ‘root‘ env.roledefs = { ‘proxy‘: [‘192.168.199.113‘], ‘media‘: [‘192.168.199.118‘] } env.passwords = { ‘root@192.168.199.113:22‘: ‘123456‘, ‘root@192.168.199.118:22‘: ‘123456‘ } @roles(‘proxy‘) def proxytask(): run("df -h") @roles(‘media‘) def mediatask(): run("free -m") #@roles(‘media‘,‘proxy‘) def run(): execute(proxytask) execute(mediatask)
fab -f fabtest.py run fab -f fabtest.py mediatask fab -f fabtest.py proxytask #可以对比一个这三个执行的结果
远程文件推送脚本: #!/usr/bin/env python #file tar upload check from fabric.api import * from fabric.context_managers import * from fabric.contrib.console import confirm env.user=‘root‘ env.hosts=[‘192.168.199.118‘] env.passwords = { ‘root@192.168.199.118:22‘: ‘123456‘ } @task def put_task(): #upload file task run("mkdir -p /root/test") with cd("/root/test") with settings(warn_only=True): #when upload error,continue result = put("/etc","/root/test") if result.failed and no confirm("put file failed,Continue[Y/N]?")
本文出自 “ThunderMeng” 博客,请务必保留此出处http://thundermeng.blog.51cto.com/9414441/1589515
原文地址:http://thundermeng.blog.51cto.com/9414441/1589515