您的位置:首页 > 运维架构

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

2014-12-13 09:01 826 查看
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!")
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  批量 ssh 自动化 fabirc