稍微成型点的用WEBSOCKET实现的实时日志LOG输出

难的是还是就地用JS显示出来相关的发布进度。

还好,花了一下午实现了。

可以移植到项目中去罗。。。

websocket.py:

import tornado.ioloop
import tornado.web
import tornado.websocket
from tornado.ioloop import IOLoop
from datetime import timedelta
import time
import os
import sys
import tornado.httpserver

class WebSocketHandler(tornado.websocket.WebSocketHandler):
    file_content = ""
    filename = "test.log"

    def open(self):
        pass

    def update_client(self):
        self.write_message(self._read_file(self.filename))

    def on_message(self, message):
        print message
        self.filename = message.split(‘-‘)[1]
        self.update_client()

    def on_close(self):
        pass

    def _read_file(self, filename):
        print filename, ‘=================‘
        with open(filename) as f:
            content = f.read()
            content_diff = content.replace(self.file_content, ‘‘)
            self.file_content = content
            return content_diff

class IndexPageHandler(tornado.web.RequestHandler):
    def get(self):
        self.render("websockets.html")

class Application(tornado.web.Application):
    def __init__(self):
        handlers = [
            (r‘/‘, IndexPageHandler),
            (r‘/ws‘, WebSocketHandler)
        ]
        settings = dict(
            template_path=os.path.join(os.path.dirname(__file__), "templates"),
            static_path=os.path.join(os.path.dirname(__file__), "static"),
            debug=True
        )
        tornado.web.Application.__init__(self, handlers, **settings)

if __name__ == ‘__main__‘:
    ws_app = Application()
    server = tornado.httpserver.HTTPServer(ws_app)
    server.listen(8888)
    tornado.ioloop.IOLoop.instance().start()

websocket.html:

<title>Tornado WebSockets</title>

<link rel="stylesheet" href="/static/uikit-2.22.0/css/uikit.min.css" />
<link rel="stylesheet" href="/static/uikit-2.22.0/css/components/progress.gradient.css"/>
<link rel="stylesheet" href="/static/css/radialindicator.css"/>
<script src="/static/js/jquery-1.11.2.js"></script>
<script src="/static/js/radialIndicator.min.js"></script>
<script src="/static/uikit-2.22.0/js/uikit.js"></script>
<script src="/static/uikit-2.22.0/js/components/sticky.min.js"></script>

<div id="procPer"></div>
<br>
<textarea id="logoutput" cols="100" rows="30" placeholder="日志输出" style="background:#000; color:#FFF" >...</textarea>
<br>
<a href="javascript:void(0);" onClick="wsFunc(‘stop‘, ‘DEMO‘)"><span id="actionSpn"  class="uk-button">停止刷新</span></a>
<script>

function GetRequest() {
       var url = location.search;
       var theRequest = new Object();
       if (url.indexOf("?") != -1) {
          var str = url.substr(1);
          strs = str.split("&");
          for(var i = 0; i < strs.length; i ++) {
             theRequest[strs[i].split("=")[0]]=unescape(strs[i].split("=")[1]);
          }
       }
       return theRequest;
    }
var Request = new Object();
Request = GetRequest();
console.log(Request);
var dev_version = Request[‘dev_version‘];
console.log(dev_version);

wsFunc("refresh", dev_version);

function wsFunc(msg, dev_version) {
        var messageContainer = document.getElementById("logoutput");
        var percentContainer = document.getElementById("procPer");

        if ("WebSocket" in window) {
            var ws = new WebSocket("ws://localhost:8888/ws");
            ws.onopen = function() {};
            ws.onmessage = function (evt) {
                messageContainer.innerHTML += evt.data;
                var d = messageContainer.scrollHeight;
                messageContainer.scrollTop = d;
                var pattern = /progress/gi;
                var ans = messageContainer.innerHTML.match(/\w+.\w+,\sdeploy\sprogress\s\d+/g);
                var dic = new Array();
                for (item in ans){
                    dic_key = ans[item].split(‘,‘)[0];
                    dic_value = ans[item].split(‘,‘)[1].split(" ")[3];
                    dic[dic_key] = dic_value;
                }
                for (key in dic) {
                    if(document.getElementById(key + "label") == undefined){
                        var span=document.createElement(‘span‘);
                        span.setAttribute("id", key + "label");
                        percentContainer.appendChild(span);
                        document.getElementById(key + "label").innerHTML = key
                    }
                    if(document.getElementById(key) == undefined){
                        var span=document.createElement(‘span‘);
                        span.setAttribute("id", key);
                        percentContainer.appendChild(span);
                        //document.getElementById(key).innerHTML =dic[key];
                        $(span).radialIndicator({
                                barColor: {
                                    10: ‘#0000FF‘,
                                    70: ‘#0000FF‘,
                                    90: ‘#0000FF‘,
                                    100: ‘#33CC33‘
                                },
                                radius: 25,
                                barWidth: 3,
                                initValue: dic[key],
                                roundCorner : true,
                                percentage: true
                    });
                        radialObj =$(span).data(‘radialIndicator‘);

                    }
                    radialObj.animate(dic[key]);

          
                    console.log(key, dic[key]);
                }

            };
            ws.onclose = function() {};
            console.log(msg);
            if (msg == "refresh") {
                sh=setInterval(function(){
                ws.send(msg+"-"+dev_version, function(){})}
                ,2000);

            } else {
                clearInterval(sh);
                document.getElementById("actionSpn").innerText = ‘OutPut‘;
            }
        } else {
            messageContainer.innerHTML += "此浏览器不支持websocket!";
        }
      }

