前言

最近有一个银行数据漂白系统,要求操作人员在页面调用远端Linux服务器的shell,并将shell输出的信息保存到一个日志文件,前台页面要实时显示日志文件的内容.这个问题难点在于如何判断哪些数据是新增加的,通过查看JDK 的帮助文档,

java.io.RandomAccessFile可以解决这个问题.为了模拟这个问题,编写LogSvr和 LogView类,LogSvr不断向mock.log日志文件写数据,而 LogView则实时输出日志变化部分的数据.

代码1:日志产生类

package com.bill99.seashell.domain.svr;

import java.io.File;

import java.io.FileWriter;

import java.io.IOException;

import java.io.Writer;

import java.text.SimpleDateFormat;

import java.util.Date;

import java.util.concurrent.Executors;

import java.util.concurrent.ScheduledExecutorService;

import java.util.concurrent.TimeUnit;

/**

*

title: 日志服务器

*

Description: 模拟日志服务器

*

CopyRight: CopyRight (c) 2010

*

Company: 99bill.com

*

Create date: 2010-6-18

*@author Tank Zhang

*@version v0.1 2010-6-18

*/

public class LogSvr {

private SimpleDateFormat dateFormat =

new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");

/**

* 将信息记录到日志文件

* @param logFile 日志文件

* @param mesInfo 信息

* @throws IOException

*/

public void logMsg(File logFile,String mesInfo) throws IOException{

if(logFile == null) {

throw new IllegalStateException("logFile can not be null!");

}

Writer txtWriter = new FileWriter(logFile,true);

txtWriter.write(dateFormat.format(new Date()) +"\t"+mesInfo+"\n");

txtWriter.flush();

}

public static void main(String[] args) throws Exception{

final LogSvr logSvr = new LogSvr();

final File tmpLogFile = new File("mock.log");

if(!tmpLogFile.exists()) {

tmpLogFile.createNewFile();

}

//启动一个线程每5秒钟向日志文件写一次数据

ScheduledExecutorService exec =

Executors.newScheduledThreadPool(1);

exec.scheduleWithFixedDelay(new Runnable(){

public void run() {

try {

logSvr.logMsg(tmpLogFile, " 99bill test !");

} catch (IOException e) {

throw new RuntimeException(e);

}

}

}, 0, 5, TimeUnit.SECONDS);

}

}

代码2:显示日志的类

package com.bill99.seashell.domain.client;

import java.io.File;

import java.io.IOException;

import java.io.RandomAccessFile;

import java.util.concurrent.Executors;

import java.util.concurrent.ScheduledExecutorService;

import java.util.concurrent.TimeUnit;

public class LogView {

private long lastTimeFileSize = 0; //上次文件大小

/**

* 实时输出日志信息

* @param logFile 日志文件

* @throws IOException

*/

public void realtimeShowLog(File logFile) throws IOException{

//指定文件可读可写

final RandomAccessFile randomFile = new RandomAccessFile(logFile,"rw");

//启动一个线程每10秒钟读取新增的日志信息

ScheduledExecutorService exec =

Executors.newScheduledThreadPool(1);

exec.scheduleWithFixedDelay(new Runnable(){

public void run() {

try {

//获得变化部分的

randomFile.seek(lastTimeFileSize);

String tmp = "";

while( (tmp = randomFile.readLine())!= null) {

System.out.println(new String(tmp.getBytes("ISO8859-1")));

}

lastTimeFileSize = randomFile.length();

} catch (IOException e) {

throw new RuntimeException(e);

}

}

}, 0, 1, TimeUnit.SECONDS);

}

public static void main(String[] args) throws Exception {

LogView view = new LogView();

final File tmpLogFile = new File("mock.log");

view.realtimeShowLog(tmpLogFile);

}

}

执行LogSvr类,LogSvr类会启动一个线程,每5秒钟向mock.log日志文件写一次数据,然后再执行LogView类,LogView每隔1秒钟读一次,如果数据有变化则输出变化的部分.

结果输出:

2010-06-19 17:25:54 99bill test !

2010-06-19 17:25:59 99bill test !

2010-06-19 17:26:04 99bill test !

2010-06-19 17:26:09 99bill test !

2010-06-19 17:26:14 99bill test !

2010-06-19 17:26:19 99bill test !

PS:

代码修改过, 有朋友下载了我的代码,说如果是中文会乱码,将日志输出类的第30行的代码 System.out.println(tmp)改成 System.out.println(new String(tmp.getBytes("ISO8859-1"))) ,就会正常显示中文.

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。

