Skip to content
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

Add mesh upgrade commands for az aks mesh #6775

Merged
merged 54 commits into from
Oct 12, 2023
Merged
Show file tree
Hide file tree
Changes from 28 commits
Commits
Show all changes
54 commits
Select commit Hold shift + click to select a range
c98dfbe
Add validation for key-vault-id for ASM BYO CA feature
deveshdama Sep 1, 2023
41910dc
Fix example for asm byo ca
deveshdama Sep 1, 2023
3c0948f
Fix example for asm byo ca
deveshdama Sep 1, 2023
2ddc5c8
Add strict validation for Azure Keyvault id param
deveshdama Sep 8, 2023
a41ed63
update recording file
deveshdama Sep 9, 2023
7a85a2e
Merge branch 'Azure:main' into main
deveshdama Sep 9, 2023
9ef0c57
Merge branch 'Azure:main' into main
deveshdama Sep 14, 2023
76be1b2
Initial changes for az aks mesh get-revisons and get-upgrades subcomm…
deveshdama Sep 15, 2023
12d7010
Adding code to format the results for aks mesh get-revisions and get-…
deveshdama Sep 15, 2023
8e03d46
Adding table format output and mesh upgrade commands
deveshdama Sep 18, 2023
753d3f8
remove test print code
deveshdama Sep 18, 2023
f7741b0
Merge branch 'Azure:main' into main
deveshdama Sep 18, 2023
38d4e13
Adding live test recording file
deveshdama Sep 18, 2023
bdf274f
Fix linter issues
deveshdama Sep 18, 2023
9f35e56
Fix an issue with the help file
deveshdama Sep 18, 2023
0bfcafe
Add custom help text for location parameter
deveshdama Sep 18, 2023
7dbb13e
Fix lint errors
deveshdama Sep 19, 2023
bf02f23
Update history.rst file with the latest changes
deveshdama Sep 19, 2023
d959d9a
Update src/aks-preview/HISTORY.rst
deveshdama Sep 19, 2023
69cdf83
Update src/aks-preview/azext_aks_preview/_help.py
deveshdama Sep 19, 2023
f30704c
Update src/aks-preview/azext_aks_preview/_help.py
deveshdama Sep 19, 2023
321a029
Update src/aks-preview/azext_aks_preview/_help.py
deveshdama Sep 19, 2023
932e0ba
Update src/aks-preview/azext_aks_preview/_help.py
deveshdama Sep 19, 2023
7ede6c8
Update src/aks-preview/azext_aks_preview/_help.py
deveshdama Sep 19, 2023
5a3edce
Update src/aks-preview/azext_aks_preview/_help.py
deveshdama Sep 19, 2023
e4deb46
Update src/aks-preview/azext_aks_preview/_params.py
deveshdama Sep 19, 2023
c3c5144
Fixed a comment as per the review comments
deveshdama Sep 19, 2023
e499913
merge with master
deveshdama Sep 19, 2023
f4fca11
fix lint issue
deveshdama Sep 19, 2023
152c941
update setup.py file
deveshdama Sep 19, 2023
e264f0f
Add optional param --revision to az aks mesh enable command and add m…
deveshdama Sep 21, 2023
272ecb9
Merge from azure main
deveshdama Sep 22, 2023
bb7741e
Fix ingress and egress gateway bugs
deveshdama Sep 25, 2023
d71d3fd
Fix a bug with disable egress gateway code
deveshdama Sep 25, 2023
2364dae
Update ASM Istio links
deveshdama Sep 25, 2023
ab8b59d
Adding live tests for get-upgrades and get-revisions
deveshdama Oct 3, 2023
98efa21
Merge remote-tracking branch 'upstream/main'
deveshdama Oct 3, 2023
21b482a
remove test code
deveshdama Oct 3, 2023
fc5c29a
fix a typo
deveshdama Oct 3, 2023
cb28cb0
fix a bug with upgrade commands
deveshdama Oct 3, 2023
fb86cfa
Fix assert statements
deveshdama Oct 4, 2023
14c98ac
Adding recording file for get-revisions live test
deveshdama Oct 5, 2023
8a4a9d8
Add recording file for live test for get-upgrades
deveshdama Oct 5, 2023
73a75d5
Fix tests
deveshdama Oct 5, 2023
4da8346
semantic sort for istio revisions
deveshdama Oct 9, 2023
1e3648b
Fix a typo
deveshdama Oct 9, 2023
b1ff17a
Fixed a bug with validation
deveshdama Oct 9, 2023
3f15218
linter error fix
deveshdama Oct 9, 2023
8e79a8b
aks mesh upgrade commands on cluster with Istio disabled should fail
deveshdama Oct 9, 2023
53fac56
lint error
deveshdama Oct 9, 2023
2d1ea3b
remove aks mesh upgrade live tests since we only support asm-1-17 as …
deveshdama Oct 10, 2023
2a6894a
Merge branch 'Azure:main' into main
deveshdama Oct 10, 2023
3bfa5b9
Update history and setup files with new versions
deveshdama Oct 10, 2023
92524c1
Updating live test recording files
deveshdama Oct 10, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 6 additions & 0 deletions src/aks-preview/HISTORY.rst
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,12 @@ To release a new version, please select a new version number (usually plus 1 to
Pending
+++++++

0.5.160
+++++++
* Add `get-upgrades` and `get-revisions` to the `az aks mesh` command.
* Add `az aks mesh upgrade` commands to manage upgrades for Azure Service Mesh.

=======
0.5.159
+++++++
* Revert `az aks copilot` Command
Expand Down
56 changes: 56 additions & 0 deletions src/aks-preview/azext_aks_preview/_format.py
Original file line number Diff line number Diff line change
Expand Up @@ -296,3 +296,59 @@ def _aks_snapshot_table_format(result):
}""")
# use ordered dicts so headers are predictable
return parsed.search(result, Options(dict_cls=OrderedDict))


def aks_mesh_revisions_table_format(result):
"""Format a list of mesh revisions as summary results for display with "-o table". """
revision_table = flatten_mesh_revision_table(result[0]['properties']['meshRevisions'])
parsed = compile_jmes("""[].{
revision: revision,
upgrades: upgrades || [`None available`] | sort_versions(@) | join(`, `, @),
compatibleWith: compatibleWith_name,
compatibleVersions: compatibleVersions || [`None available`] | sort_versions(@) | join(`, `, @)
}""")
# Use ordered dicts so headers are predictable
results = parsed.search(revision_table, Options(
dict_cls=OrderedDict, custom_functions=_custom_functions({})))

return results


# Helper function used by aks_mesh_revisions_table_format
def flatten_mesh_revision_table(revision_info):
"""Flattens revision information"""
flattened = []
for revision_data in revision_info:
flattened.extend(_format_mesh_revision_entry(revision_data))
return flattened


def aks_mesh_upgrades_table_format(result):
"""Format a list of mesh upgrades as summary results for display with "-o table". """
upgrades_table = _format_mesh_revision_entry(result[0]['properties'])
parsed = compile_jmes("""[].{
revision: revision,
upgrades: upgrades || [`None available`] | sort_versions(@) | join(`, `, @),
compatibleWith: compatibleWith_name,
compatibleVersions: compatibleVersions || [`None available`] | sort_versions(@) | join(`, `, @)
}""")
# Use ordered dicts so headers are predictable
results = parsed.search(upgrades_table, Options(
dict_cls=OrderedDict, custom_functions=_custom_functions({})))
return results


def _format_mesh_revision_entry(revision):
flattened = []
revision_entry = revision['revision']
upgrades = revision['upgrades']
compatible_with_list = revision['compatibleWith']
for compatible_with in compatible_with_list:
item = {
'revision': revision_entry,
'upgrades': upgrades,
'compatibleWith_name': compatible_with['name'],
'compatibleVersions': compatible_with['versions']
}
flattened.append(item)
return flattened
56 changes: 56 additions & 0 deletions src/aks-preview/azext_aks_preview/_help.py
Original file line number Diff line number Diff line change
Expand Up @@ -2645,6 +2645,62 @@
text: az aks mesh disable-ingress-gateway --resource-group MyResourceGroup --name MyManagedCluster --ingress-gateway-type Internal
"""

