码迷,mamicode.com
首页 > 其他好文 > 详细

Fabric自动化运维工具实现远程SSH部署及系统管理

时间:2014-12-13 10:57:48      阅读:210      评论:0      收藏:0      [点我收藏+]

标签:ssh   批量   自动化   fabirc   

    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

Fabric自动化运维工具实现远程SSH部署及系统管理

标签:ssh   批量   自动化   fabirc   

原文地址:http://thundermeng.blog.51cto.com/9414441/1589515

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!