Изменение времени сна Uber Cadence на основе внешнего (например, пользовательского) ввода
Есть ли пример того, как рабочий процесс Cadence изменяет продолжительность сна в зависимости от внешнего ввода?
Сценарий, который я ищу, заключается в следующем: рабочий процесс переходит в спящий режим до времени X, но после начала спящего режима, но до его завершения, существует внешний триггер, который приводит к изменению времени X на время Y. Y может быть позже или раньше чем X. Это может быть даже раньше, чем "сейчас", что должно немедленно освободить сон.
1 ответ
Решение
Вот фрагмент кода для того, что вы ищете
func SampleTimerWorkflow(ctx workflow.Context, timerDelay time.Duration) error
{
logger := workflow.GetLogger(ctx)
resetCh := workflow.GetSignalChannel(ctx, "reset")
timerFired := false
delay := timerDelay
for ;!timerFired; {
selector := workflow.NewSelector(ctx)
logger.Sugar().Infof("Setting up a timer to fire after: %v", delay)
timerCancelCtx, cancelTimerHandler := workflow.WithCancel(ctx)
timerFuture := workflow.NewTimer(timerCancelCtx, delay)
selector.AddFuture(timerFuture, func(f workflow.Future) {
logger.Info("Timer Fired.")
timerFired = true
})
selector.AddReceive(resetCh, func(c workflow.Channel, more bool) {
logger.Info("Reset signal received.")
logger.Info("Cancel outstanding timer.")
cancelTimerHandler()
var t int
c.Receive(ctx, &t)
logger.Sugar().Infof("Reset delay: %v seconds", t)
delay = time.Second * time.Duration(t)
})
logger.Info("Waiting for timer to fire.")
selector.Select(ctx)
}
workflow.GetLogger(ctx).Info("Workflow completed.")
return nil
}
Теперь вы можете отправить сигнал для сброса таймера на 10 секунд, как показано ниже:
cadence-cli --domain <domain> wf signal -w <workflow_id> --name reset --input 10