चूंकि जोश अर्नबर्ग द्वारा दी गई स्क्रिप्ट में कुछ गतिरोध मुद्दे हो सकते हैं (जो मैंने अभी तक अनुभव नहीं किया है, लेकिन इसकी जांच भी नहीं की है), मैंने अपने दम पर कुछ लिखा है। इसमें गतिरोध की समस्या नहीं होनी चाहिए। यह किसी भी शेल कमांड के लिए काम करता है, न कि केवल cp के लिए।
Contents of ~/bin/q
#!/bin/bash
#this waits for any PIDs to finish
anywait(){
for pid in "$@"; do
while kill -0 "$pid" 2&>1 >/dev/null; do
sleep 0.5
done
done
}
PIDFILE=~/.q.pid
#open PIDFILE and aquire lock
exec 9>>$PIDFILE
flock -w2 9 || { echo "ERROR: flock() failed." >&2; exit 1; }
#read previous instances PID from PIDFILE and write own PID to PIDFILE
OLDPID=$(<$PIDFILE)
echo $$>$PIDFILE
#release lock
flock -u 9
#wait for OLDPID
anywait $OLDPID
#do stuff
"$@"
#afterwards: cleanup (if pidfile still contains own PID, truncate it)
flock -w2 9 || { echo "ERROR: flock() failed." >&2; exit 1; }
if [ $(<$PIDFILE) == $$ ]; then
truncate -s0 $PIDFILE
fi
flock -u 9
यह प्रक्रियाओं की एक श्रृंखला बनाता है, प्रत्येक पिछले एक की प्रतीक्षा कर रहा है। यदि श्रृंखला के बीच की प्रक्रिया प्रतीक्षा करते समय दुर्घटनाग्रस्त हो जाती है (असंभव लेकिन असंभव नहीं), तो श्रृंखला टूट जाती है और दोनों भाग समानांतर में चलते हैं। यदि प्रक्रिया में से एक को मार दिया जाता है तो ऐसा ही होता है।
इस तरह का उपयोग:
q $COMMAND $ARGS
या और भी
q $COMMAND $ARGS; $ANOTHER_COMMAND $MORE_ARGS
टाइप करके टेस्ट करें
q sleep 10 &
q echo blubb &
और पाया कि 10 सेकंड के बाद ब्लब प्रिंट हो जाता है।