欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

通過(guò)Python使用saltstack生成服務(wù)器資產(chǎn)清單

 更新時(shí)間:2016年03月01日 14:23:14   作者:youerning  
人工去對(duì)每一臺(tái)服務(wù)器的硬件信息并記錄早已經(jīng)過(guò)去了,無(wú)論通過(guò)腳本還是自動(dòng)化工具都是可以進(jìn)行一次編寫到處抓取的,本文主要使用saltstack作為使用工具,然后利用其提供的APi編寫所需的Python腳本

SaltStack是一個(gè)服務(wù)器基礎(chǔ)架構(gòu)集中化管理平臺(tái),具備配置管理、遠(yuǎn)程執(zhí)行、監(jiān)控等功能,一般可以理解為簡(jiǎn)化版的puppet和加強(qiáng)版的func。SaltStack基于Python語(yǔ)言實(shí)現(xiàn),結(jié)合輕量級(jí)消息隊(duì)列(ZeroMQ)與Python第三方模塊(Pyzmq、PyCrypto、Pyjinjia2、python-msgpack和PyYAML等)構(gòu)建。

通過(guò)部署SaltStack環(huán)境,我們可以在成千上萬(wàn)臺(tái)服務(wù)器上做到批量執(zhí)行命令,根據(jù)不同業(yè)務(wù)特性進(jìn)行配置集中化管理、分發(fā)文件、采集服務(wù)器數(shù)據(jù)、操作系統(tǒng)基礎(chǔ)及軟件包管理等,SaltStack是運(yùn)維人員提高工作效率、規(guī)范業(yè)務(wù)配置與操作的利器。

前言:人工去對(duì)每一臺(tái)服務(wù)器的硬件信息并記錄早已經(jīng)過(guò)去了,無(wú)論通過(guò)腳本還是自動(dòng)化工具都是可以進(jìn)行一次編寫到處抓取的,本文主要使用saltstack作為使用工具,然后利用其提供的APi編寫所需的Python腳本~~

需求如下:生成服務(wù)器主機(jī)名,IP地址,內(nèi)存,CPU核數(shù),操作系統(tǒng),數(shù)據(jù)盤配額,主要運(yùn)行服務(wù)

saltstack快速入門,可參考:Saltstack快速入門簡(jiǎn)單匯總

這里主要用到saltstack的grains,就是saltstack minion端生成的一些靜態(tài)信息,比如CPU,內(nèi)存,主機(jī)名什么的,而這些就是我們所需要的

執(zhí)行salt \* grains.items,會(huì)打印一大堆的默認(rèn)抓取的信息,其中一部分,如下


我們當(dāng)然只挑我們需要的,操作如下

獲取主機(jī)名

salt H-T-4 grains.item host

獲取IP地址

salt zabbix grains.item ipv4

獲取CPU核數(shù)

salt \* grains.item num_cpus

以此類推,根據(jù)自己所需,提取~~~

值得注意的是,grains信息里面并沒(méi)有硬盤信息,所以還需通過(guò)disk.usage這個(gè)選項(xiàng),得到我們所需的硬盤信息

執(zhí)行salt zabbix disk.usage,得到結(jié)果如下

其中1K-blocks即我們所需的硬盤信息,根據(jù)需求只需要數(shù)據(jù)盤/data,所以后面就會(huì)計(jì)算這個(gè)盤的配額

最終腳本如下

#coding=utf-8
import salt.client as sc
import json
###salt調(diào)用
local = sc.LocalClient()
###目標(biāo)主機(jī)指定
tgt = "*"
###獲取grains,disk信息
grains = local.cmd(tgt,"grains.items")
diskusage = local.cmd(tgt,"disk.usage")
###主要應(yīng)用列表即文件開頭
app_name = ["tomcat","zookeeper","redis","mysql","nginx"]
cols = "主機(jī)名,IP地址,內(nèi)存(GB),CPU核數(shù),操作系統(tǒng),數(shù)據(jù)盤/data(GB),所屬項(xiàng)目,主要應(yīng)用"
###打開一個(gè).csv文件,以便寫入
ret_file = open("ret.csv","w")
###首先寫入開頭,有點(diǎn)字段名的意思
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"]
###可能一些主機(jī)沒(méi)有/data數(shù)據(jù)盤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這個(gè)地址
ipv4 = str(grains[i]["ipv4"]).replace(", '127.0.0.1'","")
###因?yàn)橐恍v史遺留問(wèn)題,這里取得不是主機(jī)名,而是salt-minion的id名,用以判斷主要應(yīng)用
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
###項(xiàng)目名為空
project = ""
###通過(guò)minion ID名來(lái)判斷主要運(yùn)行服務(wù),比如xx-mysql-1,則運(yùn)行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()

