txt 파일이있는 경우에만 특정 변경을 수행하는 셸 스크립트를 작업 중이지만이 테스트 루프가 작동하지 않습니다. 이유가 궁금합니다. 감사합니다!
while [ ! -f /tmp/list.txt ] ;
do
sleep 2
done
답변
“작동 안함”이라고 말하면 작동하지 않는지 어떻게 알 수 있습니까?
다음을 추가하여 파일이 실제로 존재하는지 알아낼 수 있습니다.
while [ ! -f /tmp/list.txt ]
do
sleep 2 # or less like 0.2
done
ls -l /tmp/list.txt
‘echo $ SHELL’을 입력하여 Bash (또는 관련) 셸을 사용하고 있는지 확인할 수도 있습니다. 나는 CSH와 TCSH가이 루프에 대해 약간 다른 의미를 사용한다고 생각합니다.
답변
Linux를 사용 중이고 inotify-tools가 설치된 경우 다음을 수행 할 수 있습니다.
file=/tmp/list.txt
while [ ! -f "$file" ]
do
inotifywait -qqt 2 -e create -e moved_to "$(dirname $file)"
done
이렇게하면 “x”초마다 폴링하는 동안 절전으로 인한 지연이 줄어 듭니다. 필요한 것으로 예상되는 경우 더 많은 이벤트를 추가 할 수 있습니다.
답변
나는 같은 문제가 있었다,! 대괄호 외부;
while ! [ -f /tmp/list.txt ];
do
echo "#"
sleep 1
done
또한 루프 내부에 에코를 추가하면 루프에 들어가는 지 여부를 알려줍니다.
답변
비슷한 문제가 발생하여 여기로 이어 져서 동일한 경험을하는 모든 사람에게 내 솔루션을 남겨두고 싶었습니다.
내가 실행 cat /tmp/list.txt
하면 파일에 즉시 배치되는 내용이 있음을 확신하더라도 파일이 비어 있음을 알았습니다 . 예상대로 작동 sleep 1;
하기 직전에 넣으면 나타납니다 cat /tmp/list.txt
. 파일이 생성 된 시간과 작성된 시간 사이에 지연이 있었을 것입니다.
내 최종 코드 :
while [ ! -f /tmp/list.txt ];
do
sleep 1;
done;
sleep 1;
cat /tmp/list.txt;
이것이 누군가를 좌절시키는 30 분을 구하는 데 도움이되기를 바랍니다!
답변
@ zane-hooper처럼 NFS에서 비슷한 문제가 발생했습니다. 병렬 / 분산 파일 시스템에서는 한 시스템에서 파일을 만드는 것과 파일을 “보는”다른 시스템 사이의 지연이 매우 클 수 있으므로 파일 생성 후 while 루프가 종료되기 전에 최대 1 분까지 기다릴 수 있습니다. 또한 이미 삭제 된 파일을 “보는”후유증이 있습니다.)
이것은 스크립트가 “작동하지 않는다”는 착각을 불러 일으키지 만 실제로는 공을 떨어 뜨리는 파일 시스템입니다.
알아내는 데 시간이 좀 걸렸고 누군가 시간을 절약하기를 바랍니다.
추신 이것은 또한 “부실 파일 처리기”오류의 성가신 수를 일으 킵니다.
답변
bash 및 sh 모두에서 작동합니다.
touch /tmp/testfile
sleep 10 && rm /tmp/testfile &
until ! [ -f /tmp/testfile ]
do
echo "testfile still exist..."
sleep 1
done
echo "now testfile is deleted.."
답변
다음은 시간 제한 이있는 버전 이므로 일정 시간 이 지나면 루프가 오류와 함께 종료됩니다.
# After 60 seconds the loop will exit
timeout=60
while [ ! -f /tmp/list.txt ];
do
# When the timeout is equal to zero, show an error and leave the loop.
if [ "$timeout" == 0 ]; then
echo "ERROR: Timeout while waiting for the file /tmp/list.txt."
exit 1
fi
sleep 1
# Decrease the timeout of one
((timeout--))
done