170 похожих чатов

Привет, чат! у меня возникла небольшая диллема с таймаутами сразу приведу

код:

cmd := exec.Command("my awesome command")
cmdStdout, _ := cmd.StdoutPipe()

timeout := time.Second * time.Duration(90)
timer := time.NewTimer(timeout)

_ := cmd.Start()

jobDone := make(chan error)
go func() {
jobDone <- cmd.Wait()
}()

go func() {
rd := bufio.NewReader(cmdStdout)
for {
if line, _, err := rd.ReadLine(); err != nil {
log.Println("Cannot read command output anymore...")
break
} else {
timer.Reset(timeout)
log.Println(string(line))
}
}
}()

select {
case <-timer.C:
_ = cmd.Process.Signal(syscall.SIGTERM)
return nil, errors.New("timed out")
case err := <-jobDone:
if err != nil {
return nil, errors.New("command failed")
}
}

// command finished successfully, do some stuff


Что мне здесь не нравится: мануал по timer.Reset говорит, что нельзя ресетить неистёкший таймер, особенно когда кто-то в это время слушает <-timer.C. Можно было бы конечно же сделать timer := time.NewTimer(timeout) вместе ресета, но меня терзают сомнения что это тоже нехорошо -- программа сидит слушает <-timer.C, а горутина в это время постоянно подменяет таймер.
Можно конечно слушать какой-нибудь другой канал, который не подменяется, вместо <-timer.C, но такое решение выглядит немножко странно тоже.
Как быть?

1 ответов

5 просмотров
Jorilla️️️- Автор вопроса

разобрался: делать timer.Reset(timeout) в данном случае нормально а вот если сделать timer := time.NewTimer(timeout), то селект внизу не заметит обновления таймера

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

Обсуждают сегодня

$params = [ 'formid' => 'feedbackForm', 'formTpl' => '@CODE: <form class="form-validate" data-id="ajax_form"> <fieldset class="margin-bottom-md"> ...
Pathologic
1
И ещё вопрос: можно ли типа как на дос как-то запариться и с помощью прерываний выводить текст, вместо функции printf ?
НѣкъиⰘижєжєиꙁъвьсєсвѣтьноѣсѣтиѥсть•
34
Ладно, ещё тупого спрошу. Код должен банально вывести значение регистра на консоль, на деле же не выводя ничего, просто оставляя нерабочую консоль (открыта, ничего не написан...
НѣкъиⰘижєжєиꙁъвьсєсвѣтьноѣсѣтиѥсть•
25
здравствуйте. пытаюсь проверить, содержится ли в десятичном представлении инта некоторая цифра. совершаю: strstr(x, "5") != NULL) получаю ошибку с фото (заведомо неработающий ...
Катя Шевчук🪇
18
Что там вообще с кроссплатформенностью?
🄼🄰🄺🅉🄰🄸
23
Доброй ночи. Вопрос знатокам. Имеется некая таблица, результат которой выведен в DBGrid на форме. И есть форма, с помощью которой можно как добавить запись, так и отредактиров...
Евгений
28
Ребята. Этот вопрос мучает меня уже 13 - 15 лет. Почему при валидации в ФормЛистере у поля phone поведение странноватое и отличается от других? А именно, вот набор правил д...
Андрей [aharito] Харитонов
1
{ char buff = *start; *start = *end; *end = buff; } Из-за этой строчки? Что каждый символ через перем бафф? Как вариант использовать другие со...
Wenks
12
а всё почему? потому что ассемблер в отличии от яву порождает множество пагубных привычек, среди которых например можно отметить использование глобальных переменных для всего ...
Mixail Frolov
35
Кстати, а я вот тут подумал. Допустим, у нас имеется цикл который выполняет огромное количество итераций, но мы хотим, чтобы какие-то действия исполнилось только один раз. В Я...
The Bird of Hermes
23
Карта сайта