python自动化工具日志查询分析脚本代码实现

时间:2021-05-22

受控节点slave.py

复制代码 代码如下:
import socket
import re
class Log(object):
file_list=['access.log','C:\\access.log']
master_ip='192.168.0.103'
def __init__(self):
s=socket.socket(socket.AF_INET,socket.SOCK_STREAM)
s.bind(('',3333))
s.listen(1)
while True:
conn,addr=s.accept()
print addr[0]
if addr[0]==self.master_ip:
reg=conn.recv(1024)
result=self.all_log(reg)
conn.sendall(result)
conn.close()

def all_log(self,reg):
logs=''
for f in self.file_list:
logs+='\n'+self.log_match(f,reg)
return logs

def log_match(self,f,reg):
log_result='------------------------'+f+'------------------------'+'\n'
fo=open(f,'r')
line=fo.readline()
rp=re.compile(reg)
while line!='':
log_match=rp.match(line)
if log_match:
log_result+='\n'+log_match.group()
line=fo.readline()
return log_result

if __name__=='__main__':
ds=Log()

主控节点master.py

复制代码 代码如下:
import socket
class SlvCluster(object):
ip_list=['127.0.0.1']
def __init__(self,reg):
for ip in self.ip_list:
self.single_slv(ip,reg)
def single_slv(self,slv_ip,reg):
s=socket.socket(socket.AF_INET,socket.SOCK_STREAM)
s.connect((slv_ip,3333))
s.sendall(reg)
print '-----------------------'+slv_ip+'--------------------------'
print s.recv(102400)
s.close()
if __name__=='__main__':
reg=raw_input('Input the regular expression:')
print '-----------Regular Expression: '+reg+'-----------------'
sc=SlvCluster(reg)

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章