微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

java – jsp查看日志文件(如“web tail -f”)

如何实现包含文本区域的jsp站点,该文本区域显示(tomcat)服务器上的日志文件自动刷新.

我认为刷新很容易使用setTimeout轮询到服务器并发送ajax请求.但问题是如何监视服务器上的文件(它是一个Log4J日志文件 – 也许我可以使用自己的appender?)进行更改并在ajax请求到达时仅发送更改的行?

我不知道如何检测日志中更改的行…

解决方法

ajax和每隔几秒轮询服务器是一个好主意,但使用 comet/ server-push/ websocket会更有效,你不会遇到任何延迟.

关于服务器端,您有几个选择:

>每次用户请求新数据时打开文件,转到最后并发送最后一行.您需要以某种方式指示最后一次发送的行数据,以避免多次发送相同的行或丢失其中的一些行.使用AJAX调用的时间戳参数说:给我后面的所有日志行…

解决方案效率很低,会产生大量I / O流量
>将开放流保存到每个客户端的日志文件中,当客户端要求新行时,尽可能多地阅读(当然不会阻塞).

更好,但不会很好地扩展(太多的打开文件,我来了)
>编写自定义log4j appender并将最新日志保存在内存中.当客户端询问时,只需转储此缓冲区的内容(对时间戳应用的限制相同)

非常强大,但要注意内存使用!
>最后考虑使用现成的tools like psi-probe提供开箱即用的功能

psi-probe http://psi-probe.googlecode.com/svn/wiki/Features/log-tail.png

也可以看看:

> Java web application that can stream the content of an arbitrary file to the browser (live tail)
> tail -f in a webbrowser

原文地址:https://www.jb51.cc/java/126212.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