-
Notifications
You must be signed in to change notification settings - Fork 4.9k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[Elastic Agent] Add upgrade CLI to initiate upgrade of Agent locally #21425
Conversation
Pinging @elastic/ingest-management (Team:Ingest Management) |
@@ -205,6 +206,7 @@ func newManaged( | |||
[]context.CancelFunc{managedApplication.cancelCtxFn}, | |||
reexec, | |||
acker) | |||
uc.SetUpgrader(managedApplication.upgrader) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
should we allow to upgrade agent when enrolled?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think we should allow it, but I can disable it if we think that is correct.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Code LGTM, not sure if we should enable manual upgrade when connected to fleet, but code wise it looks ok
233f815
to
6c2666c
Compare
aef67c3
to
5a9920f
Compare
Switched it to not allow local upgrade when Agent is controlled by Fleet. |
…lastic#21425) * Add new upgrade command to initiate a local upgrade of Elastic Agent. * Update drop path with file:// prefix is defined. * Add comment. * Add missing new line. * Add changelog. * Prevent upgrading of Agent locally when connected to Fleet. * Fixes from rebase. (cherry picked from commit c858dd0)
…21425) (#21542) * Add new upgrade command to initiate a local upgrade of Elastic Agent. * Update drop path with file:// prefix is defined. * Add comment. * Add missing new line. * Add changelog. * Prevent upgrading of Agent locally when connected to Fleet. * Fixes from rebase. (cherry picked from commit c858dd0)
* upstream/master: [CI] Setup git config globally (elastic#21562) docs: update generate_fields_docs.py (elastic#21359) Add support for additional fields from V2 ALB logs (elastic#21540) Move Prometheus query & remote_write to GA (elastic#21507) feat: add a new step to run the e2e tests for certain parts of Beats (elastic#21100) [Elastic Agent] Add elastic agent ID and version to events from filebeat and metricbeat. (elastic#21543) Release cloudfoundry input and processor as GA (elastic#21525) [Packetbeat] New SIP protocol (elastic#21221) [Filebeat][New Module] Add support for Microsoft MTP / 365 Defender (elastic#21446) [Beats][pytest] Asserting if filebeat logs include errors (elastic#20999) junipersrx-module initial release (elastic#20017) Add a persistent cache for cloudfoundry metadata based on badger (elastic#20775) Add missing changelog entry for cisco umbrella (elastic#21550) [Elastic Agent] Add upgrade CLI to initiate upgrade of Agent locally (elastic#21425) Enable filestream input (elastic#21533) Add filestream input reader (elastic#21481) [CI] fix 'no matches found within 10000' (elastic#21466) Fix billing.go aws.GetStartTimeEndTime (elastic#21531)
What does this PR do?
Adds a new
upgrade
CLI command that communicates with the running Elastic Agent to perform self-upgrading. This also allows a local upgrade to a new build using the--source-uri file://${path}
command line flag.Why is it important?
To allow upgrading of the installed Elastic Agent, as well as to help with testing the upgrade process because of the allowed
file://
prefix in the--source-uri
.Checklist
[ ] I have made corresponding changes to the documentation[ ] I have made corresponding change to the default configuration files[ ] I have added tests that prove my fix is effective or that my feature worksCHANGELOG.next.asciidoc
orCHANGELOG-developer.next.asciidoc
.How to test this PR locally
Using a properly installed Elastic Agent with
./elastic-agent install
. You can initiate an upgrade:The above will fail because there is no pushed 8.0.0, but using the same command and the added
--source-uri
upgrading can be tested.This requires that the branch was build with DEV on so that the *.asc files are not required
DEV=true mag package
. You can point it to the same installed version but that will result in the following error:Adding a commit and rebuilding will result in a new version that will successfully upgrade.
Related issues