程序Log实时监控 – python + websocket

需求构思: 在linux下常常需要查看程序的实时输出,我们用 tail -f logfile 即可在console下实现此需求。现在要拓宽应用: 想在web browser下查看程序(以及日志)的实时输出(也就是程序Log的Web实时监控)。

python

架构构思

因为考虑了“实时"这个需求,所以初步定位为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负责显示接受到的实时数据

 

python代码

JS代码

html代码

演示说明

Server运行tcpdump,用户在浏览器查看运行的实时数据。

项目地址

https://github.com/suxianbaozi/pywebsocketserver

或者本站下载:[file:http://www.ttlsa.com/wp-content/uploads/2015/09/pywebsocketserver-master.zip]

发表评论

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

目前评论:5   其中:访客  5   博主  0

  1. Emma 0

    我喜欢代码简洁易读,服务稳定的推送服务,前段时间研究了一下goeasy,java后台推送只需要两行代码, js前端推送也只需要3,4行,而且文档齐全,还提供了后台查询信息收发情况,所以我觉得GoEasy推送服务是个不错的选择。官网: https://goeasy.io/

  2. 帅章 0

    非常好。。。

  3. 无影风随 0

    这儿有个界面更好看的,原理差不多,http://logio.org/

    • jone 1

      @无影风随 这个logio我在github上下载下来,感觉缺文件,跑不起来啊,你弄好了吗?

  4. zzzZ 5

    支持白开大神,掌声 :wink: