通过Python使用saltstack生成服务器资产清单


Posted in Python onMarch 01, 2016

SaltStack是一个服务器基础架构集中化管理平台,具备配置管理、远程执行、监控等功能,一般可以理解为简化版的puppet和加强版的func。SaltStack基于Python语言实现,结合轻量级消息队列(ZeroMQ)与Python第三方模块(Pyzmq、PyCrypto、Pyjinjia2、python-msgpack和PyYAML等)构建。

通过部署SaltStack环境,我们可以在成千上万台服务器上做到批量执行命令,根据不同业务特性进行配置集中化管理、分发文件、采集服务器数据、操作系统基础及软件包管理等,SaltStack是运维人员提高工作效率、规范业务配置与操作的利器。

前言:人工去对每一台服务器的硬件信息并记录早已经过去了,无论通过脚本还是自动化工具都是可以进行一次编写到处抓取的,本文主要使用saltstack作为使用工具,然后利用其提供的APi编写所需的Python脚本~~

需求如下:生成服务器主机名,IP地址,内存,CPU核数,操作系统,数据盘配额,主要运行服务

saltstack快速入门,可参考:Saltstack快速入门简单汇总

这里主要用到saltstack的grains,就是saltstack minion端生成的一些静态信息,比如CPU,内存,主机名什么的,而这些就是我们所需要的

执行salt \* grains.items,会打印一大堆的默认抓取的信息,其中一部分,如下

通过Python使用saltstack生成服务器资产清单

我们当然只挑我们需要的,操作如下

获取主机名

salt H-T-4 grains.item host

获取IP地址

salt zabbix grains.item ipv4

获取CPU核数

salt \* grains.item num_cpus

以此类推,根据自己所需,提取~~~

值得注意的是,grains信息里面并没有硬盘信息,所以还需通过disk.usage这个选项,得到我们所需的硬盘信息

执行salt zabbix disk.usage,得到结果如下

通过Python使用saltstack生成服务器资产清单

其中1K-blocks即我们所需的硬盘信息,根据需求只需要数据盘/data,所以后面就会计算这个盘的配额

最终脚本如下

#coding=utf-8
import salt.client as sc
import json
###salt调用
local = sc.LocalClient()
###目标主机指定
tgt = "*"
###获取grains,disk信息
grains = local.cmd(tgt,"grains.items")
diskusage = local.cmd(tgt,"disk.usage")
###主要应用列表即文件开头
app_name = ["tomcat","zookeeper","redis","mysql","nginx"]
cols = "主机名,IP地址,内存(GB),CPU核数,操作系统,数据盘/data(GB),所属项目,主要应用"
###打开一个.csv文件,以便写入
ret_file = open("ret.csv","w")
###首先写入开头,有点字段名的意思
ret_file.write(cols + "\n")
try:
for i in grains.keys():
###打印信息可注释掉
print grains[i]["nodename"]
print "ipv4" + ":" ,grains[i]["ipv4"]
print "mem_total" + ":" , grains[i]["mem_total"] / 1024 + 1
print "num_cpus" + ":" , grains[i]["num_cpus"]
print "osfullname" + ":" , grains[i]["osfullname"]
print "release" + ":" , grains[i]["lsb_distrib_release"]
###可能一些主机没有/data数据盘1048576是1024x1024
if "/data" not in diskusage[i]:
print "diskusage" + ":" + "have no /data disk"
else:
data_vol = int(diskusage[i]["/data"]["1K-blocks"])
print "diskusage" + ":" , data_vol / 1048576 
###去掉127.0.0.1这个地址
ipv4 = str(grains[i]["ipv4"]).replace(", '127.0.0.1'","")
###因为一些历史遗留问题,这里取得不是主机名,而是salt-minion的id名,用以判断主要应用
hostname = grains[i]["id"]
ipv4 = str(grains[i]["ipv4"]).replace(", '127.0.0.1'","")
ipv4 = ipv4.replace(",","and")
mem = grains[i]["mem_total"] / 1024 + 1
num_cpu = grains[i]["num_cpus"]
OS = grains[i]["osfullname"] + grains[i]["lsb_distrib_release"]
if "/data" not in diskusage[i]:
disk_data = "None"
else:
disk_data = data_vol / 1048576
###项目名为空
project = ""
###通过minion ID名来判断主要运行服务,比如xx-mysql-1,则运行mysql
for j in app_name:
if j in hostname.lower():
app = j
break
else:
app = "undefined"
c = ","
###连接并写入
line = hostname + c + ipv4 + c + str(mem) + c + str(num_cpu) + c + str(OS) + c + str(disk_data) + c + project + c + app
ret_file.write(line + "\n")
except Exception,e:
print "Exception:\n",e
finally:
ret_file.close()

