Python运维工具介绍1–fabric



fabric是一个Python写的运维工具。他使用python完全实现了ssh客户端的协议。使得之前的服务器部署,维护,获得当前服务器状态等需要ssh上服务器的工作,可以完全的自动化运行。这种工具对于我这种喜欢折腾的人来说,无疑是种解脱。

Get Start 

如何安装 

  • 安装Python。 官方网站
  • 安装easy_install或者pip
  • 键入命令easy_install fabric或者pip -U fabric
  • 将Python的Scripts目录放到Path中(好似只是windows需要,这个目录大概在你的Python安装目录下的Scripts文件夹)。

Try Hello World 

安装完毕后,我们就要体验一下fabric了。用你最喜欢的IDE将下面代码存成一个叫做”fabfile.py”的文件。代码如下:

from fabric.api import * @task def PrintCpuinfo():         cmd_output = run("cat /proc/cpuinfo")         print cmd_output

这段代码的目的就是获得远端计算机上CPU的参数。并输出出来。写完代码后,我们使用命令行输入fab PrintCpuinfo(一定要确定PATH中有个scripts哦)。就可以按照提示输入登录host,密码等等。

深入了解 

配置Host 

之前,在Hello World中,我们并未配置需要登录的Host,我们运行后,fabric会使用命令行交互获得需要登录的host和密码。但是,我们需要做的是自动化的去干这件事情。应该如何将登陆自动化呢?

使用命令行参数 

在调用fabric的时候,我们可以使用命令行参数-H确定这个命令需要在哪台主机,或者哪些台主机上运行。示例如下:

fab -H user1@host1,user2@host2 PrintCpuinfo

这样便可以自动化的在多台计算机上执行PrintCpuinfo命令。

在fabfile中配置HOST 

我们可以在fabfile中,定义tast之前,加入如下代码,来配置要登录的host。

env.password = "password" env.hosts = ["a@host1","b@host2"]

这样,使用fab PrintCpuinfo的时候,便可以自动登录到远程计算机了而不需要输入密码了。

还有哪些命令? 

在fabric中,不仅仅支持我们上面用到的run命令,同时还有如下命令:

  • sudo: 和run类似,只是sudo之后运行
  • get/put: 使用sftp协议上传下载文件
  • local:本地运行命令
  • cd: 更改目录,使用 with cd("目录名"):来进行。
  • prompt: 类似于raw_input的命令,只是与env变量有交互。
  • reboot:重启。

fabric使用了极其原始和简单的api与远程计算机进行交互。这注定了其易用性,和可扩展性。。但是仅仅有fabric对于很多事情都是很困难的,例如跨操作系统的操作(ubuntu/centos)等。可能会在之后某篇文章中做一介绍。