Мне нужно прослушать файл, когда его содержимое будет добавлено, я прочитаю новую строку и поработаю с содержимым новой строки.
Длина файла никогда не уменьшится (фактически это файл журнала tomcat).
Я использую следующие коды:
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.RandomAccessFile;
import org.apache.log4j.Logger;
import com.zjswkj.analyser.ddao.LogEntryDao;
import com.zjswkj.analyser.model.LogEntry;
import com.zjswkj.analyser.parser.LogParser;
public class ListenTest {
private RandomAccessFile raf;
private long lastPosition;
private String logEntryPattern = "^([\\d.]+) (\\S+) (\\S+) \\[([\\w:/]+\\s[+\\-]\\d{4})\\] \"(.+?)\" (\\d{3}) (\\S+) \"([^\"]+)\" \"([^\"]+)\"";
private static Logger log = Logger.getLogger(ListenTest.class);
public void startListenLogOfCurrentDay() {
try {
if (raf == null)
raf = new RandomAccessFile(
"/tmp/logs/localhost_access_log.2010-12-20.txt",
"r");
String line;
while (true) {
raf.seek(lastPosition);
while ((line = raf.readLine()) != null) {
if (!line.matches(logEntryPattern)) {
// not a complete line,roll back
lastPosition = raf.getFilePointer() - line.getBytes().length;
log.debug("roll back:" + line.getBytes().length + " bytes");
if (line.equals(""))
continue;
log.warn("broken line:[" + line + "]");
Thread.sleep(2000);
} else {
// save it
LogEntry le = LogParser.parseLog(line);
LogEntryDao.saveLogEntry(le);
lastPosition = raf.getFilePointer();
}
}
}
} catch (FileNotFoundException e) {
log.error("can not find log file of today");
} catch (IOException e) {
log.error("IO Exception:" + e.getMessage());
} catch (InterruptedException e) {
e.printStackTrace();
}
}
public static void main(String[] args) {
new ListenTest().startListenLogOfCurrentDay();
}
}
Теперь, моя проблема в том, что, если строка, которая записывается в новую строку файла, не завершена, возникнет мертвая петля.
Например, если кот пытается записать в файл новую строку:
10.33.2.45 - - [08/Dec/2010:08:44:43 +0800] "GET /poi.txt HTTP/1.1" 200 672 "-" "Mozilla/5.0 (Windows; U; Windows NT 6.1; en-US; rv:1.9.2.8) Gecko/20100722 Firefox/3.6.8"
И когда пишется только одна часть строки (например: <<strong> 10.33.2.45 - - [08 / Dec / 2010: 08: 44: 43 +0800] "GET /poi.txt HTTP / 1.1 «200 672 >), теперь, поскольку он не может соответствовать определенному мной шаблону, то есть tomcat не завершает свою работу по записи, поэтому я попытаюсь откатить указатель файла и перевести 2 секунды в спящий режим, а затем снова прочитать .
Во время сна последняя часть строки может быть еще написана (на самом деле я пишу их, а не tomcat для теста), по моему мнению, randomaccessfile будет читать новую строку, которая может соответствовать шаблону, однако, похоже, что нет .
Кто-нибудь может проверить коды?
ПРИМЕЧАНИЕ : формат файла журнала «комбинируется» следующим образом:
10.33.2.45 - - [08/Dec/2010:08:44:43 +0800] "GET /poi.txt HTTP/1.1" 200 672 "-" "Mozilla/5.0 (Windows; U; Windows NT 6.1; en-US; rv:1.9.2.8) Gecko/20100722 Firefox/3.6.8"