16

我正在开发一个读取 /var/log/auth.log 文件的监控程序。我正在使用 Apache Commons IOTailer类实时读取文件。开始时,我想在一个简单的文件上测试实时读取部分,并在控制台行中手动输入一些代码。这是我的代码:

public class Main {
    public static void main(String[] args) {
        TailerListener listener = new MyListener();
        Tailer tailer = Tailer.create(new File("log.txt"), listener, 500);
        while(true) {

        }
    }
}

public class MyListener extends TailerListenerAdapter {
    @Override
    public void handle(String line) {
        System.out.println(line);
    }
}

从终端:sudo echo "Hello" >> log.txt 问题是当我尝试在文件中手动编写某些内容时,它不会在控制台中打印它。我试图找到一个使用 Tailer 类的具体示例,但没有运气。我在这里做错了什么?

4

2 回答 2

19

根据我的测试,Tailer只有在您向文件添加换行符时才会打印一行。所以试试sudo echo "Hello\n" >> log.txt

另请注意,如果您调用create,您将启动一个线程但没有处理它。因此,为什么你必须有一个 while/true 循环。

你可以试试这个:

public static void main(String[] args) {
    TailerListener listener = new MyListener();
    Tailer tailer = new Tailer(new File("log.txt"), listener, 500);        
    tailer.run();
}
于 2014-04-10T12:12:54.543 回答
1

您的代码应该可以工作。对我来说,这确实按预期工作。

package de.lhorn.stackoverflowplayground;

import java.io.File;
import org.apache.commons.io.input.Tailer;
import org.apache.commons.io.input.TailerListenerAdapter;

public class App {

    private static final int SLEEP = 500;

    public static void main(String[] args) throws Exception {
        App app = new App();
        app.run();
    }

    private void run() throws InterruptedException {
        MyListener listener = new MyListener();
        Tailer tailer = Tailer.create(new File("/tmp/log.txt"), listener, SLEEP);
        while (true) {
            Thread.sleep(SLEEP);
        }
    }

    public class MyListener extends TailerListenerAdapter {

        @Override
        public void handle(String line) {
            System.out.println(line);
        }

    }
}
于 2014-04-10T12:27:23.463 回答