3

I need to wrap the Unix command "tail -f" in a BufferedInputStream. I don't want to simulate or mimic tail as stated by this question. Rather, I want to use tail, waiting for it to give me a new line.

Community
  • 1
  • 1
geowa4
  • 40,390
  • 17
  • 88
  • 107

6 Answers6

14

Your best bet is to use the Process class and read with a Scanner:

Runtime r = Runtime.getRuntime()
Process p = r.exec("tail -f")
Scanner s = new Scanner(p.getInputStream())
while (s.hasNextLine()) {
    String line = s.nextLine()
    // Do whatever you want with the output.
}

hasNextLine() should block as it's waiting for more input from the input stream, so you will not be busy-waiting as data comes in.

mustpax
  • 1,408
  • 13
  • 20
1

Look at Runtime.exec(String command). Returns a Process object that has Input and Output Streams.

Gandalf
  • 9,648
  • 8
  • 53
  • 88
1

check also ProcessBuilder:

Process tail = new ProcessBuilder("tail", "-f", file).start();
BufferedInputStream bis = new BufferedInputStream(tail.getInputStream())

where file is String like "/var/log/messages".

dfa
  • 114,442
  • 31
  • 189
  • 228
0

I am guessing that system() and popen() type approaches will not work as they will block your program until the tail command terminates.

I think you could redirect the output to a file and use 'diff' against the last version to see which lines are new?

Edd Barrett
  • 3,425
  • 2
  • 29
  • 48
0

If you have the unix command

tail -f <file> | <some java program>

Then the tail would appear as an InputStream that may block for a period of time. If you don't want to block yourself, you would use the nio packages. I believe that most other ways to access the tail command (such as Process) results in a similar InputStream.

Kathy Van Stone
  • 25,531
  • 3
  • 32
  • 40