Тайм-аут команда в ударе без ненужной задержки

Я нашел проблему.

Внутри file_paths.xml значение «пути» узлов должно начинаться с «/»,

, поэтому с этим узлом: <files-path name="GeneratedReports" path="/GeneratedReports" /> мой код работает.

Также мне нужно было удалить MyIntent.SetFlags(ActivityFlags.ClearWhenTaskReset | ActivityFlags.NewTask);

267
задан Community 23 May 2017 в 01:47
поделиться

5 ответов

Я думаю, что это точно, что Вы просите:

http://www.bashcookbook.com/bashinfo/source/bash-4.0/examples/scripts/timeout3

#!/bin/bash
#
# The Bash shell script executes a command with a time-out.
# Upon time-out expiration SIGTERM (15) is sent to the process. If the signal
# is blocked, then the subsequent SIGKILL (9) terminates it.
#
# Based on the Bash documentation example.

# Hello Chet,
# please find attached a "little easier"  :-)  to comprehend
# time-out example.  If you find it suitable, feel free to include
# anywhere: the very same logic as in the original examples/scripts, a
# little more transparent implementation to my taste.
#
# Dmitry V Golovashkin <Dmitry.Golovashkin@sas.com>

scriptName="${0##*/}"

declare -i DEFAULT_TIMEOUT=9
declare -i DEFAULT_INTERVAL=1
declare -i DEFAULT_DELAY=1

# Timeout.
declare -i timeout=DEFAULT_TIMEOUT
# Interval between checks if the process is still alive.
declare -i interval=DEFAULT_INTERVAL
# Delay between posting the SIGTERM signal and destroying the process by SIGKILL.
declare -i delay=DEFAULT_DELAY

function printUsage() {
    cat <<EOF

Synopsis
    $scriptName [-t timeout] [-i interval] [-d delay] command
    Execute a command with a time-out.
    Upon time-out expiration SIGTERM (15) is sent to the process. If SIGTERM
    signal is blocked, then the subsequent SIGKILL (9) terminates it.

    -t timeout
        Number of seconds to wait for command completion.
        Default value: $DEFAULT_TIMEOUT seconds.

    -i interval
        Interval between checks if the process is still alive.
        Positive integer, default value: $DEFAULT_INTERVAL seconds.

    -d delay
        Delay between posting the SIGTERM signal and destroying the
        process by SIGKILL. Default value: $DEFAULT_DELAY seconds.

As of today, Bash does not support floating point arithmetic (sleep does),
therefore all delay/time values must be integers.
EOF
}

# Options.
while getopts ":t:i:d:" option; do
    case "$option" in
        t) timeout=$OPTARG ;;
        i) interval=$OPTARG ;;
        d) delay=$OPTARG ;;
        *) printUsage; exit 1 ;;
    esac
done
shift $((OPTIND - 1))

# $# should be at least 1 (the command to execute), however it may be strictly
# greater than 1 if the command itself has options.
if (($# == 0 || interval <= 0)); then
    printUsage
    exit 1
fi

# kill -0 pid   Exit code indicates if a signal may be sent to $pid process.
(
    ((t = timeout))

    while ((t > 0)); do
        sleep $interval
        kill -0 $$ || exit 0
        ((t -= interval))
    done

    # Be nice, post SIGTERM first.
    # The 'exit 0' below will be executed if any preceeding command fails.
    kill -s SIGTERM $$ && kill -0 $$ || exit 0
    sleep $delay
    kill -s SIGKILL $$
) 2> /dev/null &

exec "$@"
139
ответ дан Matthew H. 23 November 2019 в 02:22
поделиться

В 99% случаев ответ не должен реализовывать логику тайм-аута. Логика тайм-аута находится почти в любой ситуации красный предупредительный знак, что что-то еще неправильно и должно быть зафиксировано вместо этого.

Ваш процесс зависает или повреждается после n секунды иногда? Затем узнайте, почему и фиксируют это вместо этого.

Как в стороне, чтобы сделать правильно решение strager, которое необходимо использовать, ожидает "$SPID" вместо fg 1, с тех пор в сценариях у Вас нет управления заданиями (и пытающийся включить это глупо). Кроме того, fg 1 полагается на то, что Вы не запустили никакие другие задания ранее в сценарии, который является плохим предположением для создания.

-1
ответ дан lhunath 23 November 2019 в 02:22
поделиться

Вид hacky, но это работает. Не работает, если у Вас есть другие приоритетные процессы (помогите мне зафиксировать это!)

sleep TIMEOUT & SPID=${!}; (YOUR COMMAND HERE; kill ${SPID}) & CPID=${!}; fg 1; kill ${CPID}

На самом деле я думаю, что можно инвертировать его, соответствуя 'бонусным' критериям:

(YOUR COMMAND HERE & SPID=${!}; (sleep TIMEOUT; kill ${SPID}) & CPID=${!}; fg 1; kill ${CPID}) < asdf > fdsa
8
ответ дан strager 23 November 2019 в 02:22
поделиться

См. также сценарий http://www.pixelbeat.org/scripts/timeout, функциональность которого была интегрирована в более новые coreutils

.
9
ответ дан 23 November 2019 в 02:22
поделиться

Я предпочитаю "timelimit", у которого есть пакет, по крайней мере, в debian.

http://devel.ringlet.net/sysutils/timelimit/

Это немного лучше, чем тайм-аут coreutils, потому что он что-то печатает при завершении процесса, а также по умолчанию через некоторое время отправляет SIGKILL .

17
ответ дан 23 November 2019 в 02:22
поделиться
Другие вопросы по тегам:

Похожие вопросы: