工具类commons-io的Tailer用来监控文件


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

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

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

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

2、TailerListener类

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

三、测试使用代码

[java]view plaincopy
  1. packagecom.hadoop.leran.commons.io;
  2. importorg.apache.commons.io.FileUtils;
  3. importorg.apache.commons.io.IOUtils;
  4. importorg.apache.commons.io.input.Tailer;
  5. importorg.apache.commons.io.input.TailerListenerAdapter;
  6. importjava.io.File;
  7. publicclassTailerTest{
  8. publicstaticvoidmain(String[]args)throwsException{
  9. TailerTesttailerTest=newTailerTest();
  10. tailerTest.test();
  11. booleanflag=true;
  12. Filefile=newFile("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. publicvoidtest()throwsException{
  19. Filefile=newFile("C:/Users/hadoop/Desktop/test/1.txt");
  20. FileUtils.touch(file);
  21. Tailertailer=newTailer(file,newTailerListenerAdapter(){
  22. @Override
  23. publicvoidfileNotFound(){//文件没有找到
  24. System.out.println("文件没有找到");
  25. super.fileNotFound();
  26. }
  27. @Override
  28. publicvoidfileRotated(){//文件被外部的输入流改变
  29. System.out.println("文件rotated");
  30. super.fileRotated();
  31. }
  32. @Override
  33. publicvoidhandle(Stringline){//增加的文件的内容
  34. System.out.println("文件line:"+line);
  35. super.handle(line);
  36. }
  37. @Override
  38. publicvoidhandle(Exceptionex){
  39. ex.printStackTrace();
  40. super.handle(ex);
  41. }
  42. },4000,true);
  43. newThread(tailer).start();
  44. }
  45. }

工具类commons-io的文件监控

一、前言:

使用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

三、读源代码的测试代码

[java]view plaincopy
  1. packagecom.hadoop.leran.commons.io;
  2. importorg.apache.commons.io.FileUtils;
  3. importorg.apache.commons.io.filefilter.FileFilterUtils;
  4. importorg.apache.commons.io.filefilter.IOFileFilter;
  5. importorg.apache.commons.io.monitor.FileAlterationListenerAdaptor;
  6. importorg.apache.commons.io.monitor.FileAlterationMonitor;
  7. importorg.apache.commons.io.monitor.FileAlterationObserver;
  8. importjava.io.File;
  9. importjava.io.FileFilter;
  10. publicclassFileAlterationObserverTest{
  11. publicstaticvoidmain(String[]args)throwsException{
  12. FileAlterationObserverTestfileAlter=newFileAlterationObserverTest();
  13. fileAlter.test();
  14. StringfilePath="C:/Users/hadoop/Desktop/test/";
  15. Filefile=newFile(filePath);
  16. FileUtils.deleteDirectory(file);
  17. file.mkdirs();
  18. //FiletxtFile=newFile(filePath+File.separator+System.currentTimeMillis()+".txt");
  19. //FileUtils.touch(txtFile);
  20. //FiletxtFile=newFile("C:/Users/hadoop/Desktop/test/1401629335839.txt");
  21. //txtFile.deleteOnExit();
  22. //FileUtils.touch(txtFile);
  23. //FilenewFile=newFile(filePath+File.separator+System.currentTimeMillis());
  24. //newFile.mkdirs();
  25. booleanflag=true;
  26. while(flag){
  27. /***测试文件的变化代码*/
  28. //FilenewFileTxt=newFile(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. FilenewFile=newFile(filePath+File.separator+System.currentTimeMillis());
  36. newFile.mkdir();
  37. Thread.sleep(2000);
  38. FilenewFileTxt=newFile(newFile.getAbsolutePath()+File.separator+System.currentTimeMillis()+".txt");
  39. FileUtils.touch(newFileTxt);
  40. }
  41. }
  42. publicvoidtest()throwsException{
  43. StringfilePath="C:/Users/hadoop/Desktop/test/";
  44. FileFilterfilter=FileFilterUtils.and(newMyFileFilter());
  45. FileAlterationObserverfileAlterationObserver=newFileAlterationObserver(filePath,filter);
  46. fileAlterationObserver.addListener(newFileAlterationListenerAdaptor(){
  47. @Override
  48. publicvoidonStart(FileAlterationObserverobserver){
  49. System.out.println("startonfile");
  50. super.onStart(observer);
  51. }
  52. @Override
  53. publicvoidonDirectoryDelete(Filedirectory){
  54. System.out.println("deletefile");
  55. super.onDirectoryDelete(directory);
  56. }
  57. @Override
  58. publicvoidonDirectoryCreate(Filedirectory){
  59. System.out.println("createfile");
  60. super.onDirectoryCreate(directory);
  61. }
  62. @Override
  63. publicvoidonDirectoryChange(Filedirectory){
  64. System.out.println("changefile");
  65. super.onDirectoryChange(directory);
  66. }
  67. @Override
  68. publicvoidonFileCreate(Filefile){
  69. System.out.println("filecreate");
  70. super.onFileCreate(file);
  71. }
  72. @Override
  73. publicvoidonFileDelete(Filefile){
  74. System.out.println("filedelete");
  75. super.onFileDelete(file);
  76. }
  77. @Override
  78. publicvoidonFileChange(Filefile){
  79. System.out.println("filechange");
  80. super.onFileChange(file);
  81. }
  82. });
  83. FileAlterationMonitorfileAlterationMonitor=newFileAlterationMonitor(1000);
  84. fileAlterationMonitor.addObserver(fileAlterationObserver);
  85. fileAlterationMonitor.start();
  86. }
  87. }
  88. /***
  89. *自定义的文件过滤器
  90. */
  91. classMyFileFilterimplementsIOFileFilter{
  92. @Override
  93. publicbooleanaccept(Filefile){
  94. //Stringextension=FilenameUtils.getExtension(file.getAbsolutePath());
  95. //if(extension!=null&&extension.equals("txt"))
  96. //returntrue;
  97. //returnfalse;
  98. returntrue;
  99. }
  100. @Override
  101. publicbooleanaccept(Filedir,Stringname){
  102. //System.out.println("dir:"+dir+"----->"+name);
  103. returntrue;
  104. }
  105. }

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

优质内容筛选与推荐>>
1、网络操作与AFNetworking
2、转载-软件测试职业发展方向
3、药剂科处方点评的数据过滤
4、这是时间的推移 不是系统的分类
5、优化前台标题,导航,面包屑导航,列表页左侧产品属性,及分类h1标签内文字。


长按二维码向我转账

受苹果公司新规定影响,微信 iOS 版的赞赏功能被关闭,可通过二维码转账支持公众号。

    阅读
    好看
    已推荐到看一看
    你的朋友可以在“发现”-“看一看”看到你认为好看的文章。
    已取消,“好看”想法已同步删除
    已推荐到看一看 和朋友分享想法
    最多200字,当前共 发送

    已发送

    朋友将在看一看看到

    确定
    分享你的想法...
    取消

    分享想法到看一看

    确定
    最多200字,当前共

    发送中

    网络异常,请稍后重试

    微信扫一扫
    关注该公众号





    联系我们

    欢迎来到TinyMind。

    关于TinyMind的内容或商务合作、网站建议,举报不良信息等均可联系我们。

    TinyMind客服邮箱:support@tinymind.net.cn