</script>

样子:

时间: 2024-10-12 13:03:23

稍微成型点的用WEBSOCKET实现的实时日志LOG输出的相关文章

Java用WebSocket + tail命令实现Web实时日志

在Linux操作系统中,经常需要查看日志文件的实时输出内容,通常会使用tail -f或者tailf命令.查看实时日志可能会需要首先SSH连上Linux主机,步骤很麻烦不说,如果是生产环境的服务器,可能还会控制各种权限.基于Web的实时日志可以解决这个问题. 由于传统的HTTP协议是请求/响应模式,而实时日志需要不定时的持续的输出,由服务器主动推送给客户端浏览器.所以这里使用的是HTML5的WebSocket协议. 按照惯例,先上图: Java后台 JSR 356是Java实现WebSocket的

Vue+WebSocket 实现页面实时刷新长连接

Vue+WebSocket 实现页面实时刷新长连接:https://www.cnblogs.com/fmixue/p/9110074.html 看完让你彻底搞懂Websocket原理:https://blog.csdn.net/frank_good/article/details/50856585 webSocket长连接实现demo(场景:扫码自动跳转登录,或者替换轮询):https://blog.csdn.net/GordoHu/article/details/78293803 原文地址:h

websocket+node.js 实时聊天系统问题咨询

1.最近新学习websocket.做了一个实时聊天.用Node.js搭建的服务:serevr.js. 两个相互通信页面:client.html 和server.html 但是就是有很多问题,想让知道的人帮我看看哈: 我先把代码贴出来: server.js:  var ws=require("nodejs-websocket");  console.log("开始建立连接...");  var str1=null,str2=null, clientReady=fals

基于python的websocket开发,tomcat日志web页面实时打印监控案例

web socket 接收器:webSocket.py 相关依赖 # pip install bottle gevent gevent-websocket argparse from bottle import request, Bottle, abort from geventwebsocket import WebSocketError from gevent.pywsgi import WSGIServer from geventwebsocket.handler import WebSo

[PHP] php作为websocket的客户端实时读取推送日志文件

首先要使用composer来下载一个第三方扩展就可以实现php的websocket客户端,直接在当前目录生成下composer.json文件就可以了composer require textalk/websocket require('vendor/autoload.php'); use WebSocket\Client; $client = new Client("ws://echo.websocket.org/"); $client->send("Hello Web

nginx,tornado,websocket,supervisord配置成型

因为要上生产环境,所以配置还是专业一些比较好. nginx.conf upstream websocket_host { server 127.0.0.1:9527; } location /ws_log { proxy_redirect off; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header Host $

python与html5 websocket开发聊天对话窗

1.下载必须的包 https://github.com/Pithikos/python-websocket-server,解压缩并把文件夹名'python-websocket-server-master' 改为'websocket' 2.websocket文件夹内只保留websocket_server文件夹和server.py 3.稍微修改server.py的源码 1 from websocket_server import WebsocketServer 2 3 # Called for ev

java SSM框架 多数据源 代码生成器 websocket即时通讯 shiro redis 后台框架源码

获取[下载地址]   QQ: 313596790官网 http://www.fhadmin.org/A 调用摄像头拍照,自定义裁剪编辑头像,头像图片色度调节B 集成代码生成器 [正反双向](单表.主表.明细表.树形表,快速开发利器)+快速表单构建器 freemaker模版技术 ,0个代码不用写,生成完整的一个模块,带页面.建表sql脚本,处理类,service等完整模块C 集成阿里巴巴数据库连接池druid  数据库连接池  阿里巴巴的 druid.Druid在监控.可扩展性.稳定性和性能方面都

使用 HTML5 WebSocket 构建实时 Web 应用

作为下一代的 Web 标准,HTML5 拥有许多引人注目的新特性,如 Canvas.本地存储.多媒体编程接口.WebSocket 等等.这其中有"Web 的 TCP "之称的 WebSocket 格外吸引开发人员的注意.WebSocket 的出现使得浏览器提供对 Socket 的支持成为可能,从而在浏览器和服务器之间提供了一个基于 TCP 连接的双向通道.Web 开发人员可以非常方便地使用 WebSocket 构建实时 web 应用,开发人员的手中从此又多了一柄神兵利器.本文首先介绍