工具类commons-io的Tailer用来监控文件
一、前言:在Linux下有使用tail命令
在Commons-io中也提供这种方法
二、他采用的是线程方式来监控文件内容的变化
1、Tailer类(采用线程的方式进行文件的内容变法)
2、TailerListener类
3、TailerListenerAdapter类,该类是集成了TailerListener的实现空的接口方式
三、测试使用代码
- package com.hadoop.leran.commons.io;
- import org.apache.commons.io.FileUtils;
- import org.apache.commons.io.IOUtils;
- import org.apache.commons.io.input.Tailer;
- import org.apache.commons.io.input.TailerListenerAdapter;
- import java.io.File;
- public class TailerTest {
- public static void main(String []args) throws Exception{
- TailerTest tailerTest = new TailerTest();
- tailerTest.test();
- boolean flag = true;
- File file = new File("C:/Users/hadoop/Desktop/test/1.txt");
- while(flag){
- Thread.sleep(1000);
- FileUtils.write(file,""+System.currentTimeMillis()+ IOUtils.LINE_SEPARATOR,true);
- }
- }
- public void test() throws Exception{
- File file = new File("C:/Users/hadoop/Desktop/test/1.txt");
- FileUtils.touch(file);
- Tailer tailer = new Tailer(file,new TailerListenerAdapter(){
- @Override
- public void fileNotFound() { //文件没有找到
- System.out.println("文件没有找到");
- super.fileNotFound();
- }
- @Override
- public void fileRotated() { //文件被外部的输入流改变
- System.out.println("文件rotated");
- super.fileRotated();
- }
- @Override
- public void handle(String line) { //增加的文件的内容
- System.out.println("文件line:"+line);
- super.handle(line);
- }
- @Override
- public void handle(Exception ex) {
- ex.printStackTrace();
- super.handle(ex);
- }
- },4000,true);
- new Thread(tailer).start();
- }
- }
一、前言:
使用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
三、读源代码的测试代码
- package com.hadoop.leran.commons.io;
- import org.apache.commons.io.FileUtils;
- import org.apache.commons.io.filefilter.FileFilterUtils;
- import org.apache.commons.io.filefilter.IOFileFilter;
- import org.apache.commons.io.monitor.FileAlterationListenerAdaptor;
- import org.apache.commons.io.monitor.FileAlterationMonitor;
- import org.apache.commons.io.monitor.FileAlterationObserver;
- import java.io.File;
- import java.io.FileFilter;
- public class FileAlterationObserverTest {
- public static void main(String []args) throws Exception{
- FileAlterationObserverTest fileAlter = new FileAlterationObserverTest();
- fileAlter.test();
- String filePath = "C:/Users/hadoop/Desktop/test/";
- File file = new File(filePath);
- FileUtils.deleteDirectory(file);
- file.mkdirs();
- //File txtFile = new File(filePath+File.separator+System.currentTimeMillis()+".txt");
- //FileUtils.touch(txtFile);
- // File txtFile = new File("C:/Users/hadoop/Desktop/test/1401629335839.txt");
- // txtFile.deleteOnExit();
- // FileUtils.touch(txtFile);
- // File newFile = new File(filePath+File.separator+System.currentTimeMillis());
- // newFile.mkdirs();
- boolean flag = true;
- while(flag){
- /***测试文件的变化代码*/
- // File newFileTxt = new File(filePath+File.separator+System.currentTimeMillis()+".txt");
- // FileUtils.touch(newFileTxt);
- // Thread.sleep(2000);
- // FileUtils.write(newFileTxt,"1",true);
- // Thread.sleep(2000);
- // newFileTxt.delete();
- /****测试文件夹的变化代码***/
- File newFile = new File(filePath+File.separator+System.currentTimeMillis());
- newFile.mkdir();
- Thread.sleep(2000);
- File newFileTxt = new File(newFile.getAbsolutePath()+File.separator+System.currentTimeMillis()+".txt");
- FileUtils.touch(newFileTxt);
- }
- }
- public void test() throws Exception{
- String filePath = "C:/Users/hadoop/Desktop/test/";
- FileFilter filter = FileFilterUtils.and(new MyFileFilter());
- FileAlterationObserver fileAlterationObserver = new FileAlterationObserver(filePath,filter);
- fileAlterationObserver.addListener(new FileAlterationListenerAdaptor() {
- @Override
- public void onStart(FileAlterationObserver observer) {
- System.out.println("start on file");
- super.onStart(observer);
- }
- @Override
- public void onDirectoryDelete(File directory) {
- System.out.println("delete file");
- super.onDirectoryDelete(directory);
- }
- @Override
- public void onDirectoryCreate(File directory) {
- System.out.println("create file");
- super.onDirectoryCreate(directory);
- }
- @Override
- public void onDirectoryChange(File directory) {
- System.out.println("change file");
- super.onDirectoryChange(directory);
- }
- @Override
- public void onFileCreate(File file) {
- System.out.println("file create");
- super.onFileCreate(file);
- }
- @Override
- public void onFileDelete(File file) {
- System.out.println("file delete");
- super.onFileDelete(file);
- }
- @Override
- public void onFileChange(File file) {
- System.out.println("file change");
- super.onFileChange(file);
- }
- });
- FileAlterationMonitor fileAlterationMonitor = new FileAlterationMonitor(1000);
- fileAlterationMonitor.addObserver(fileAlterationObserver);
- fileAlterationMonitor.start();
- }
- }
- /***
- * 自定义的文件过滤器
- */
- class MyFileFilter implements IOFileFilter {
- @Override
- public boolean accept(File file) {
- // String extension = FilenameUtils.getExtension(file.getAbsolutePath());
- // if(extension!=null&&extension.equals("txt"))
- // return true;
- // return false;
- return true;
- }
- @Override
- public boolean accept(File dir, String name) {
- //System.out.println("dir:"+dir+"----->"+name);
- return true;
- }
- }
出处:http://blog.csdn.net/xiaoyezi1001/article/details/28095281
工具类commons-io的Tailer用来监控文件的更多相关文章
- Java常用工具类之IO流工具类
package com.wazn.learn.util; import java.io.Closeable; import java.io.IOException; /** * IO流工具类 * * ...
- Android 常用工具类之SPUtil,可以修改默认sp文件的路径
参考: 1. 利用Java反射机制改变SharedPreferences存储路径 Singleton1900 2. Android快速开发系列 10个常用工具类 Hongyang import ...
- 分享一个FileUtil工具类,基本满足web开发中的文件上传,单个文件下载,多个文件下载的需求
获取该FileUtil工具类具体演示,公众号内回复fileutil20200501即可. package com.example.demo.util; import javax.servlet.htt ...
- 【工具类】如何通过代码安装一个apk文件
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android=&quo ...
- 项目实战工具类(二):ZipUtils(压缩/解压缩文件相关)
import android.content.Context; import android.util.Log; import java.io.File; import java.io.FileInp ...
- Commons IO方便读写文件的工具类
Commons IO是apache的一个开源的工具包,封装了IO操作的相关类,使用Commons IO可以很方便的读写文件,url源代码等. 普通地读取一个网页的源代码的代码可能如下 InputStr ...
- ftp上传或下载文件工具类
FtpTransferUtil.java工具类,向ftp上传或下载文件: package utils; import java.io.File; import java.io.FileOutputSt ...
- Java IO流学习总结七:Commons IO 2.5-FileUtils
在上面的几篇文章中,介绍了IO的常规用法,今天介绍 Commons IO 框架的使用. Commons IO简介 Apache Commons IO是Apache基金会创建并维护的Java函数库.它提 ...
- 常用高效 Java 工具类总结
一.前言 在Java中,工具类定义了一组公共方法,这篇文章将介绍Java中使用最频繁及最通用的Java工具类.以下工具类.方法按使用流行度排名,参考数据来源于Github上随机选取的5万个开源项目源码 ...
随机推荐
- Spring相关理解
日常拖完整患者............... 待续...
- hibernate课程 初探单表映射3-4 组件属性
本节内容: 1 简介组件属性 2 demo 1 简介组件属性: <component name = "address" class = "Address" ...
- 获取hudson持续构建编译结果的一种方法
作者:朱金灿 来源:http://blog.csdn.net/clever101 很多时候使用hudson结合VisualStudio进行持续构建后需要获取持续构建的编译结果,通过编译结果来知道哪些项 ...
- 《Unity預計算即時GI》笔记:三、Clusters和总结
Clusters 叢集,透過修改叢集(Clusters)也是一個降低Unity預計算流程所需要執行的工作數量的好方法.降低叢集數量也能提高執行時的效能. 當採用PRGI來計算場景光照時,Unity會簡 ...
- BZOJ 4541: [Hnoi2016]矿区 平面图转对偶图+DFS树
4541: [Hnoi2016]矿区 Time Limit: 30 Sec Memory Limit: 512 MBSubmit: 433 Solved: 182[Submit][Status][ ...
- TFS看板的设计
列 产品开发的整个流程如下图,将流程配置到看板的列: 需求池-->就绪-->开发-->测试-->待验收 -->待发布 -->已关闭 一般将Bug和需求放在一块看版上 ...
- 【BZOJ1029】[JSOI2007] 建筑抢修(堆优化贪心)
点此看题面 大致题意: 有N个受到严重损伤的建筑,对于每个建筑,修好它需要\(T1\)秒,且必须在\(T2\)秒之前修完(\(T1\)与\(T2\)不是固定值),问你最多能修好几个建筑. 题解 一看到 ...
- 【洛谷1967】货车运输(最大生成树+倍增LCA)
点此看题面 大致题意: 有\(n\)个城市和\(m\)条道路,每条道路有一个限重.多组询问,每次询问从\(x\)到\(y\)的最大载重为多少. 一个贪心的想法 首先,让我们来贪心一波. 由于要求最大载 ...
- 深入理解计算机系统_3e 第二章家庭作业 CS:APP3e chapter 2 homework
初始完成日期:2017.9.26 许可:除2.55对应代码外(如需使用请联系 randy.bryant@cs.cmu.edu),任何人可以自由的使用,修改,分发本文档的代码. 本机环境: (有一些需要 ...
- THinkPHP 5.0 域名路由
ThinkPHP支持完整域名.子域名和IP部署的路由和绑定功能 要启用域名部署路由功能,首先需要开启: 'url_domain_deploy' => true 定义域名部署规则支持两种方式:动态 ...