()
| 440 | } |
| 441 | |
| 442 | func (j *Job) runOnce() { |
| 443 | defer j.ResetAllOnce() |
| 444 | |
| 445 | curTime := time.Now() |
| 446 | sinceLastRun := calcSinceLastRun(curTime, j.prevRun) |
| 447 | j.prevRun = curTime |
| 448 | |
| 449 | metrics := j.collect() |
| 450 | |
| 451 | if j.panicked.Load() { |
| 452 | return |
| 453 | } |
| 454 | |
| 455 | if j.processMetrics(metrics, curTime, sinceLastRun) { |
| 456 | j.retries.Store(0) |
| 457 | } else { |
| 458 | j.retries.Add(1) |
| 459 | } |
| 460 | |
| 461 | _, _ = io.Copy(j.out, j.buf) |
| 462 | j.buf.Reset() |
| 463 | } |
| 464 | |
| 465 | func (j *Job) collect() collectedMetrics { |
| 466 | j.panicked.Store(false) |