mirror of
https://github.com/balena-os/balena-supervisor.git
synced 2025-01-11 15:32:47 +00:00
Merge pull request #1331 from balena-io/always-poll
Catch errors in the target state poll so polling will always continue
This commit is contained in:
commit
02be46068b
@ -612,31 +612,35 @@ export class APIBinder {
|
||||
}
|
||||
|
||||
private async pollTargetState(skipFirstGet: boolean = false): Promise<void> {
|
||||
const appUpdatePollInterval = await this.config.get(
|
||||
'appUpdatePollInterval',
|
||||
);
|
||||
let appUpdatePollInterval;
|
||||
try {
|
||||
appUpdatePollInterval = await this.config.get('appUpdatePollInterval');
|
||||
if (!skipFirstGet) {
|
||||
await this.getAndSetTargetState(false);
|
||||
this.targetStateFetchErrors = 0;
|
||||
}
|
||||
|
||||
// We add a random jitter up to `maxApiJitterDelay` to
|
||||
// space out poll requests
|
||||
let pollInterval =
|
||||
const pollInterval =
|
||||
Math.random() * constants.maxApiJitterDelay + appUpdatePollInterval;
|
||||
|
||||
if (!skipFirstGet) {
|
||||
try {
|
||||
await this.getAndSetTargetState(false);
|
||||
this.targetStateFetchErrors = 0;
|
||||
await Bluebird.delay(pollInterval);
|
||||
} catch (e) {
|
||||
pollInterval = Math.min(
|
||||
appUpdatePollInterval,
|
||||
const pollInterval = Math.min(
|
||||
// If we failed fetching the appUpdatePollInterval then there won't have been any network
|
||||
// requests so we default it to a low value of 10s since we don't need to worry about too
|
||||
// many network requests
|
||||
appUpdatePollInterval ?? 10000,
|
||||
15000 * 2 ** this.targetStateFetchErrors,
|
||||
);
|
||||
++this.targetStateFetchErrors;
|
||||
}
|
||||
}
|
||||
|
||||
await Bluebird.delay(pollInterval);
|
||||
} finally {
|
||||
await this.pollTargetState();
|
||||
}
|
||||
}
|
||||
|
||||
private async pinDevice({ app, commit }: DevicePinInfo) {
|
||||
if (this.balenaApi == null) {
|
||||
|
Loading…
Reference in New Issue
Block a user