Skip to content

Commit

Permalink
Implementation of new conf flag AutoUpdate.UpdateToLatestVersion supp…
Browse files Browse the repository at this point in the history
…ort (#3027)

* GA update to latest version flag

* address comments

* resloving comments

* added TODO

* ignore warning

* resolving comment

* address comments

* config present check

* added a comment
  • Loading branch information
nagworld9 authored Feb 6, 2024
1 parent 0c7b12d commit 176ffbf
Show file tree
Hide file tree
Showing 40 changed files with 360 additions and 48 deletions.
4 changes: 2 additions & 2 deletions azurelinuxagent/common/agent_supported_feature.py
Original file line number Diff line number Diff line change
Expand Up @@ -76,15 +76,15 @@ def __init__(self):

class _GAVersioningGovernanceFeature(AgentSupportedFeature):
"""
CRP would drive the RSM upgrade version if agent reports that it does support RSM upgrades with this flag otherwise CRP fallback to largest version.
CRP would drive the RSM update if agent reports that it does support RSM upgrades with this flag otherwise CRP fallback to largest version.
Agent doesn't report supported feature flag if auto update is disabled or old version of agent running that doesn't understand GA versioning.
Note: Especially Windows need this flag to report to CRP that GA doesn't support the updates. So linux adopted same flag to have a common solution.
"""

__NAME = SupportedFeatureNames.GAVersioningGovernance
__VERSION = "1.0"
__SUPPORTED = conf.get_autoupdate_enabled()
__SUPPORTED = conf.get_auto_update_to_latest_version()

def __init__(self):
super(_GAVersioningGovernanceFeature, self).__init__(name=self.__NAME,
Expand Down
33 changes: 25 additions & 8 deletions azurelinuxagent/common/conf.py
Original file line number Diff line number Diff line change
Expand Up @@ -87,6 +87,12 @@ def get_int(self, key, default_value):
except ValueError:
return self._get_default(default_value)

def is_present(self, key):
"""
Returns True if the given flag present in the configuration file, False otherwise.
"""
return self.values.get(key) is not None


__conf__ = ConfigurationProvider()

Expand Down Expand Up @@ -129,6 +135,7 @@ def load_conf_from_file(conf_file_path, conf=__conf__):
"ResourceDisk.EnableSwap": False,
"ResourceDisk.EnableSwapEncryption": False,
"AutoUpdate.Enabled": True,
"AutoUpdate.UpdateToLatestVersion": True,
"EnableOverProvisioning": True,
#
# "Debug" options are experimental and may be removed in later
Expand All @@ -137,7 +144,6 @@ def load_conf_from_file(conf_file_path, conf=__conf__):
"Debug.CgroupLogMetrics": False,
"Debug.CgroupDisableOnProcessCheckFailure": True,
"Debug.CgroupDisableOnQuotaCheckFailure": True,
"Debug.DownloadNewAgents": True,
"Debug.EnableAgentMemoryUsageCheck": False,
"Debug.EnableFastTrack": True,
"Debug.EnableGAVersioning": True
Expand Down Expand Up @@ -230,6 +236,13 @@ def get_switch_default_value(option):
raise ValueError("{0} is not a valid configuration parameter.".format(option))


def is_present(key, conf=__conf__):
"""
Returns True if the given flag present in the configuration file, False otherwise.
"""
return conf.is_present(key)


def enable_firewall(conf=__conf__):
return conf.get_switch("OS.EnableFirewall", False)

Expand Down Expand Up @@ -513,15 +526,19 @@ def get_monitor_network_configuration_changes(conf=__conf__):
return conf.get_switch("Monitor.NetworkConfigurationChanges", False)


def get_download_new_agents(conf=__conf__):
def get_auto_update_to_latest_version(conf=__conf__):
"""
If True, the agent go through update logic to look for new agents to download otherwise it will stop agent updates.
NOTE: AutoUpdate.Enabled controls whether the Agent downloads new update and also whether any downloaded updates are started or not, while DownloadNewAgents controls only the former.
AutoUpdate.Enabled == false -> Agent preinstalled on the image will process extensions and will not update (regardless of DownloadNewAgents flag)
AutoUpdate.Enabled == true and DownloadNewAgents == true, any update already downloaded will be started, and agent look for future updates
AutoUpdate.Enabled == true and DownloadNewAgents == false, any update already downloaded will be started, but the agent will not look for future updates
If set to True, agent will update to the latest version
NOTE:
when both turned on, both AutoUpdate.Enabled and AutoUpdate.UpdateToLatestVersion same meaning: update to latest version
when turned off, AutoUpdate.Enabled: reverts to pre-installed agent, AutoUpdate.UpdateToLatestVersion: uses latest version already installed on the vm and does not download new agents
Even we are deprecating AutoUpdate.Enabled, we still need to support if users explicitly setting it instead new flag.
If AutoUpdate.UpdateToLatestVersion is present, it overrides any value set for AutoUpdate.Enabled (if present).
If AutoUpdate.UpdateToLatestVersion is not present but AutoUpdate.Enabled is present and set to 'n', we adhere to AutoUpdate.Enabled flag's behavior
if both not present, we default to True.
"""
return conf.get_switch("Debug.DownloadNewAgents", True)
default = get_autoupdate_enabled(conf=conf)
return conf.get_switch("AutoUpdate.UpdateToLatestVersion", default)


def get_cgroup_check_period(conf=__conf__):
Expand Down
4 changes: 2 additions & 2 deletions azurelinuxagent/ga/agent_update_handler.py
Original file line number Diff line number Diff line change
Expand Up @@ -141,8 +141,8 @@ def _get_agent_family_manifest(self, goal_state):
def run(self, goal_state, ext_gs_updated):

try:
# Ignore new agents if update is disabled. The latter flag only used in e2e tests.
if not conf.get_autoupdate_enabled() or not conf.get_download_new_agents():
# If auto update is disabled, we don't proceed with update
if not conf.get_auto_update_to_latest_version():
return

# Update the state only on new goal state
Expand Down
6 changes: 6 additions & 0 deletions azurelinuxagent/ga/update.py
Original file line number Diff line number Diff line change
Expand Up @@ -772,6 +772,12 @@ def log_if_agent_versioning_feature_disabled():
log_if_op_disabled("OS.EnableFirewall", conf.enable_firewall())
log_if_op_disabled("Extensions.Enabled", conf.get_extensions_enabled())
log_if_op_disabled("AutoUpdate.Enabled", conf.get_autoupdate_enabled())
log_if_op_disabled("AutoUpdate.UpdateToLatestVersion", conf.get_auto_update_to_latest_version())

if conf.is_present("AutoUpdate.Enabled") and conf.get_autoupdate_enabled() != conf.get_auto_update_to_latest_version():
msg = "AutoUpdate.Enabled property is **Deprecated** now but it's set to different value from AutoUpdate.UpdateToLatestVersion. Please consider removing it if added by mistake"
logger.warn(msg)
add_event(AGENT_NAME, op=WALAEventOperation.ConfigurationChange, message=msg)

if conf.enable_firewall():
log_if_int_changed_from_default("OS.EnableFirewallPeriod", conf.get_enable_firewall_period())
Expand Down
6 changes: 5 additions & 1 deletion config/alpine/waagent.conf
Original file line number Diff line number Diff line change
Expand Up @@ -75,7 +75,11 @@ OS.OpensslPath=None
OS.SshDir=/etc/ssh

# Enable or disable goal state processing auto-update, default is enabled
# AutoUpdate.Enabled=y
# When turned off, it remains on latest version installed on the vm
# Added this new option AutoUpdate.UpdateToLatestVersion in place of AutoUpdate.Enabled, and encourage users to transition to this new option
# See wiki[https://github.com/Azure/WALinuxAgent/wiki/FAQ#autoupdateenabled-vs-autoupdateupdatetolatestversion] for more details
# TODO: Update the wiki link and point to readme page or public facing doc
# AutoUpdate.UpdateToLatestVersion=y

# Determine the update family, this should not be changed
# AutoUpdate.GAFamily=Prod
Expand Down
5 changes: 4 additions & 1 deletion config/arch/waagent.conf
Original file line number Diff line number Diff line change
Expand Up @@ -100,7 +100,10 @@ OS.SshDir=/etc/ssh
# OS.EnableRDMA=y

# Enable or disable goal state processing auto-update, default is enabled
# AutoUpdate.Enabled=y
# When turned off, it remains on latest version installed on the vm
# Added this new option AutoUpdate.UpdateToLatestVersion in place of AutoUpdate.Enabled, and encourage users to transition to this new option
# See wiki[https://github.com/Azure/WALinuxAgent/wiki/FAQ#autoupdateenabled-vs-autoupdateupdatetolatestversion] for more details
# AutoUpdate.UpdateToLatestVersion=y

# Determine the update family, this should not be changed
# AutoUpdate.GAFamily=Prod
Expand Down
5 changes: 4 additions & 1 deletion config/bigip/waagent.conf
Original file line number Diff line number Diff line change
Expand Up @@ -82,7 +82,10 @@ OS.SshdConfigPath=/config/ssh/sshd_config
OS.EnableRDMA=n

# Enable or disable goal state processing auto-update, default is enabled
AutoUpdate.Enabled=y
# When turned off, it remains on latest version installed on the vm
# Added this new option AutoUpdate.UpdateToLatestVersion in place of AutoUpdate.Enabled, and encourage users to transition to this new option
# See wiki[https://github.com/Azure/WALinuxAgent/wiki/FAQ#autoupdateenabled-vs-autoupdateupdatetolatestversion] for more details
# AutoUpdate.UpdateToLatestVersion=y

# Determine the update family, this should not be changed
# AutoUpdate.GAFamily=Prod
Expand Down
8 changes: 6 additions & 2 deletions config/clearlinux/waagent.conf
Original file line number Diff line number Diff line change
Expand Up @@ -73,8 +73,12 @@ OS.OpensslPath=None
# Set the path to SSH keys and configuration files
OS.SshDir=/etc/ssh

# Enable or disable self-update, default is enabled
AutoUpdate.Enabled=y
# Enable or disable goal state processing auto-update, default is enabled
# When turned off, it remains on latest version installed on the vm
# Added this new option AutoUpdate.UpdateToLatestVersion in place of AutoUpdate.Enabled, and encourage users to transition to this new option
# See wiki[https://github.com/Azure/WALinuxAgent/wiki/FAQ#autoupdateenabled-vs-autoupdateupdatetolatestversion] for more details
# AutoUpdate.UpdateToLatestVersion=y

AutoUpdate.GAFamily=Prod

# Determine if the overprovisioning feature is enabled. If yes, hold extension
Expand Down
5 changes: 4 additions & 1 deletion config/coreos/waagent.conf
Original file line number Diff line number Diff line change
Expand Up @@ -104,7 +104,10 @@ OS.OpensslPath=None
# OS.EnableRDMA=y

# Enable or disable goal state processing auto-update, default is enabled
# AutoUpdate.Enabled=y
# When turned off, it remains on latest version installed on the vm
# Added this new option AutoUpdate.UpdateToLatestVersion in place of AutoUpdate.Enabled, and encourage users to transition to this new option
# See wiki[https://github.com/Azure/WALinuxAgent/wiki/FAQ#autoupdateenabled-vs-autoupdateupdatetolatestversion] for more details
# AutoUpdate.UpdateToLatestVersion=y

# Determine the update family, this should not be changed
# AutoUpdate.GAFamily=Prod
Expand Down
5 changes: 4 additions & 1 deletion config/debian/waagent.conf
Original file line number Diff line number Diff line change
Expand Up @@ -110,7 +110,10 @@ OS.SshDir=/etc/ssh
# OS.EnableRDMA=y

# Enable or disable goal state processing auto-update, default is enabled
# AutoUpdate.Enabled=y
# When turned off, it remains on latest version installed on the vm
# Added this new option AutoUpdate.UpdateToLatestVersion in place of AutoUpdate.Enabled, and encourage users to transition to this new option
# See wiki[https://github.com/Azure/WALinuxAgent/wiki/FAQ#autoupdateenabled-vs-autoupdateupdatetolatestversion] for more details
# AutoUpdate.UpdateToLatestVersion=y

# Determine the update family, this should not be changed
# AutoUpdate.GAFamily=Prod
Expand Down
5 changes: 4 additions & 1 deletion config/devuan/waagent.conf
Original file line number Diff line number Diff line change
Expand Up @@ -104,7 +104,10 @@ OS.SshDir=/etc/ssh
# OS.EnableRDMA=y

# Enable or disable goal state processing auto-update, default is enabled
# AutoUpdate.Enabled=y
# When turned off, it remains on latest version installed on the vm
# Added this new option AutoUpdate.UpdateToLatestVersion in place of AutoUpdate.Enabled, and encourage users to transition to this new option
# See wiki[https://github.com/Azure/WALinuxAgent/wiki/FAQ#autoupdateenabled-vs-autoupdateupdatetolatestversion] for more details
# AutoUpdate.UpdateToLatestVersion=y

# Determine the update family, this should not be changed
# AutoUpdate.GAFamily=Prod
Expand Down
5 changes: 4 additions & 1 deletion config/freebsd/waagent.conf
Original file line number Diff line number Diff line change
Expand Up @@ -102,7 +102,10 @@ OS.SudoersDir=/usr/local/etc/sudoers.d
# OS.EnableRDMA=y

# Enable or disable goal state processing auto-update, default is enabled
# AutoUpdate.Enabled=y
# When turned off, it remains on latest version installed on the vm
# Added this new option AutoUpdate.UpdateToLatestVersion in place of AutoUpdate.Enabled, and encourage users to transition to this new option
# See wiki[https://github.com/Azure/WALinuxAgent/wiki/FAQ#autoupdateenabled-vs-autoupdateupdatetolatestversion] for more details
# AutoUpdate.UpdateToLatestVersion=y

# Determine the update family, this should not be changed
# AutoUpdate.GAFamily=Prod
Expand Down
7 changes: 7 additions & 0 deletions config/gaia/waagent.conf
Original file line number Diff line number Diff line change
Expand Up @@ -101,8 +101,15 @@ OS.SshDir=/etc/ssh
OS.EnableRDMA=n

# Enable or disable goal state processing auto-update, default is enabled
# When turned off, it reverts to the pre-installed agent that comes with image
# AutoUpdate.Enabled is a legacy parameter used only for backwards compatibility. We encourage users to transition to new option AutoUpdate.UpdateToLatestVersion
# See wiki[https://github.com/Azure/WALinuxAgent/wiki/FAQ#autoupdateenabled-vs-autoupdateupdatetolatestversion] for more details
AutoUpdate.Enabled=n

# Enable or disable goal state processing auto-update, default is enabled
# When turned off, it remains on latest version installed on the vm
# AutoUpdate.UpdateToLatestVersion=y

# Determine the update family, this should not be changed
# AutoUpdate.GAFamily=Prod

Expand Down
5 changes: 4 additions & 1 deletion config/iosxe/waagent.conf
Original file line number Diff line number Diff line change
Expand Up @@ -100,7 +100,10 @@ OS.SshDir=/etc/ssh
# OS.EnableRDMA=y

# Enable or disable goal state processing auto-update, default is enabled
AutoUpdate.Enabled=y
# When turned off, it remains on latest version installed on the vm
# Added this new option AutoUpdate.UpdateToLatestVersion in place of AutoUpdate.Enabled, and encourage users to transition to this new option
# See wiki[https://github.com/Azure/WALinuxAgent/wiki/FAQ#autoupdateenabled-vs-autoupdateupdatetolatestversion] for more details
# AutoUpdate.UpdateToLatestVersion=y

# Determine the update family, this should not be changed
# AutoUpdate.GAFamily=Prod
Expand Down
8 changes: 6 additions & 2 deletions config/mariner/waagent.conf
Original file line number Diff line number Diff line change
Expand Up @@ -75,8 +75,12 @@ OS.OpensslPath=None
# Set the path to SSH keys and configuration files
OS.SshDir=/etc/ssh

# Enable or disable self-update, default is enabled
AutoUpdate.Enabled=y
# Enable or disable goal state processing auto-update, default is enabled
# When turned off, it remains on latest version installed on the vm
# Added this new option AutoUpdate.UpdateToLatestVersion in place of AutoUpdate.Enabled, and encourage users to transition to this new option
# See wiki[https://github.com/Azure/WALinuxAgent/wiki/FAQ#autoupdateenabled-vs-autoupdateupdatetolatestversion] for more details
# AutoUpdate.UpdateToLatestVersion=y

AutoUpdate.GAFamily=Prod

# Determine if the overprovisioning feature is enabled. If yes, hold extension
Expand Down
7 changes: 7 additions & 0 deletions config/nsbsd/waagent.conf
Original file line number Diff line number Diff line change
Expand Up @@ -98,8 +98,15 @@ Extension.LogDir=/log/azure
# OS.EnableRDMA=y

# Enable or disable goal state processing auto-update, default is enabled
# When turned off, it reverts to the pre-installed agent that comes with image
# AutoUpdate.Enabled is a legacy parameter used only for backwards compatibility. We encourage users to transition to new option AutoUpdate.UpdateToLatestVersion
# See wiki[https://github.com/Azure/WALinuxAgent/wiki/FAQ#autoupdateenabled-vs-autoupdateupdatetolatestversion] for more details
AutoUpdate.Enabled=n

# Enable or disable goal state processing auto-update, default is enabled
# When turned off, it remains on latest version installed on the vm
# AutoUpdate.UpdateToLatestVersion=y

# Determine the update family, this should not be changed
# AutoUpdate.GAFamily=Prod

Expand Down
5 changes: 4 additions & 1 deletion config/openbsd/waagent.conf
Original file line number Diff line number Diff line change
Expand Up @@ -96,7 +96,10 @@ OS.PasswordPath=/etc/master.passwd
# OS.EnableRDMA=y

# Enable or disable goal state processing auto-update, default is enabled
# AutoUpdate.Enabled=y
# When turned off, it remains on latest version installed on the vm
# Added this new option AutoUpdate.UpdateToLatestVersion in place of AutoUpdate.Enabled, and encourage users to transition to this new option
# See wiki[https://github.com/Azure/WALinuxAgent/wiki/FAQ#autoupdateenabled-vs-autoupdateupdatetolatestversion] for more details
# AutoUpdate.UpdateToLatestVersion=y

# Determine the update family, this should not be changed
# AutoUpdate.GAFamily=Prod
Expand Down
8 changes: 6 additions & 2 deletions config/photonos/waagent.conf
Original file line number Diff line number Diff line change
Expand Up @@ -70,8 +70,12 @@ OS.OpensslPath=None
# Set the path to SSH keys and configuration files
OS.SshDir=/etc/ssh

# Enable or disable self-update, default is enabled
AutoUpdate.Enabled=y
# Enable or disable goal state processing auto-update, default is enabled
# When turned off, it remains on latest version installed on the vm
# Added this new option AutoUpdate.UpdateToLatestVersion in place of AutoUpdate.Enabled, and encourage users to transition to this new option
# See wiki[https://github.com/Azure/WALinuxAgent/wiki/FAQ#autoupdateenabled-vs-autoupdateupdatetolatestversion] for more details
# AutoUpdate.UpdateToLatestVersion=y

AutoUpdate.GAFamily=Prod

# Determine if the overprovisioning feature is enabled. If yes, hold extension
Expand Down
5 changes: 4 additions & 1 deletion config/suse/waagent.conf
Original file line number Diff line number Diff line change
Expand Up @@ -113,7 +113,10 @@ OS.SshDir=/etc/ssh
# OS.CheckRdmaDriver=y

# Enable or disable goal state processing auto-update, default is enabled
# AutoUpdate.Enabled=y
# When turned off, it remains on latest version installed on the vm
# Added this new option AutoUpdate.UpdateToLatestVersion in place of AutoUpdate.Enabled, and encourage users to transition to this new option
# See wiki[https://github.com/Azure/WALinuxAgent/wiki/FAQ#autoupdateenabled-vs-autoupdateupdatetolatestversion] for more details
# AutoUpdate.UpdateToLatestVersion=y

# Determine the update family, this should not be changed
# AutoUpdate.GAFamily=Prod
Expand Down
5 changes: 4 additions & 1 deletion config/ubuntu/waagent.conf
Original file line number Diff line number Diff line change
Expand Up @@ -101,7 +101,10 @@ OS.SshDir=/etc/ssh
# OS.CheckRdmaDriver=y

# Enable or disable goal state processing auto-update, default is enabled
# AutoUpdate.Enabled=y
# When turned off, it remains on latest version installed on the vm
# Added this new option AutoUpdate.UpdateToLatestVersion in place of AutoUpdate.Enabled, and encourage users to transition to this new option
# See wiki[https://github.com/Azure/WALinuxAgent/wiki/FAQ#autoupdateenabled-vs-autoupdateupdatetolatestversion] for more details
# AutoUpdate.UpdateToLatestVersion=y

# Determine the update family, this should not be changed
# AutoUpdate.GAFamily=Prod
Expand Down
5 changes: 4 additions & 1 deletion config/waagent.conf
Original file line number Diff line number Diff line change
Expand Up @@ -122,7 +122,10 @@ OS.SshDir=/etc/ssh
# OS.CheckRdmaDriver=y

# Enable or disable goal state processing auto-update, default is enabled
# AutoUpdate.Enabled=y
# When turned off, it remains on latest version installed on the vm
# Added this new option AutoUpdate.UpdateToLatestVersion in place of AutoUpdate.Enabled, and encourage users to transition to this new option
# See wiki[https://github.com/Azure/WALinuxAgent/wiki/FAQ#autoupdateenabled-vs-autoupdateupdatetolatestversion] for more details
# AutoUpdate.UpdateToLatestVersion=y

# Determine the update family, this should not be changed
# AutoUpdate.GAFamily=Prod
Expand Down
Loading

0 comments on commit 176ffbf

Please sign in to comment.