helps['aks mesh get-revisions'] = """
type: command
short-summary: Discover available Azure Service Mesh revisions and their compatibility.
long-summary: This command discovers available Azure Service Mesh revisions and their compatibility information for the given location.
examples:
- name: Discover Azure Service Mesh revisions.
text: az aks mesh get-revisions --location westus2
crafted: true
"""

helps['aks mesh get-upgrades'] = """
type: command
short-summary: Discover available Azure Service Mesh upgrades.
long-summary: This command discovers available Azure Service Mesh upgrades for the mesh revision installed on the cluster.
examples:
- name: Discover Azure Service Mesh upgrades.
text: az aks mesh get-upgrades --resource-group MyResourceGroup --name MyManagedCluster
"""

helps['aks mesh upgrade start'] = """
type: command
short-summary: Initiate Azure Service Mesh upgrade.
long-summary: This command initiates upgrade of Azure Service Mesh to the specified revision.
parameters:
- name: --revision
type: string
short-summary: Azure Service Mesh revision to upgrade to.
examples:
- name: Initiate Azure Service Mesh upgrade.
text: az aks mesh upgrade start --resource-group MyResourceGroup --name MyManagedCluster --revision asm-1-18
"""

helps['aks mesh upgrade'] = """
type: group
short-summary: Commands to manage the upgrades for Azure Service Mesh.
long-summary: A group of commands to manage the upgrades for Azure Service Mesh in given cluster.
"""

