Java實(shí)現(xiàn)實(shí)時(shí)監(jiān)控目錄下文件變化的方法
一、commons-io方法
1、使用Commons-io的monitor下的相關(guān)類可以處理對(duì)文件進(jìn)行監(jiān)控,它采用的是觀察者模式來實(shí)現(xiàn)的
- (1)可以監(jiān)控文件夾的創(chuàng)建、刪除和修改
- (2)可以監(jiān)控文件的創(chuàng)建、刪除和修改
- (3)采用的是觀察者模式來實(shí)現(xiàn)的
- (4)采用線程去定時(shí)去刷新檢測(cè)文件的變化情況
2、引入commons-io包,需要2.0以上。
<!-- https://mvnrepository.com/artifact/commons-io/commons-io --> <dependency> <groupId>commons-io</groupId> <artifactId>commons-io</artifactId> <version>2.6</version> </dependency>
3、編寫繼承FileAlterationListenerAdaptor的類FileListener。
import java.io.File;
import org.apache.commons.io.monitor.FileAlterationListenerAdaptor;
import org.apache.commons.io.monitor.FileAlterationObserver;
import org.apache.log4j.Logger;
/**
* 文件變化監(jiān)聽器
* 在Apache的Commons-IO中有關(guān)于文件的監(jiān)控功能的代碼. 文件監(jiān)控的原理如下:
* 由文件監(jiān)控類FileAlterationMonitor中的線程不停的掃描文件觀察器FileAlterationObserver,
* 如果有文件的變化,則根據(jù)相關(guān)的文件比較器,判斷文件時(shí)新增,還是刪除,還是更改。(默認(rèn)為1000毫秒執(zhí)行一次掃描)
*/
public class FileListener extends FileAlterationListenerAdaptor {
private Logger log = Logger.getLogger(FileListener.class);
/**
* 文件創(chuàng)建執(zhí)行
*/
public void onFileCreate(File file) {
log.info("[新建]:" + file.getAbsolutePath());
}
/**
* 文件創(chuàng)建修改
*/
public void onFileChange(File file) {
log.info("[修改]:" + file.getAbsolutePath());
}
/**
* 文件刪除
*/
public void onFileDelete(File file) {
log.info("[刪除]:" + file.getAbsolutePath());
}
/**
* 目錄創(chuàng)建
*/
public void onDirectoryCreate(File directory) {
log.info("[新建]:" + directory.getAbsolutePath());
}
/**
* 目錄修改
*/
public void onDirectoryChange(File directory) {
log.info("[修改]:" + directory.getAbsolutePath());
}
/**
* 目錄刪除
*/
public void onDirectoryDelete(File directory) {
log.info("[刪除]:" + directory.getAbsolutePath());
}
public void onStart(FileAlterationObserver observer) {
// TODO Auto-generated method stub
super.onStart(observer);
}
public void onStop(FileAlterationObserver observer) {
// TODO Auto-generated method stub
super.onStop(observer);
}
}
4、實(shí)現(xiàn)main方法
public static void main(String[] args) throws Exception{
// 監(jiān)控目錄
String rootDir = "D:\\apache-tomcat-7.0.78";
// 輪詢間隔 5 秒
long interval = TimeUnit.SECONDS.toMillis(1);
// 創(chuàng)建過濾器
IOFileFilter directories = FileFilterUtils.and(
FileFilterUtils.directoryFileFilter(),
HiddenFileFilter.VISIBLE);
IOFileFilter files = FileFilterUtils.and(
FileFilterUtils.fileFileFilter(),
FileFilterUtils.suffixFileFilter(".txt"));
IOFileFilter filter = FileFilterUtils.or(directories, files);
// 使用過濾器
FileAlterationObserver observer = new FileAlterationObserver(new File(rootDir), filter);
//不使用過濾器
//FileAlterationObserver observer = new FileAlterationObserver(new File(rootDir));
observer.addListener(new FileListener());
//創(chuàng)建文件變化監(jiān)聽器
FileAlterationMonitor monitor = new FileAlterationMonitor(interval, observer);
// 開始監(jiān)控
monitor.start();
}
二、使用JDK7提供的WatchService
public static void main(String[] a) {
final Path path = Paths.get("D:\\apache-tomcat-7.0.78");
try (WatchService watchService = FileSystems.getDefault().newWatchService()) {
//給path路徑加上文件觀察服務(wù)
path.register(watchService, StandardWatchEventKinds.ENTRY_CREATE,
StandardWatchEventKinds.ENTRY_MODIFY,
StandardWatchEventKinds.ENTRY_DELETE);
while (true) {
final WatchKey key = watchService.take();
for (WatchEvent<?> watchEvent : key.pollEvents()) {
final WatchEvent.Kind<?> kind = watchEvent.kind();
if (kind == StandardWatchEventKinds.OVERFLOW) {
continue;
}
//創(chuàng)建事件
if (kind == StandardWatchEventKinds.ENTRY_CREATE) {
System.out.println("[新建]");
}
//修改事件
if (kind == StandardWatchEventKinds.ENTRY_MODIFY) {
System.out.println("修改]");
}
//刪除事件
if (kind == StandardWatchEventKinds.ENTRY_DELETE) {
System.out.println("[刪除]");
}
// get the filename for the event
final WatchEvent<Path> watchEventPath = (WatchEvent<Path>) watchEvent;
final Path filename = watchEventPath.context();
// print it out
System.out.println(kind + " -> " + filename);
}
boolean valid = key.reset();
if (!valid) {
break;
}
}
} catch (IOException | InterruptedException ex) {
System.err.println(ex);
}
}
三、以上方法都可以實(shí)現(xiàn)對(duì)相應(yīng)文件夾得文件監(jiān)控,但是在使用jdk7提供的API時(shí),會(huì)出現(xiàn)些許問題。
- (1)當(dāng)文件修改時(shí),會(huì)被調(diào)用兩次,即輸出兩個(gè)相同的修改。
- (2)不能對(duì)其子文件夾進(jìn)行監(jiān)控,只能提示目錄被修改。
- (3)無法對(duì)文件類型進(jìn)行過濾。
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接
- 基于spring-boot和docker-java實(shí)現(xiàn)對(duì)docker容器的動(dòng)態(tài)管理和監(jiān)控功能[附完整源碼下載]
- Java使用WatchService監(jiān)控文件內(nèi)容變化的示例
- Java實(shí)時(shí)監(jiān)控日志文件并輸出的方法詳解
- java獲取redis日志信息與動(dòng)態(tài)監(jiān)控信息的方法
- java實(shí)現(xiàn)文件變化監(jiān)控的方法(推薦)
- SHELL腳本監(jiān)控JAVA進(jìn)程的代碼
- 使用Java編寫一個(gè)簡(jiǎn)單的Web的監(jiān)控系統(tǒng)
- Java服務(wù)器主機(jī)信息監(jiān)控工具類的示例代碼
相關(guān)文章
springboot 運(yùn)行 jar 包讀取外部配置文件的問題
這篇文章主要介紹了springboot 運(yùn)行 jar 包讀取外部配置文件,本文主要描述linux系統(tǒng)執(zhí)行jar包讀取jar包同級(jí)目錄的外部配置文件,主要分為兩種方法,每種方法通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2021-07-07
Spring?代理?Bean?獲取不到原始?Bean?對(duì)象注解解決方法
這篇文章主要介紹了Spring?代理?Bean?獲取不到原始?Bean?對(duì)象注解解決方法,文章圍繞主題相關(guān)資料展開詳細(xì)介紹,需要的小伙伴可以參考一下2022-04-04
SpringBoot + SpringSecurity 環(huán)境搭建的步驟
這篇文章主要介紹了SpringBoot + SpringSecurity 環(huán)境搭建的步驟,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-05-05

