Respostas:
A chave é o comando "wait":
#!/bin/bash
/my/process &
/another/process &
wait
echo "All processes done!"
cmd1 & p=$!; cmd2 & q=$!; while sleep 1; do echo still running ; done& wait $p $q; kill $!;
Com waitvocê pode ter a granularidade necessária:
sleep 1 &
PID1=$!
sleep 2 &
PID2=$!
wait $PID1
echo 'PID1 has ended.'
wait
echo 'All background processes have exited.'
Aqui está uma maneira de fazer isso:
launch backgroundprocess &
PROC_ID=$!
while kill -0 "$PROC_ID" >/dev/null 2>&1; do
echo "PROCESS IS RUNNING"
done
echo "PROCESS TERMINATED"
exit 0
waité mais adequado para isso?
Você pode executar seu processo com nohup e escrever um script de shell para ler o arquivo nohup.out que o nohup usa para registrar.
nohup command &
nohupnão escreve nada nohup.out; apenas cria o arquivo e redireciona a saída do comando para ele. (2) Se o comando não produzir nenhuma saída, nada será gravado nohup.out, e essa ideia não vai a lugar nenhum rapidamente. (3) Mesmo commandque a saída de gravação seja escrita, como você pode saber quando termina monitorando essa saída?
lsofpara ver se nohupainda está usando nohup.out, mas eu concordo que este é um método muito cabeludo.
commandcomeça a correr, nohupjá se foi. (1) Sim, estou repetindo um número, porque estou repetindo o que disse há dois anos: nohupnão escreve nada para nohup.out. (5) Sim, você pode escrever um shell script para executar um loop e executar lsofpara ver se nohup.outainda está aberto. Mas isso seria uma resposta diferente. (6) Mesmo se você fizesse isso, não seria confiável. E se algum outro processo abrisse o nohup.outarquivo? Você realmente deseja verificar se esse processo específico foi nohup.outaberto. (7) Mas, se você fizer isso, por que não apenas verificar se o processo está em execução?