helps['aks mesh upgrade complete'] = """
type: command
short-summary: Complete Azure Service Mesh upgrade.
long-summary: This command completes Azure Service Mesh canary upgrade by removing the previous revision.
examples:
- name: Complete Azure Service Mesh upgrade.
text: az aks mesh upgrade complete --resource-group MyResourceGroup --name MyManagedCluster
"""

helps['aks mesh upgrade rollback'] = """
type: command
short-summary: Rollback Azure Service Mesh upgrade.
long-summary: This command rolls back Azure Service Mesh upgrade to the previous stable revision.
examples:
- name: Rollback Azure Service Mesh upgrade.
text: az aks mesh upgrade rollback --resource-group MyResourceGroup --name MyManagedCluster
"""

helps['aks mesh enable-egress-gateway'] = """
type: command
short-summary: Enable an Azure Service Mesh egress gateway.
Expand Down
7 changes: 5 additions & 2 deletions src/aks-preview/azext_aks_preview/_params.py
Original file line number Diff line number Diff line change
Expand Up @@ -32,8 +32,6 @@
CONST_ABSOLUTEMONTHLY_MAINTENANCE_SCHEDULE,
CONST_AZURE_KEYVAULT_NETWORK_ACCESS_PRIVATE,
CONST_AZURE_KEYVAULT_NETWORK_ACCESS_PUBLIC,
CONST_AZURE_SERVICE_MESH_INGRESS_MODE_EXTERNAL,
CONST_AZURE_SERVICE_MESH_INGRESS_MODE_INTERNAL,
CONST_CREDENTIAL_FORMAT_AZURE,
CONST_CREDENTIAL_FORMAT_EXEC,
CONST_DAILY_MAINTENANCE_SCHEDULE,
Expand Down Expand Up @@ -929,6 +927,11 @@ def load_arguments(self, _):
c.argument('root_cert_object_name')
c.argument('cert_chain_object_name')

with self.argument_context('aks mesh get-revisions') as c:
c.argument('location', required=True, help='Location in which to discover available Azure Service Mesh revisions.')

with self.argument_context('aks mesh upgrade start') as c:
c.argument('revision', required=True)

def _get_default_install_location(exe_name):
system = platform.system()
Expand Down
27 changes: 27 additions & 0 deletions src/aks-preview/azext_aks_preview/commands.py
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,8 @@
aks_show_table_format,
aks_upgrades_table_format,
aks_versions_table_format,
aks_mesh_revisions_table_format,
aks_mesh_upgrades_table_format,
)
from knack.log import get_logger

Expand Down Expand Up @@ -276,3 +278,28 @@ def load_command_table(self, _):
'aks_mesh_disable_egress_gateway',
supports_no_wait=True,
confirmation=True)
g.custom_command(
'get-revisions',
'aks_mesh_get_revisions',
table_transformer=aks_mesh_revisions_table_format)
g.custom_command(
'get-upgrades',
'aks_mesh_get_upgrades',
table_transformer=aks_mesh_upgrades_table_format)
deveshdama marked this conversation as resolved.
Show resolved Hide resolved

# AKS mesh upgrade commands
with self.command_group('aks mesh upgrade', managed_clusters_sdk, client_factory=cf_managed_clusters) as g:
g.custom_command(
'start',
'aks_mesh_upgrade_start',
supports_no_wait=True)
g.custom_command(
'complete',
'aks_mesh_upgrade_complete',
supports_no_wait=True,
confirmation='Are you sure you want to complete the upgrade?')
g.custom_command(
'rollback',
'aks_mesh_upgrade_rollback',
supports_no_wait=True,
confirmation='Are you sure you want to rollback the upgrade?')
61 changes: 61 additions & 0 deletions src/aks-preview/azext_aks_preview/custom.py
Original file line number Diff line number Diff line change
Expand Up @@ -2524,6 +2524,65 @@ def aks_mesh_disable_egress_gateway(
egx_gtw_nodeselector=None)


def aks_mesh_get_revisions(
cmd,
client,
location
):
return client.list_mesh_revision_profiles(location)


def aks_mesh_get_upgrades(
cmd,
client,
resource_group_name,
name
):
return client.list_mesh_upgrade_profiles(resource_group_name, name)


def aks_mesh_upgrade_start(
cmd,
client,
resource_group_name,
name,
revision
):
return _aks_mesh_update(
cmd,
client,
resource_group_name,
name,
revision=revision)


def aks_mesh_upgrade_complete(
cmd,
client,
resource_group_name,
name):
return _aks_mesh_update(
cmd,
client,
resource_group_name,
name,
mesh_upgrade_command="complete")


def aks_mesh_upgrade_rollback(
cmd,
client,
resource_group_name,
name
):
return _aks_mesh_update(
cmd,
client,
resource_group_name,
name,
mesh_upgrade_command="rollback")


def _aks_mesh_update(
cmd,
client,
Expand All @@ -2542,6 +2601,8 @@ def _aks_mesh_update(
enable_egress_gateway=None,
egx_gtw_nodeselector=None,
disable_egress_gateway=None,
revision=None,
mesh_upgrade_command=None,
):
raw_parameters = locals()

Expand Down
20 changes: 19 additions & 1 deletion src/aks-preview/azext_aks_preview/managed_cluster_decorator.py
Original file line number Diff line number Diff line change
Expand Up @@ -2085,7 +2085,6 @@ def update_azure_service_mesh_profile(self) -> ServiceMeshProfile:

:return: updated service mesh profile
"""

