一、前言:在Linux下有使用tail命令

在Commons-io中也提供这种方法

二、他采用的是线程方式来监控文件内容的变化

1、Tailer类(采用线程的方式进行文件的内容变法)

2、TailerListener类

3、TailerListenerAdapter类,该类是集成了TailerListener的实现空的接口方式

三、测试使用代码

  1. package com.hadoop.leran.commons.io;
  2. import org.apache.commons.io.FileUtils;
  3. import org.apache.commons.io.IOUtils;
  4. import org.apache.commons.io.input.Tailer;
  5. import org.apache.commons.io.input.TailerListenerAdapter;
  6. import java.io.File;
  7. public class TailerTest {
  8. public static void main(String []args) throws Exception{
  9. TailerTest tailerTest = new TailerTest();
  10. tailerTest.test();
  11. boolean flag = true;
  12. File file = new File("C:/Users/hadoop/Desktop/test/1.txt");
  13. while(flag){
  14. Thread.sleep(1000);
  15. FileUtils.write(file,""+System.currentTimeMillis()+ IOUtils.LINE_SEPARATOR,true);
  16. }
  17. }
  18. public void test() throws Exception{
  19. File file = new File("C:/Users/hadoop/Desktop/test/1.txt");
  20. FileUtils.touch(file);
  21. Tailer tailer = new Tailer(file,new TailerListenerAdapter(){
  22. @Override
  23. public void fileNotFound() {  //文件没有找到
  24. System.out.println("文件没有找到");
  25. super.fileNotFound();
  26. }
  27. @Override
  28. public void fileRotated() {  //文件被外部的输入流改变
  29. System.out.println("文件rotated");
  30. super.fileRotated();
  31. }
  32. @Override
  33. public void handle(String line) { //增加的文件的内容
  34. System.out.println("文件line:"+line);
  35. super.handle(line);
  36. }
  37. @Override
  38. public void handle(Exception ex) {
  39. ex.printStackTrace();
  40. super.handle(ex);
  41. }
  42. },4000,true);
  43. new Thread(tailer).start();
  44. }
  45. }

一、前言:

使用Commons-io的monitor下的相关类可以处理对文件进行监控,它采用的是观察者模式来实现的

1、可以监控文件夹的创建、删除和修改

2、可以监控文件的创建、删除和修改

3、采用的是观察者模式来实现的

4、采用线程去定时去刷现检测文件的变化情况

二、代码分析

(一)、FileAlterationListener分析,提供了检测文件夹和文件的变化回调函数的接口,观察模式回调的接口

1、提供了文件夹的创建、删除和修改的接口

2、提供了文件的创建、删除和修改的接口

(二)、FileAlterationListenerAdaptor实现了FileAlterationListener的接口,只是空的实现,可以根据用户的使用情况来处理文件的变化

(三)、FileAlterationObserver重点的观察者模式的类

1、提供对某路径下文件监控

2、使用FileFilter来控制对那些文件进行监控,在实际的使用情况是使用FileFilterUtils来控制,他设置了添加一系列的FileFilter

3、IOCase可以用来对系统的判断,使用是Unix和Windows进行不同的处理,Unix支持文件名的大小写,Windows不区分文件的大小写

(四)、FileAlterationMonitor类

1、它继承了Runnable接口

2、它检测文件的过程是采用一个线程去不停的进行文件的检测

3、精髓之处,文件的内容的改变处理过程

对于文件的变化有点不太准确,只是判断文件名、文件大小、文件的修改日期来判断

( 五)、FileEntry类

1、提供了文件夹和文件夹下文件的层级结构

2、提供了文件是否改变了,采用了备忘录模式(形式上有点,没有很严格的控制),将上一次的状态进行保存,在比较的时候重新读取新的状态,

比较完后备忘录重新将新的状态进行保存。

(六)、Common-io中提供一序列的文件的FileFilter类,使用是可以看情况查看源代码

1、提供了FileFilterUtils来提供添加一些列的FileFilter

2、添加一序列的FileFilter的实现是使用AndFileFilter来实现的

3、提供相识的OrFileFilter和NotFileFilter

