에 의해 파일이 순차적으로 다운로드되고 wget
있습니다.
로 포장을 풀기 시작하면 cat myfile.tar.bz2 | tar -xj
더 빠른 내용에 따라 올바르게 포장이 풀리거나 “예기치 않은 EOF”가 표시되지 않을 수 있습니다.
파일을 “cat and follow”하는 방법, 즉 파일의 내용을 stdout으로 출력하지만 EOF에서 종료하지 말고 대신 해당 파일에 서브 스크립 브 된 상태로 유지하고 데이터의 새로운 부분을 계속 출력하여 파일이 닫혀있는 경우에만 종료 N 초 내에 다시 열지 않았습니다.
@arielCo의 답변 을 기반으로 cat_and_follow 스크립트 를 작성하여 더 이상 파일을 쓰기 위해 파일을 열지 않을 때 종료합니다 .tail
답변
tail +1f file
wget
다운로드하는 동안 LibreOffice 소스 tarball을 사용하여 Ubuntu에서 테스트 했습니다.
tail +1f libreoffice-4.2.5.2.tar.xz | tar -tvJf -
또한 내 Android 전화의 tail +1 -f file
Busybox와 함께 사용되는 Solaris 10, RHEL3, AIX 5 및 Busybox 1.22.1에서도 작동합니다 .
답변
문제는 cat
파일이 여전히 추가되고 있다는 것을 인식하지 못한다 는 것 입니다. cat
파일의 (현재) 끝이 발생 하자마자 종료됩니다.
당신은 확인해야합니다 wget
이를 방지하기 위해 파이프 (또는 FIFO)에 쓰기.
wget -O - http://... | tar -xjf -
답변
처음부터 중단 될 때까지 파일 을 읽고 따르 려면 :
tail -fn +1 file
이를 증명하려면 다음을 시도하십시오 (GNU Coreutils를 사용하는 Bash 가정).
(while true; do printf . >> /tmp/file; sleep 1; done)&
tail -fn +1 /tmp/file # (Ctrl-C to interrupt, of course, or otherwise kill it.)
kill % # Kills the while-loop.
(참고 : +1f
다른 사람들이 언급 한 것은 최소한 GNU tail
명령 에서 파일 이름으로 해석됩니다 .)
위의 내용은 단일 파일에 적용됩니다. 여러 파일을 연결하면 첫 번째 파일에 매달리지 않고 결정적으로 모든 파일을 따를 수 없습니다. ‘ cat and follow ‘에 마지막 파일 만 따라 가면 프로세스 대체를 사용할 수 있습니다 . 또 다른 데모는 다음과 같습니다.
printf file1 > /tmp/file1; printf file2 > /tmp/file2
(while true; do printf . | tee -a /tmp/file{1,2} > /dev/null; sleep 1; done)&
cat /tmp/file1 <(tail -fn +1 /tmp/file2) # (Interrupt or kill it.)
kill % # Kills the while-loop.