一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

腳本之家,腳本語言編程技術及教程分享平臺!
分類導航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務器之家 - 腳本之家 - Python - Python腳本實現Zabbix多行日志監控過程解析

Python腳本實現Zabbix多行日志監控過程解析

2020-08-26 09:22Zabbix_Z大叔 Python

這篇文章主要介紹了Python腳本實現Zabbix多行日志監控過程解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下

通過使用zabbix 日志監控 我發現一個問題 例如oracle的日志有報錯的情況 ,通常不會去手動清理 這樣的話當第二次有日志寫進來的時候 zabbix的機制是回去檢查全部日志,這樣的話之前已經告警過的錯誤日志,又會被檢查到,這樣就會出現重復告警,而且zabbix的日志監控只能讀到匹配當前行關鍵字的數據,感覺不太靈活, 比如我想要匹配到的關鍵字之后再當前關鍵字的下N行再去匹配另一個關鍵字這個時候就比較麻煩,在這里給大家推薦一個有效,便捷解決的方式。

通過Python腳本實現日志監控 要求 1 記錄腳本檢查日志位置,避免下次觸發腳本的時候出現重復告警 2 關鍵字匹配支持正則 3 支持多個關鍵字查詢,例如第一個關鍵字匹配到當之后在這個關鍵字的下N行再去匹配第二個關鍵字 具體傳參格式
python3 npar.py /u03/z.txt '(ORA-|REEOR),(04030|02011)' 2

第一個參數是日志路徑 第二個參數是關鍵字 第三個參數為 匹配到第一個表達式這種的關鍵字后再去地 N(2)行去匹配第二個關鍵詞(04030|02011)具體腳本實現如下

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
import os
import sys
logtxt = "logtxt.txt"
def read_txt(files, start_line):
    data = []
data.append("")
with open(str(files) + "", "r",
        encoding = 'UTF-8') as f:
    for line in f.readlines():
    line = line.strip('\n')# 去掉列表中每一個元素的換行符
data.append(line)
# 記錄本次的行數
wirte_log(len(data) - 1)
if len(data) > start_line:
    return data[start_line - 1: ]
else :
    print("開始行數大于文本文件總行數!")
def wirte_log(lines):
    global logtxt
with open(logtxt, "w") as file: #”w "代表著每次運行都覆蓋內容
file.write(str(lines))
def read_log():
    global logtxt
if not os.path.exists(logtxt):
    with open(logtxt, "w") as file: #”w "代表著每次運行都覆蓋內容
file.write(str(1))
with open(logtxt + "", "r", encoding =
        'UTF-8') as f:
    s_lines = f.readlines()
print("從第" + str(s_lines[0]) + "行開始")
return s_lines[0]
def deal_read_log(files, keyword,
        interval_line):
    keywords = keyword.replace("(", "").replace(
        ")", "").replace("'", "").replace('"',
        '"').split(',')
start_keywords = keywords[0].split("|")
end_keywords = keywords[1].split("|")
start_line = read_log()
lines_data = read_txt(files, int(
    start_line))
for_line = 1
while (for_line < len(lines_data)):
    #print(for_line)
# print(lines_data[for_line])
#
if end_keywords in lines_data[for_line]:
    #print(lines_data[for_line])
# print("-------------------")
# for_line = for_line + 1
#
else :
    isexist = 0
for sk in start_keywords:
    if sk in lines_data[for_line]:
    isexist = 1
break;
if isexist == 1:
    #if start_keywords[0] in lines_data[
        for_line] or start_keywords[1] in
    lines_data[for_line]:
    #當前行有end_keywords
isexist2 = 0
for sk in end_keywords:
    if sk in lines_data[for_line]:
    isexist2 = 1
break;
if isexist2 == 1:
    #print("行數=" + str(start_line - 1 +
        for_line) + "-" + str(start_line - 1 +
        for_line))
print(lines_data[for_line])
else :
    #當前行沒有end_keywords。 往下interval_line行去尋找
# 標記當前行數
flag_line = for_line
count = 1
for_line = for_line + 1
while (for_line < len(lines_data)):
    isexist3 = 0
for sk in end_keywords:
    if sk in lines_data[for_line]:
    isexist3 = 1
break;
if isexist3 == 1:
    #print("行數=" + str(start_line - 1 +
        flag_line) + "-" + str(start_line -
        1 + for_line))
for prin in range(flag_line, for_line +
        1):
    print(lines_data[prin])
break;
for_line = for_line + 1
if count == int(interval_line):
    break;
count = count + 1
for_line = for_line - 1
for_line = for_line + 1
if name == 'main':
    files = sys.argv[1]
if '.log' in files:
    logtxt = files.replace(".log",
        "_log.txt")
else :
    logtxt = files.replace(".txt",
        "_log.txt")
# files = "ora.txt"
keywords = sys.argv[2]
# keywords = "'((04030|04000),ORA-)'"
#上下關聯行數
interval_line = int(sys.argv[3])
# interval_line = 10
deal_read_log(files, keywords,
    interval_line)

接下來就是添加監控了

在agent的conf 文件里面添加UserParameter

Python腳本實現Zabbix多行日志監控過程解析

Python腳本實現Zabbix多行日志監控過程解析

到這里監控就完成了

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。

原文鏈接:https://blog.51cto.com/14483703/2519876

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 扒开放荡老师裙子猛烈的进入 | 精品无码乱码AV | 色交视频| 久久久久伊人 | 天堂网www在线中文天堂 | 边摸边吃奶边做爽gif动态图 | 无人知晓小说姜璟免费阅读 | 男生和女生艹逼 | 亚洲精品欧洲久久婷婷99 | 1024免费观看完整版在线播放 | 亚洲欧美综合一区 | 精品国产乱码久久久久久软件 | 久久免费国产视频 | babes性欧美30 | 91在线免费看 | 国产成人综合亚洲一区 | 日韩欧美国产一区二区三区 | 亚洲人成毛片线播放 | 污书屋 | 色综合伊人色综合网亚洲欧洲 | 国产片自拍 | 欧美性黑人巨大gaysex | 十八女下面流水不遮免费 | 亚洲精品tv久久久久久久久久 | 久久亚洲免费视频 | 动漫在线观看h | 99久久免费国产香蕉麻豆 | eeuss18影院www国产 | 男女男精品视频 | 法国贵妇一级伦理hd | 国产午夜永久福利视频在线观看 | 深夜激情网 | 久久精品一卡二卡三卡四卡视频版 | 99久久精品国产一区二区 | 国产成人精品曰本亚洲77美色 | 歪歪私人影院成人毛片 | 欧美国产影院 | 果冻传媒和91制片厂网站软件 | 亚洲国产精品久久网午夜小说 | 欧美特欧美特级一片 | 色人阁图片 |