三、读源代码的测试代码

  1. package com.hadoop.leran.commons.io;
  2. import org.apache.commons.io.FileUtils;
  3. import org.apache.commons.io.filefilter.FileFilterUtils;
  4. import org.apache.commons.io.filefilter.IOFileFilter;
  5. import org.apache.commons.io.monitor.FileAlterationListenerAdaptor;
  6. import org.apache.commons.io.monitor.FileAlterationMonitor;
  7. import org.apache.commons.io.monitor.FileAlterationObserver;
  8. import java.io.File;
  9. import java.io.FileFilter;
  10. public class FileAlterationObserverTest {
  11. public static void main(String []args) throws Exception{
  12. FileAlterationObserverTest fileAlter = new FileAlterationObserverTest();
  13. fileAlter.test();
  14. String filePath = "C:/Users/hadoop/Desktop/test/";
  15. File file = new File(filePath);
  16. FileUtils.deleteDirectory(file);
  17. file.mkdirs();
  18. //File txtFile = new File(filePath+File.separator+System.currentTimeMillis()+".txt");
  19. //FileUtils.touch(txtFile);
  20. //        File txtFile = new File("C:/Users/hadoop/Desktop/test/1401629335839.txt");
  21. //        txtFile.deleteOnExit();
  22. //        FileUtils.touch(txtFile);
  23. //        File newFile = new File(filePath+File.separator+System.currentTimeMillis());
  24. //        newFile.mkdirs();
  25. boolean flag = true;
  26. while(flag){
  27. /***测试文件的变化代码*/
  28. //            File newFileTxt = new File(filePath+File.separator+System.currentTimeMillis()+".txt");
  29. //            FileUtils.touch(newFileTxt);
  30. //            Thread.sleep(2000);
  31. //            FileUtils.write(newFileTxt,"1",true);
  32. //            Thread.sleep(2000);
  33. //            newFileTxt.delete();
  34. /****测试文件夹的变化代码***/
  35. File newFile = new File(filePath+File.separator+System.currentTimeMillis());
  36. newFile.mkdir();
  37. Thread.sleep(2000);
  38. File newFileTxt = new File(newFile.getAbsolutePath()+File.separator+System.currentTimeMillis()+".txt");
  39. FileUtils.touch(newFileTxt);
  40. }
  41. }
  42. public void test() throws Exception{
  43. String filePath = "C:/Users/hadoop/Desktop/test/";
  44. FileFilter filter = FileFilterUtils.and(new MyFileFilter());
  45. FileAlterationObserver fileAlterationObserver = new FileAlterationObserver(filePath,filter);
  46. fileAlterationObserver.addListener(new FileAlterationListenerAdaptor() {
  47. @Override
  48. public void onStart(FileAlterationObserver observer) {
  49. System.out.println("start on file");
  50. super.onStart(observer);
  51. }
  52. @Override
  53. public void onDirectoryDelete(File directory) {
  54. System.out.println("delete file");
  55. super.onDirectoryDelete(directory);
  56. }
  57. @Override
  58. public void onDirectoryCreate(File directory) {
  59. System.out.println("create file");
  60. super.onDirectoryCreate(directory);
  61. }
  62. @Override
  63. public void onDirectoryChange(File directory) {
  64. System.out.println("change file");
  65. super.onDirectoryChange(directory);
  66. }
  67. @Override
  68. public void onFileCreate(File file) {
  69. System.out.println("file create");
  70. super.onFileCreate(file);
  71. }
  72. @Override
  73. public void onFileDelete(File file) {
  74. System.out.println("file delete");
  75. super.onFileDelete(file);
  76. }
  77. @Override
  78. public void onFileChange(File file) {
  79. System.out.println("file change");
  80. super.onFileChange(file);
  81. }
  82. });
  83. FileAlterationMonitor fileAlterationMonitor =  new FileAlterationMonitor(1000);
  84. fileAlterationMonitor.addObserver(fileAlterationObserver);
  85. fileAlterationMonitor.start();
  86. }
  87. }
  88. /***
  89. * 自定义的文件过滤器
  90. */
  91. class MyFileFilter implements IOFileFilter {
  92. @Override
  93. public boolean accept(File file) {
  94. //        String extension = FilenameUtils.getExtension(file.getAbsolutePath());
  95. //        if(extension!=null&&extension.equals("txt"))
  96. //           return true;
  97. //        return false;
  98. return true;
  99. }
  100. @Override
  101. public boolean accept(File dir, String name) {
  102. //System.out.println("dir:"+dir+"----->"+name);
  103. return true;
  104. }
  105. }

出处:http://blog.csdn.net/xiaoyezi1001/article/details/28095281

