zabbixはscreenスクリプトを作成し、bashスクリプトによってzabbixデータベースを分析してサーバの毎日の障害統計を実現します.
http://qicheng0211.blog.51cto.com/3958621/1622152
次はscreenを作成するスクリプトで、1つのホストのすべてのgraphsを1つのscreenに配置して表示できます.
スクリプトの使用方法:
解決策:suricatascのインストール
ここで最初のzabbix serverは、あなたのホスト名またはホストIPアドレスの2番目のzabbix serverが画像名です.
効果図:
bashスクリプトによるzabbixデータベースの分析により、サーバの毎日の障害統計を実現
bossは毎晩9時にメールを送るように要求して、各部門の総監の携帯電話に行って、一日の中のすべてのサーバーの誤った統計を総括して、任務を受け取った後、私は分析して、zabbixの持参の機能を通じてあまり実現しなくて、そこでshellのスクリプトを書くことを通じて実現するつもりで、スクリプトの簡単な説明:sql文を通じて、events表の中の一日のすべての警報を検索して、triggersテーブルでアラームを分類し、分類ごとに対応する配列に入れ、最後に会社のメールインタフェースを通じて統計メールを送信します.
注意:このスクリプトはzabbix 1.8.3バージョンでテストに合格しました.他のバージョンはテストしていません.sendsms_pro.phpは弊社のメールインタフェースで、インタフェースがなければlinux fetionを使って実現できます.
次はscreenを作成するスクリプトで、1つのホストのすべてのgraphsを1つのscreenに配置して表示できます.
#!/usr/bin/env python
import urllib2
import json
import argparse
def authenticate(url, username, password):
values = {'jsonrpc': '2.0',
'method': 'user.login',
'params': {
'user': username,
'password': password
},
'id': '0'
}
data = json.dumps(values)
req = urllib2.Request(url, data, {'Content-Type': 'application/json-rpc'})
response = urllib2.urlopen(req, data)
output = json.loads(response.read())
try:
message = output['result']
except:
message = output['error']['data']
print message
quit()
return output['result']
def getGraph(hostname, url, auth, graphtype, dynamic, columns):
if (graphtype == 0):
selecttype = ['graphid']
select = 'selectGraphs'
if (graphtype == 1):
selecttype = ['itemid', 'value_type']
select = 'selectItems'
values = {'jsonrpc': '2.0',
'method': 'host.get',
'params': {
select: selecttype,
'output': ['hostid', 'host'],
'searchByAny': 1,
'filter': {
'host': hostname
}
},
'auth': auth,
'id': '2'
}
data = json.dumps(values)
req = urllib2.Request(url, data, {'Content-Type': 'application/json-rpc'})
response = urllib2.urlopen(req, data)
host_get = response.read()
output = json.loads(host_get)
# print json.dumps(output)
graphs = []
if (graphtype == 0):
for i in output['result'][0]['graphs']:
graphs.append(i['graphid'])
if (graphtype == 1):
for i in output['result'][0]['items']:
if int(i['value_type']) in (0, 3):
graphs.append(i['itemid'])
graph_list = []
x = 0
y = 0
for graph in graphs:
graph_list.append({
"resourcetype": graphtype,
"resourceid": graph,
"width": "500",
"height": "100",
"x": str(x),
"y": str(y),
"colspan": "0",
"rowspan": "0",
"elements": "0",
"valign": "0",
"halign": "0",
"style": "0",
"url": "",
"dynamic": str(dynamic)
})
x += 1
if x == columns:
x = 0
y += 1
return graph_list
def screenCreate(url, auth, screen_name, graphids, columns):
# print graphids
if len(graphids) % columns == 0:
vsize = len(graphids) / columns
else:
vsize = (len(graphids) / columns) + 1
values = {"jsonrpc": "2.0",
"method": "screen.create",
"params": [{
"name": screen_name,
"hsize": columns,
"vsize": vsize,
"screenitems": []
}],
"auth": auth,
"id": 2
}
for i in graphids:
values['params'][0]['screenitems'].append(i)
data = json.dumps(values)
req = urllib2.Request(url, data, {'Content-Type': 'application/json-rpc'})
response = urllib2.urlopen(req, data)
host_get = response.read()
output = json.loads(host_get)
try:
message = output['result']
except:
message = output['error']['data']
print json.dumps(message)
def main():
#
url = 'http:///zabbix/api_jsonrpc.php'
username = "Your API Users Username"
password = "Your API Users Username"
parser = argparse.ArgumentParser(description='Create Zabbix screen from all of a host Items or Graphs.')
parser.add_argument('hostname', metavar='H', type=str,
help='Zabbix Host to create screen from')
parser.add_argument('screenname', metavar='N', type=str,
help='Screen name in Zabbix. Put quotes around it if you want spaces in the name.')
parser.add_argument('-c', dest='columns', type=int, default=3,
help='number of columns in the screen (default: 3)')
parser.add_argument('-d', dest='dynamic', action='store_true',
help='enable for dynamic screen items (default: disabled)')
parser.add_argument('-t', dest='screentype', action='store_true',
help='set to 1 if you want item simple graphs created (default: 0, regular graphs)')
args = parser.parse_args()
hostname = args.hostname
screen_name = args.screenname
columns = args.columns
dynamic = (1 if args.dynamic else 0)
screentype = (1 if args.screentype else 0)
auth = authenticate(url, username, password)
graphids = getGraph(hostname, url, auth, screentype, dynamic, columns)
print "Screen Name: " + screen_name
print "Total Number of Graphs: " + str(len(graphids))
screenCreate(url, auth, screen_name, graphids, columns)
if __name__ == '__main__':
main()
スクリプトの使用方法:
[root@monitor sbin]# ./screen.py -h
Traceback (most recent call last):
File "./screen.py", line 4, in
import argparse
ImportError: No module named argparse
解決策:suricatascのインストール
[root@localhost ~]# rpm -qa python
python-2.6.6-36.el6.x86_64
[root@localhost ~]# suricatasc
Traceback (most recent call last):
File "/usr/bin/suricatasc", line 18, in
import argparse
ImportError: No module named argparse
# tar -xf argparse-1.3.0.tar.gz
# cd argparse-1.3.0
# python setup.py install
Traceback (most recent call last):
File "setup.py", line 3, in
from setuptools import setup, find_packages
ImportError: No module named setuptools
setuptools , python , , :
# tar -xf setuptools-15.2.tar.gz
# cd setuptools-15.2
# python setup.py build
# python setup,py install
# cd argparse-1.3.0
# python setup.py install
ここで最初のzabbix serverは、あなたのホスト名またはホストIPアドレスの2番目のzabbix serverが画像名です.
効果図:
bashスクリプトによるzabbixデータベースの分析により、サーバの毎日の障害統計を実現
bossは毎晩9時にメールを送るように要求して、各部門の総監の携帯電話に行って、一日の中のすべてのサーバーの誤った統計を総括して、任務を受け取った後、私は分析して、zabbixの持参の機能を通じてあまり実現しなくて、そこでshellのスクリプトを書くことを通じて実現するつもりで、スクリプトの簡単な説明:sql文を通じて、events表の中の一日のすべての警報を検索して、triggersテーブルでアラームを分類し、分類ごとに対応する配列に入れ、最後に会社のメールインタフェースを通じて統計メールを送信します.
----------------------------------------------------------------------------------------------------------------------------------------------
#!/bin/sh
### ## :V0.2 2010-10-21 22:28 David.zhu
#------------------------------
## array1
## array2
## array3
## array4
## array5
#-----------------------------
now=`date +%s`
fix=`expr $now - 86400`
myconn="mysql -h 192.168.0.10 -uzabbix -pzabbix zabbix"
result=`${myconn}
-e "SELECT objectid FROM events WHERE value=1 AND objectid >10000
AND clock>=${fix} AND clock<=${now} ORDER BY clock DESC LIMIT
100" | grep -v "objectid"`
i=0
for trid in ${result};do
PRO=`${myconn}
-e "SELECT priority FROM triggers t WHERE ((t.triggerid BETWEEN
000000000000000 AND 099999999999999)) AND (t.triggerid IN(${trid}))"|
grep -v priority`
case $PRO in
1) array1[$i]=${PRO};;
2) array2[$i]=${PRO};;
3) array3[$i]=${PRO};;
4) array4[$i]=${PRO};;
5) array5[$i]=${PRO};;
*) error[$i]=${PRO};;
esac
i=`expr $i + 1`
done
message=" --- :${#array5[@]} | :${#array4[@]} | :${#array3[@]} | :${#array2[@]} | :${#array1[@]} "
mobile=('138*****' '138*****' '138*****' '138*****')
for ((j=0;j&1
done
-----------------------------------------------------------------------------------------------------------------------------------------------
注意:このスクリプトはzabbix 1.8.3バージョンでテストに合格しました.他のバージョンはテストしていません.sendsms_pro.phpは弊社のメールインタフェースで、インタフェースがなければlinux fetionを使って実現できます.