diff options
author | Harald Musum <musum@verizonmedia.com> | 2020-03-29 09:54:40 +0200 |
---|---|---|
committer | Harald Musum <musum@verizonmedia.com> | 2020-03-29 09:54:40 +0200 |
commit | d0e36f8329daba094e908c1949dddd7e7de941e8 (patch) | |
tree | 7dd653558714e134414826c80a767a0dbc5f4dae /node-admin | |
parent | 44e2be1ea393b7556ab59e7f77a757d8d25be546 (diff) |
Set warmup duration based on zone
No warmup time necessary in cd or test environments. Set
default warmup time to 89 seconds, as the previous value of 60
seconds (which ended up being ~90 seconds) was the wanted one based
on experience with prod applications.
Diffstat (limited to 'node-admin')
-rw-r--r-- | node-admin/src/main/java/com/yahoo/vespa/hosted/node/admin/nodeagent/NodeAgentImpl.java | 13 |
1 files changed, 10 insertions, 3 deletions
diff --git a/node-admin/src/main/java/com/yahoo/vespa/hosted/node/admin/nodeagent/NodeAgentImpl.java b/node-admin/src/main/java/com/yahoo/vespa/hosted/node/admin/nodeagent/NodeAgentImpl.java index c4966b69acb..48ee49deb1c 100644 --- a/node-admin/src/main/java/com/yahoo/vespa/hosted/node/admin/nodeagent/NodeAgentImpl.java +++ b/node-admin/src/main/java/com/yahoo/vespa/hosted/node/admin/nodeagent/NodeAgentImpl.java @@ -4,6 +4,7 @@ package com.yahoo.vespa.hosted.node.admin.nodeagent; import com.yahoo.config.provision.DockerImage; import com.yahoo.config.provision.Environment; import com.yahoo.config.provision.NodeType; +import com.yahoo.config.provision.SystemName; import com.yahoo.config.provision.zone.ZoneApi; import com.yahoo.log.LogLevel; import com.yahoo.vespa.flags.DoubleFlag; @@ -53,7 +54,7 @@ public class NodeAgentImpl implements NodeAgent { // Container is started with uncapped CPU and is kept that way until the first successful health check + this duration // Subtract 1 second to avoid warmup coming in lockstep with tick time and always end up using an extra tick when there are just a few ms left - private static final Duration DEFAULT_WARM_UP_DURATION = Duration.ofMinutes(1).minus(Duration.ofSeconds(1)); + private static final Duration DEFAULT_WARM_UP_DURATION = Duration.ofSeconds(90).minus(Duration.ofSeconds(1)); private static final Logger logger = Logger.getLogger(NodeAgentImpl.class.getName()); @@ -102,9 +103,9 @@ public class NodeAgentImpl implements NodeAgent { public NodeAgentImpl(NodeAgentContextSupplier contextSupplier, NodeRepository nodeRepository, Orchestrator orchestrator, DockerOperations dockerOperations, StorageMaintainer storageMaintainer, FlagSource flagSource, Optional<CredentialsMaintainer> credentialsMaintainer, - Optional<AclMaintainer> aclMaintainer, Optional<HealthChecker> healthChecker, Clock clock) { + Optional<AclMaintainer> aclMaintainer, Optional<HealthChecker> healthChecker, Clock clock, ZoneApi zone) { this(contextSupplier, nodeRepository, orchestrator, dockerOperations, storageMaintainer, flagSource, credentialsMaintainer, - aclMaintainer, healthChecker, clock, DEFAULT_WARM_UP_DURATION); + aclMaintainer, healthChecker, clock, warmUpDurationForZone(zone)); } public NodeAgentImpl(NodeAgentContextSupplier contextSupplier, NodeRepository nodeRepository, @@ -605,4 +606,10 @@ public class NodeAgentImpl implements NodeAgent { protected Optional<CredentialsMaintainer> credentialsMaintainer() { return credentialsMaintainer; } + + private static Duration warmUpDurationForZone(ZoneApi zone) { + return zone.getSystemName() == SystemName.cd || zone.getEnvironment().isTest() + ? Duration.ZERO + : DEFAULT_WARM_UP_DURATION; + } } |