工具类commons-io的Tailer用来监控文件的更多相关文章

  1. Java常用工具类之IO流工具类

    package com.wazn.learn.util; import java.io.Closeable; import java.io.IOException; /** * IO流工具类 * * ...

  2. Android 常用工具类之SPUtil,可以修改默认sp文件的路径

    参考: 1. 利用Java反射机制改变SharedPreferences存储路径    Singleton1900 2. Android快速开发系列 10个常用工具类 Hongyang import ...

  3. 分享一个FileUtil工具类,基本满足web开发中的文件上传,单个文件下载,多个文件下载的需求

    获取该FileUtil工具类具体演示,公众号内回复fileutil20200501即可. package com.example.demo.util; import javax.servlet.htt ...

  4. 【工具类】如何通过代码安装一个apk文件

    <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android=&quo ...

  5. 项目实战工具类(二):ZipUtils(压缩/解压缩文件相关)

    import android.content.Context; import android.util.Log; import java.io.File; import java.io.FileInp ...

  6. Commons IO方便读写文件的工具类

    Commons IO是apache的一个开源的工具包,封装了IO操作的相关类,使用Commons IO可以很方便的读写文件,url源代码等. 普通地读取一个网页的源代码的代码可能如下 InputStr ...

  7. ftp上传或下载文件工具类

    FtpTransferUtil.java工具类,向ftp上传或下载文件: package utils; import java.io.File; import java.io.FileOutputSt ...

  8. Java IO流学习总结七:Commons IO 2.5-FileUtils

    在上面的几篇文章中,介绍了IO的常规用法,今天介绍 Commons IO 框架的使用. Commons IO简介 Apache Commons IO是Apache基金会创建并维护的Java函数库.它提 ...

  9. 常用高效 Java 工具类总结

    一.前言 在Java中,工具类定义了一组公共方法,这篇文章将介绍Java中使用最频繁及最通用的Java工具类.以下工具类.方法按使用流行度排名,参考数据来源于Github上随机选取的5万个开源项目源码 ...

随机推荐

  1. SpringMVC04 很杂很重要(注解,乱码处理,通配符,域属性调用,校正参数名称,访问路径,请求、响应携带参数,请求方法)

    1.导入架包 <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3 ...

  2. Sql server 数据库的备份和还原数据库提示“ 加载的介质已格式化为支持 1 个介质簇,但根据指定的备份设备,应支持 2 个介质簇”

     数据库备份和还原总结 在 "M:\2017-Pro\company\other\databak_2014-10\anquanbaowei_db_201704300200.BAK" ...

  3. js重载的实现

    在JavaScript高级程序设计书中看到 ECMAScript函数中不能想传统意义上那样实现重载.而在其他语句中(Java)中,可以为一个函数编写两个定义,只要两个定义的签名(接受的参 数的类型和数 ...

  4. vue-cli之脚手架

    一.创建VUE项目 npm install vue-cli -g vue init webpack myprject cd myproject npm run dev 补充: 组件:它是可扩展的htm ...

  5. Visual Studio Code的快捷键和相关技巧

    编辑相关的键盘快捷键: Shift + Alt + F = 格式化代码(似乎不好用) Ctrl + Shift + Enter = 在上一行新建空行并转到上一行 Ctrl + K,Ctrl + C = ...

  6. Oracle 11g服务详细介绍

    按照windows 7 64位 安装oracle 11g R2中的方法成功安装Oracle 11g后,共有7个服务,这七个服务的含义分别为: 1. Oracle ORCL VSS Writer Ser ...

  7. [转]Git之忽略文件(ignore file)

    原文链接:http://blog.csdn.net/benkaoya/article/details/7932370 .gitignore 配置文件用于配置不需要加入版本管理的文件,配置好该文件可以为 ...

  8. Java Annotation使用详解

    Java  Annotation是JDK5.0引入的一种注释机制.它与注释有一定区别,可以理解为代码上的特殊标记,通过这些标记我们可以在编译,类加载,运行等程序类的生命周期内被读取.执行相应的处理.通 ...

  9. hadoop2.4 WARN util.NativeCodeLoader: Unable to load native-hadoop library for your platform... using builtin-java classes where applicable

    在Ubuntu上安装完hadoop2.4以后,使用以下命令: hadoop fs -ls // :: WARN util.NativeCodeLoader: Unable to load native ...

  10. linux 命令——34 du(转)

    Linux du命令也是查看使用空间的,但是与df命令不同的是Linux du命令是对文件和目录磁盘使用的空间的查看,还是和df命令有一些区别的. 1.命令格式: du [选项][文件] 2.命令功能 ...