用記事本打開應(yīng)該是這樣

以上內(nèi)容是小編給大家介紹的通過(guò)Python使用saltstack生成服務(wù)器資產(chǎn)清單的全部敘述,希望對(duì)大家有所幫助!

相關(guān)文章

  • Python3.10中match-case的用法和示例詳解

    Python3.10中match-case的用法和示例詳解

    在?Python?3.10?中引入了新的?match-case?語(yǔ)法,它是一種用于模式匹配的結(jié)構(gòu),下面小編就來(lái)和大家簡(jiǎn)單聊聊match-case的用法和示例吧,有需要的小伙伴可以參考下
    2023-10-10
  • 對(duì)Python生成漢字字庫(kù)文字,以及轉(zhuǎn)換為文字圖片的實(shí)例詳解

    對(duì)Python生成漢字字庫(kù)文字,以及轉(zhuǎn)換為文字圖片的實(shí)例詳解

    今天小編就為大家分享一篇對(duì)Python生成漢字字庫(kù)文字,以及轉(zhuǎn)換為文字圖片的實(shí)例詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-01-01
  • Pytest使用logging模塊寫日志的實(shí)例詳解

    Pytest使用logging模塊寫日志的實(shí)例詳解

    logging是python語(yǔ)言中的一個(gè)日志模塊,專門用來(lái)寫日志的,日志級(jí)別通常分為debug、info、warning、error、critical幾個(gè)級(jí)別,一般情況下,默認(rèn)的日志級(jí)別為warning,在調(diào)試或者測(cè)試階段,下面就快速體驗(yàn)一下logging模塊寫日志的用法,感興趣的朋友跟隨小編一起看看吧
    2022-12-12
  • Python二維列表的創(chuàng)建、轉(zhuǎn)換以及訪問(wèn)詳解

    Python二維列表的創(chuàng)建、轉(zhuǎn)換以及訪問(wèn)詳解

    列表中的元素還可以是另一個(gè)列表,這種列表稱為多為列表,只有一層嵌套的多維列表稱為二維列表,下面這篇文章主要給大家介紹了關(guān)于Python二維列表的創(chuàng)建、轉(zhuǎn)換及訪問(wèn)的相關(guān)資料,需要的朋友可以參考下
    2022-04-04
  • Python Django 后臺(tái)管理之后臺(tái)模型屬性詳解

    Python Django 后臺(tái)管理之后臺(tái)模型屬性詳解

    這篇文章主要介紹了Python Django 后臺(tái)管理之后臺(tái)模型屬性,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-04-04
  • PyQt5中多線程模塊QThread使用方法的實(shí)現(xiàn)

    PyQt5中多線程模塊QThread使用方法的實(shí)現(xiàn)

    這篇文章主要介紹了PyQt5中多線程模塊QThread使用方法的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-01-01
  • 詳解如何在Python中實(shí)現(xiàn)遺傳算法

    詳解如何在Python中實(shí)現(xiàn)遺傳算法

    遺傳算法是一種模擬自然進(jìn)化過(guò)程與機(jī)制來(lái)搜索最優(yōu)解的方法,這篇文章主要為大家介紹了如何在Python中實(shí)現(xiàn)遺傳算法,感興趣的小伙伴可以了解一下
    2023-06-06
  • Python獲取當(dāng)前目錄下所有文件的6種方法總結(jié)

    Python獲取當(dāng)前目錄下所有文件的6種方法總結(jié)

    這篇文章主要給大家介紹了關(guān)于Python獲取當(dāng)前目錄下所有文件的6種方法,要獲取當(dāng)前目錄下的所有目錄,可以使用Python內(nèi)置的os模塊中的listdir()函數(shù)和isdir()函數(shù),需要的朋友可以參考下
    2023-08-08
  • Python基于百度AI實(shí)現(xiàn)抓取表情包

    Python基于百度AI實(shí)現(xiàn)抓取表情包

    本文先抓取網(wǎng)絡(luò)上的表情圖像,然后利用百度 AI 識(shí)別表情包上的說(shuō)明文字,并利用表情文字重命名文件,感興趣的小伙伴們可以參考一下
    2021-06-06
  • TensorFlow進(jìn)階學(xué)習(xí)定制模型和訓(xùn)練算法

    TensorFlow進(jìn)階學(xué)習(xí)定制模型和訓(xùn)練算法

    本文將為你提供關(guān)于 TensorFlow 的中級(jí)知識(shí),你將學(xué)習(xí)如何通過(guò)子類化構(gòu)建自定義的神經(jīng)網(wǎng)絡(luò)層,以及如何自定義訓(xùn)練算法,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-07-07

最新評(píng)論