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


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.password = {
    '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 not confirm("put file failed,Continue[Y/N]?"):
        about("Aborting file put task!")

CentOS 6.0下SSH免密码登录配置

提高Ubuntu的SSH登陆认证速度的办法

开启SSH服务让Android手机远程访问 Ubuntu 14.04 

如何为Linux系统中的SSH添加双重认证

在 Linux 中为非 SSH 用户配置 SFTP 环境

Linux 上SSH 服务的配置和管理

SSH入门学习基础教程

本文永久更新链接地址: 

相关内容