java读取日志_Java实时监控日志文件并输出的方法详解相关推荐

  1. java解析日志数据_Java实时监控日志文件并输出的方法详解

    Java实时监控日志文件并输出的方法详解 想在前台显示数据同步过程中产生的日志文件,在网上找到解决方案,做了代码测试好用.这里做个记录 java.io.RandomAccessFile可以解决同时向文 ...

  2. java spring mvc 上传_Java Spring MVC 上传下载文件配置及controller方法详解

    下载: 1.在spring-mvc中配置(用于100M以下的文件下载) 下载文件代码 @RequestMapping("/file/{name.rp}") public Respo ...

  3. python统计csv行数_对Python 多线程统计所有csv文件的行数方法详解

    如下所示: #统计某文件夹下的所有csv文件的行数(多线程) import threading import csv import os class MyThreadLine(threading.Th ...

  4. python对文件的处理_python文件处理fileinput使用方法详解

    这篇文章主要介绍了python文件处理fileinput使用方法详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 一.介绍 fileinput模块 ...

  5. python fileinput_python文件处理fileinput使用方法详解

    这篇文章主要介绍了python文件处理fileinput使用方法详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 一.介绍 fileinput模块 ...

  6. python修改xml标签的值_对python修改xml文件的节点值方法详解

    这是我的xml文件结构 <?xml version='1.0' encoding='utf-8'?> JPEGImages train_2018-05-08_1000.jpg D:\all ...

  7. 【文件md5值查看方法详解】:如何获取文件的唯一标识?

    [文件md5值查看方法详解]:如何获取文件的唯一标识? 在日常工作中,我们经常需要检查文件是否被篡改或者验证文件的完整性.而文件的MD5值就是一个很好的选择,因为它可以作为文件的唯一标识.那么,如何获 ...

  8. java中flush函数作用_Java语言中flush()函数作用及使用方法详解

    最近在学习io流,发现每次都会出现flush()函数,查了一下其作用,起作用主要如下 //------–flush()的作用--------– 笼统且错误的回答: 缓冲区中的数据保存直到缓冲区满后才写 ...

  9. java 查询sql语句_java执行SQL语句实现查询的通用方法详解

    完成sql查询 并将查询结果放入vector容器,以便其他程序使用 /* * 执行sql查询语句 */ public static vector executequery(class clazz, s ...

最新文章

  1. Weblogic 集群部署说明 --转
  2. 南京:第三届软博会“外包”将唱主角
  3. 系统搭建遇到问题3:Ubuntu问题造成网卡名称异常导致Vivado绑定网卡地址的Lic无法正常工作(JESD)...
  4. 9个提高代码运行效率的小技巧你知道几个?
  5. 使用c++为node.js扩展模块
  6. .net 获取xml里面的值_Java-XML技术
  7. 2018-2019-2 20165312《网络攻防技术》Exp7 网络欺诈防范
  8. 在TensorFlow中实现文本分类的卷积神经网络
  9. 组合索引怎么应该怎么选取引导列?
  10. 使用webgl(three.js)搭建一个3D智慧园区、3D建筑,3D消防模拟,web版3D,bim管理系统——第四课(炫酷版一)...
  11. Windows PowerShell命令大全
  12. 曲线运动与万有引力公式_高中物理公式大全
  13. 周杰伦2011所有歌曲完整版无删节全正版打包免费下载 http://115.com/file/bhr
  14. 扫呗--扫码付支付问题
  15. SpringSecurity前后端分离02(授权)
  16. 通俗易懂的Kafka零拷贝机制
  17. 潜望丨蔚来发布了喜忧参半的财报 与特斯拉的较量刚刚开始
  18. 安装Win11找不到固态硬盘如何解决?
  19. ML-Agents案例之蠕虫
  20. PS cc 2018分享

热门文章

  1. reg51.h和reg52.h头文件
  2. C语言求一个数的倒数的平方根近似值
  3. Linux Socket C语言网络编程:Select Socket
  4. pkg-config --cflags --libs
  5. python基础(笔记)
  6. 引入jQuery的src设置
  7. delete index mysql_为什么MySQL不建议delete删除数据「心得分享」
  8. python快速运算符_Python基本运算符
  9. php短链接api,PHP通过调用新浪API生成t.cn格式短网址链接的方法详解
  10. 2021年终总结2022未来展望——人生天地之间,若白驹过隙,忽然而已