用记事本打开应该是这样

通过Python使用saltstack生成服务器资产清单

以上内容是小编给大家介绍的通过Python使用saltstack生成服务器资产清单的全部叙述,希望对大家有所帮助!

Python 相关文章推荐
深入探究Python中变量的拷贝和作用域问题
May 05 Python
django接入新浪微博OAuth的方法
Jun 29 Python
Windows下为Python安装Matplotlib模块
Nov 06 Python
Python随手笔记第一篇(2)之初识列表和元组
Jan 23 Python
利用python画一颗心的方法示例
Jan 31 Python
python计算两个地址之间的距离方法
Jun 09 Python
Python定义一个跨越多行的字符串的多种方法小结
Jul 19 Python
基于TensorBoard中graph模块图结构分析
Feb 15 Python
python matplotlib:plt.scatter() 大小和颜色参数详解
Apr 14 Python
pycharm中选中一个单词替换所有重复单词的实现方法
Nov 17 Python
python基础之文件操作
Oct 24 Python
Python 如何利用ffmpeg 处理视频素材
Nov 27 Python
Python解析json文件相关知识学习
Mar 01 #Python
使用简单工厂模式来进行Python的设计模式编程
Mar 01 #Python
Python文件处理
Feb 29 #Python
python 默认参数问题的陷阱
Feb 29 #Python
简要讲解Python编程中线程的创建与锁的使用
Feb 28 #Python
Python中time模块和datetime模块的用法示例
Feb 28 #Python
python 写的一个爬虫程序源码
Feb 28 #Python
You might like
十大催泪虐心动漫,你能坚持看到第几部?
2020/03/04 日漫
PHP FTP操作类代码( 上传、拷贝、移动、删除文件/创建目录)
2014/05/10 PHP
php实现将数组转换为XML的方法
2015/03/09 PHP
php使用自定义函数实现汉字分割替换功能示例
2017/01/30 PHP
详解PHP中的序列化、反序列化操作
2017/03/21 PHP
基于PHP-FPM进程池探秘
2017/10/17 PHP
JavaScript进阶教程(第四课第一部分)
2007/04/05 Javascript
javascript 页面划词搜索JS
2009/09/28 Javascript
jQuery中element选择器用法实例
2014/12/29 Javascript
arguments对象验证函数的参数是否合法
2015/06/26 Javascript
Javascript使用post方法提交数据实例
2015/08/03 Javascript
JS调用某段SQL语句的方法
2016/10/20 Javascript
bootstrap的常用组件和栅格式布局详解
2017/05/02 Javascript
JS库之ParticlesJS使用简介
2017/09/12 Javascript
浅谈如何使用 webpack 优化资源
2017/10/20 Javascript
js注册时输入合法性验证方法
2017/10/21 Javascript
在create-react-app中使用css modules的示例代码
2018/07/31 Javascript
Nodejs中的JWT和Session的使用
2018/08/21 NodeJs
jQuery实现动态添加和删除input框代码实例
2019/03/29 jQuery
js判断复选框是否选中的方法示例【基于jQuery】
2019/10/10 jQuery
重置Redux的状态数据的方法实现
2019/11/18 Javascript
Python中利用sorted()函数排序的简单教程
2015/04/27 Python
Python的Django框架中的数据库配置指南
2015/07/17 Python
Python的迭代器和生成器
2015/07/29 Python
如何安装多版本python python2和python3共存以及pip共存
2018/09/18 Python
对Python之gzip文件读写的方法详解
2019/02/08 Python
Python3.5 Pandas模块之Series用法实例分析
2019/04/23 Python
python tkinter组件使用详解
2019/09/16 Python
使用Python实现分别输出每个数组
2019/12/06 Python
python PIL/cv2/base64相互转换实例
2020/01/09 Python
DJI大疆德国官方商城:大疆无人机
2018/09/01 全球购物
乌克兰珠宝大卖场:Zlato.ua
2020/09/27 全球购物
卫校中专生的自我评价
2014/01/15 职场文书
安全生产检查通报
2014/01/29 职场文书
简易版租房协议书范本
2014/10/13 职场文书
2015教师年度考核评语
2015/03/25 职场文书