updated = False
new_profile = self.models.ServiceMeshProfile(mode=CONST_AZURE_SERVICE_MESH_MODE_DISABLED) \
if self.mc.service_mesh_profile is None else copy.deepcopy(self.mc.service_mesh_profile)
Expand Down Expand Up @@ -2246,6 +2245,25 @@ def update_azure_service_mesh_profile(self) -> ServiceMeshProfile:
new_profile.istio.certificate_authority.plugin.cert_chain_object_name = cert_chain_object_name
updated = True

# deal with mesh upgrade commands
mesh_upgrade_command = self.raw_param.get("mesh_upgrade_command", None)
if mesh_upgrade_command is not None:
if len(new_profile.istio.revisions) < 2:
raise ArgumentUsageError('Azure Service Mesh upgrade is not in progress.')

if mesh_upgrade_command is not None and mesh_upgrade_command == "complete":
deveshdama marked this conversation as resolved.
Show resolved Hide resolved
new_profile.istio.revisions.remove(min(new_profile.istio.revisions))
if mesh_upgrade_command is not None and mesh_upgrade_command == "rollback":
new_profile.istio.revisions.remove(max(new_profile.istio.revisions))
updated = True

revision = self.raw_param.get("revision", None)
if revision is not None:
if new_profile.istio.revisions is None:
new_profile.istio.revisions = []
new_profile.istio.revisions.append(revision)
updated = True

if updated:
return new_profile
else:
Expand Down
Loading