- 需求构思: 在linux下常常需要查看程序的实时输出,我们用 tail -f logfile 即可在console下实现此需求。现在要拓宽应用: 想在web browser下查看程序(以及日志)的实时输出(也就是程序Log的Web实时监控)。
- 架构构思: 因为考虑了“实时"这个需求,所以初步定位为socket架构; 再因为是构建在web之上,属于web app,所以socket进一步细分为:web socket。初步验证: web socket的 server部分: 可选: 1)自己实现 2) Node.js 3)其他框架(i.e. pywebsocketserver), web socket的client部分: 可选: 1) firefox 16 2) chrome 3)其他浏览器
- 架构实现
- Python里的subprocess可用pipe获取数据,再开子进程获取数据行
- Server负责把上述数据行缓存后再源源不断发送到 Client
- Client负责显示接受到的实时数据
- 代码部分
# -*- coding: utf8 -*- import sys import time import threading from pywebsocketserver.server import SocketServer from pywebsocketserver.baseio import BaseIO import subprocess def tcpdump(): global g_output_log popen=subprocess.Popen(['bash','-c',"/usr/sbin/tcpdump -i eth0 -v"],stdout=subprocess.PIPE,stderr=subprocess.PIPE) pid=popen.pid print('Popen.pid:'+str(pid)) while True: line=popen.stdout.readline().strip() #line =popen.communicate() print "output:%s" %(line) g_output_log.append(line) if subprocess.Popen.poll(popen) is not None: break print('DONE') class MyIO(BaseIO): def onData(self,uid,text): self.sendData(uid,"received the message:%s"%(text,)) def onConnect(self,uid): global g_uid g_uid=uid while True: #self.sendData(uid,"testing...") if len(g_output_log) >0: log = g_output_log.pop() self.sendData(uid,log) else: time.sleep(.01) try: g_output_log=[] g_uid=None tcpdump = threading.Thread(name='tcpdump', target=tcpdump) tcpdump.start() port = sys.argv[1] except: port = 88 port = int(port) myIo = MyIO() SocketServer(port,myIo).run()
function SocketClient(ip,port,query) { var _this = this; this.socket = ''; this.uid = 0; this.sign = ''; this.connect = function() { this.socket = new WebSocket('ws://'+ip+':'+port+'/'+query); this.socket.onopen = function() { _this.onOpen() } this.socket.onmessage = function(event) { data = event.data; data = data.split("<split>") _this.uid = data[0]; _this.sign = data[1]; text = data[2]; if(text!='SETUID') { _this.onData(text); } else { _this.onRegist() } } this.socket.onclose = function(event) { _this.onClose(); }; } this.onRegist = function() { } this.onClose = function() { } this.onOpen = function() { } this.onData = function(text) { } this.sendData = function (text) { var data = this.uid+'<split>'+this.sign+'<split>'+text this.socket.send(data); } this.close = function() { this.socket.close(); } }
<html> <head> <meta http-equiv="content-type" content="text/html; charset=UTF-8"> <script src="socketclient.js"></script> </head> <body> <script> var client = new SocketClient("192.168.199.3",88,"chat"); client.connect(); client.onData = function(text) { console.log(text); element=document.getElementById("log"); if(element){ if(element.value.length >100000) { element.value=""; } element.value += (text + "\n"); element.scrollTop = element.scrollHeight; } } client.onRegist = function() { this.sendData("I am coming!"); } </script> <textarea name="log" id="log" style="font-size:12px; width:100%; height: 600px;">Tcpdump log:</textarea> </body> </html>
- 演示说明
Server运行tcpdump,用户在浏览器查看运行的实时数据。
相关推荐
python-flask框架,实时监控本地系统的cpu、内存使用率,用psutil获得系统进程信息,flask web框架,ajax局部刷新获得数据,echarts图表显示,sqlalchemy连接mysql数据库,只要把数据库连接换成自己的就可以用了
pythonpython基于图像识别的仪表实时监控系统python基于图像识别的仪表实时监控系统python基于图像识别的仪表实时监控系统python基于图像识别的仪表实时监控系统python基于图像识别的仪表实时监控系统python基于图像...
基于Python和Hadoop的图书馆实时监控系统设计与实现.pdf
目前Linux下有一些使用Python语言编写的Linux系统监控工具比如inotify-sync(文件系统安全监控软件)、glances(资源监控工具)在实际工作中,Linux系统管理员可以根据自己使用的服务器的具体情况编写一下简单实用的...
python基于图像识别的仪表实时监控系统 python;pyqt5==5.15.2;requests;opencv-python;numpy
NULL 博文链接:https://xielioo.iteye.com/blog/2287801
python+flask微信小程序订餐系统源码 python+flask微信小程序订餐系统源码python+flask微信小程序订餐系统源码 python+flask微信小程序订餐系统源码python+flask微信小程序订餐系统源码 ...
主要为大家详细介绍了python实现实时监控文件的3种方法,感兴趣的小伙伴们可以参考一下
本代码实现了用python处理svn log数据(xml格式),把Log的数据转化为一个python的数据结构,方便作更进一步数据挖掘!
毕业设计:python基于图像识别的仪表实时监控系统(源码 + 数据库)
基于python实现的linux后台日志监控小项目
1.发送端和监控脚本都放在各个服务器上,监控脚本辅助监控服务器CPU,DISK使用情况和数据库的巡检报告。 发送端负责将巡检结果传送打接受端。 2.接收端和发邮件放到外网的服务器上,负责将监控的结果以邮件方式发送...
基于web的视频实时监控系统python源码(95分以上课程大作业).zip基于web的视频实时监控系统python源码(95分以上课程大作业).zip基于web的视频实时监控系统python源码(95分以上课程大作业).zip基于web的视频实时监控...
资源分类:Python库 所属语言:Python 资源全名:concurrent_log_handler-0.9.4-py2.py3-none-any.whl 资源来源:官方 安装方法:https://lanzao.blog.csdn.net/article/details/101784059
基于python的基于图像识别的仪表实时监控系统的实现.zip 运行步骤 需要先安装Python的相关依赖:pyqt5==5.15.2,pyqt-sip==12.9.1,requests,opencv-python,numpy使用pip install 安装 第一步:创建数据库,数据库名...
基于Python的交换机实时监控系统的设计与实现.pdf
基于Python与海康SDK的工业设备视频监控系统开发.pdf
本代码是短信监控代码,可以对短信发送通道的短信进行监控,代码是用python编写
用python+flask做的简单的监控系统,能对实时的显示系统的一些状态
主要功能: 1、获取Server Name 2、获取操作系统版本信息 3、获取CPU硬件信息 4、获取内存使用信息 5、获取相关网络信息 6、获取磁盘及分区的相关信息 ... 8、获取服务器开机时间、运行时间相关信息 ...