Монитор log4j журнал для изменений в Javafx
Я очень новый мир Java в целом. У меня есть приложение javafx, где я пытаюсь настроить наблюдатель файла в файле журнала log4j, чтобы отслеживать изменения и отображать изменения в текстовой области. У меня есть код ниже, который отлично работает на любом файле, кроме файла журнала log4j.
Кроме того, я замечаю, что когда я обновляю папку, содержащую файл log4j в проводнике Windows, это, кажется, работает. Я запутался и не уверен, что я делаю неправильно или не уверен, возможно ли это вообще.
Пожалуйста, порекомендуйте.
package application;
import java.io.IOException;
import java.net.URL;
import java.nio.file.FileSystems;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.Paths;
import java.nio.file.StandardWatchEventKinds;
import java.nio.file.WatchEvent;
import java.nio.file.WatchKey;
import java.nio.file.WatchService;
import java.util.ResourceBundle;
import java.util.stream.Collectors;
import org.apache.log4j.Logger;
import org.apache.log4j.PropertyConfigurator;
import javafx.application.Platform;
import javafx.fxml.FXML;
import javafx.fxml.Initializable;
import javafx.scene.control.Button;
import javafx.scene.control.TextArea;
import javafx.scene.text.TextFlow;
public class MainappWindowController implements Initializable {
@FXML
private Button btn_appendtext;
@FXML
private TextArea txtarea_logview;
@FXML
private TextFlow txtflow_logview;
// FOR Logging
public static final Logger log = Logger.getLogger(Main.class);
String log4jConfPath = "./log4j_properties/log4j.properties";
Path watchPath = Paths.get("C:/temp/mylogfile_being_watched_by_java.txt");
@Override
public void initialize(URL location, ResourceBundle resources) {
// TODO Auto-generated method stub
btn_appendtext.setOnAction(e -> {
testlogger();
});
// load file initially
if (Files.exists(watchPath)) {
loadFile();
} else {
log.info("File does not exist");
}
// watch file
WatchThread watchThread = new WatchThread(watchPath);
watchThread.setDaemon(true);
watchThread.start();
// Add log4j properties file to configuration
PropertyConfigurator.configure(log4jConfPath);
}
public void testlogger() {
log.info("This is an information message");
}
private void loadFile() {
try {
String stringFromFile = Files.lines(watchPath).collect(Collectors.joining("\n"));
txtarea_logview.setText(stringFromFile);
} catch (Exception e) {
e.printStackTrace();
}
}
private class WatchThread extends Thread {
Path watchPath;
public WatchThread(Path watchPath) {
this.watchPath = watchPath;
}
@Override
public void run() {
try {
WatchService watcher = FileSystems.getDefault().newWatchService();
WatchKey key = watchPath.getParent().register(watcher, StandardWatchEventKinds.ENTRY_CREATE,
StandardWatchEventKinds.ENTRY_MODIFY);
while (true) {
// wait for key to be signaled
try {
key = watcher.take();
} catch (InterruptedException x) {
return;
}
for (WatchEvent<?> event : key.pollEvents()) {
WatchEvent.Kind<?> kind = event.kind();
if (kind == StandardWatchEventKinds.OVERFLOW) {
continue;
}
WatchEvent<Path> ev = (WatchEvent<Path>) event;
Path path = ev.context();
if (!path.getFileName().equals(watchPath.getFileName())) {
continue;
}
// process file
Platform.runLater(() -> {
loadFile();
});
}
boolean valid = key.reset();
if (!valid) {
break;
}
}
} catch (IOException x) {
System.err.println(x);
}
}
}
}