Você pode gerar um processo que produza alguma saída em segundo plano e o mate assim que scp
estiver pronto:
(while sleep 60; do echo downloading; done) &
PID=$!
scp "$1" "$2"
kill $PID
Eu uso um script bash para fazer o download de um arquivo grande de um dispositivo cliente para um servidor da Web.
Mas, como isso levará muito tempo, o nginx retornará o tempo limite do gateway. O que eu pretendo fazer é passar o stdout do script bash para um subprocesso python e enviá-lo como resposta. Como o scp não produzirá nenhuma saída no stdout, preciso enviar alguma resposta a cada minuto até que o comando scp
seja concluído.
Existe alguma maneira de conseguir isso usando o script bash?
Além disso, não consigo aumentar o tempo limite do Nginx, pois normalmente levará mais de 20 minutos
Aqui está uma função mais geral para lidar com o download e aguardar:
#! /bin/bash
# Wait for process end and show seconds count down
# Arg1: PID
# Arg2: Expected seconds
# Arg3: (optional): dump file
# Arg4: (optional): expected file size in bytes
function waitpid() {
[ -n "$3" ] && touch "$3"
local COUNT=$(( $2*10 ))
while [ -e /proc/$1 ]; do
if [ $(( COUNT%10 )) -eq 0 ]; then
echo -en "\r$(( COUNT/10 )) sec"
if [ -n "$3" ]; then
bytes=$( stat --format=%s $3 )
echo -n " $bytes bytes "
if [ -n "$4" ]; then
echo -n "$(( $bytes*100/$4 ))% "
fi
fi
fi
echo -en ".\e[K"
sleep 0.1
[ $COUNT -gt 0 ] && COUNT=$(( COUNT-1 ))
done
echo
}
echo "Example 1: Wait for process to be finished"
sleep 10 &
waitpid $! 10
echo "Example 2: Wait and show file size"
for N in {1..5} ; do echo "BAR $N" >> /tmp/foo ; sleep 2 ; done &
waitpid $! 10 /tmp/foo
Exemplo de saída:
Example 1: Wait for process to be finished
3 sec........
Example 2: Wait and show file size
7 sec 160 bytes .......
Editar: se for muito complexo, use a versão curta:
sleep 10 &
while [ -e /proc/$! ]; do echo -n . ; sleep 1 ; done
Captura de tela:
$ sleep 10 &
[1] 5432
$ while [ -e /proc/$! ]; do echo -n . ; sleep 1 ; done
..........[1]+ Done sleep 10
OK, eu finalmente consegui, eu passo os argumentos $1
e $2
para scp
, aqui eu obtenho o ID do processo do comando scp
e até que ele termine eu ecoo a resposta baixando a cada um minuto .
Para isso eu uso SECONDS
no bash
t=$SECONDS
scp $1 $2 &
PROC_ID=$!
while kill -0 "$PROC_ID" >/dev/null 2>&1; do
n=$(( SECONDS-t))
if (( n > 60 )); then
echo downloading
t=$SECONDS
fi
done