system deployments: remove old rolling eval creation #27007
Merged
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
When using deployments, the deployment watcher emits all the evals we expect to see to step through the deployment once each allocation becomes healthy for
min_healthy_time. But we left the old rolling-update eval code in place and with the new job parsing of theupdateblock that ends up emitting a eval immediately with a zero wait time and we don't end up respecting themin_healthy_time.This is all driven from the deployment watcher now, so we can simply remove it from the scheduler.
Testing & Reproduction steps
Run two nodes. Run the following jobspec.
jobspec
Wait until the initial deployment is done and then destructively update (ex. incrementing
task.env.version). Previously an eval triggered by rolling-update would run and you'd see both new allocs immediately. Now we wait 15s after the first alloc becomes healthy and then the new alloc is created via an eval triggered by the deploymentwatcher.Changes to Security Controls
Are there any changes to security controls (access controls, encryption, logging) in this pull request? If so, explain.