一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - Java實時監控日志文件并輸出的方法詳解

Java實時監控日志文件并輸出的方法詳解

2020-11-20 10:24sunnylocus Java教程

這篇文章主要給大家介紹了關于Java實時監控日志文件并輸出的方法,文中通過示例代碼介紹的非常詳細,對大家具有一定的參考學習價值,需要的朋友們下面跟著小編一起來學習學習吧。

前言

最近有一個銀行數據漂白系統,要求操作人員在頁面調用遠端Linux服務器的shell,并將shell輸出的信息保存到一個日志文件,前臺頁面要實時顯示日志文件的內容.這個問題難點在于如何判斷哪些數據是新增加的,通過查看JDK 的幫助文檔,

java.io.RandomAccessFile可以解決這個問題.為了模擬這個問題,編寫LogSvr和 LogView類,LogSvr不斷向mock.log日志文件寫數據,而 LogView則實時輸出日志變化部分的數據.

代碼1:日志產生類

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
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;
/**
 *<p>title: 日志服務器</p>
 *<p>Description: 模擬日志服務器</p>
 *<p>CopyRight: CopyRight (c) 2010</p>
 *<p>Company: 99bill.com</p>
 *<p>Create date: 2010-6-18</P>
 *@author Tank Zhang<[email protected]>
 *@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:顯示日志的類

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
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秒鐘讀一次,如果數據有變化則輸出變化的部分.

結果輸出:

?
1
2
3
4
5
6
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"))) ,就會正常顯示中文.

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對服務器之家的支持。

原文鏈接:http://sunnylocus.iteye.com/blog/694666

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 毛片在线免费视频 | 美女脱得一二净无内裤全身的照片 | 放荡的女老板bd中文字幕 | 嫩草影院永久在线播放 | 好男人资源免费观看 | 日本精品人妖shemale人妖 | 国产啪精品视频网给免丝袜 | 日韩大片免费看 | 国产亚洲精品自在线亚洲情侣 | 日本精品一区二区在线播放 | 亚洲国产成人精品 | 欧美成人中文字幕 | 国产欧美另类 | 亚洲va在线va天堂va偷拍 | 国内永久第一免费福利视频 | 亚洲国产精品久久无套麻豆 | 成人啪啪漫画全文阅读 | 欧美日韩在线一区二区三区 | 强制高h | 成人福利网站 | 欧洲美女女同 | 国产午夜成人无码免费看 | 国产成人精品999在线 | 日本在线观看免费观看完整版 | 小草观看免费高清视频 | 欧美精品一区二区三区免费 | 秋霞午夜伦午夜高清福利片 | 亚色九九九全国免费视频 | 精品91自产拍在线观看99re | re99| 亚洲AV无码国产精品色午夜情 | 美女逼逼喷水 | 青青青手机视频 | 国产a不卡片精品免费观看 国产aaa伦理片 | 三年片韩国在线 | 暖暖在线精品日本中文 | 欧美多gayxxxx| 国产乱子伦在线观看不卡 | 亚洲国产精品久久久久久 | 国产成人精品一区二三区在线观看 | 成人毛片高清视频观看 |