From 537c81415678060351cb9bbd638cbd8f36fecde9 Mon Sep 17 00:00:00 2001 From: Zeliang Tian Date: Tue, 9 Aug 2022 11:58:18 +0800 Subject: [PATCH 1/5] Always show TSG link for AzureMLKubernetes extension at the head --- src/k8s-extension/HISTORY.rst | 1 + .../partner_extensions/AzureMLKubernetes.py | 32 ++++++++++++------- 2 files changed, 22 insertions(+), 11 deletions(-) diff --git a/src/k8s-extension/HISTORY.rst b/src/k8s-extension/HISTORY.rst index 4b40bd2fbd4..dc6c36a814a 100644 --- a/src/k8s-extension/HISTORY.rst +++ b/src/k8s-extension/HISTORY.rst @@ -6,6 +6,7 @@ Release History 1.3.0 ++++++++++++++++++ * Add support for provisionedClusters +* microsoft.azureml.kubernetes: Always show TSG link for AzureMLKubernetes extension at the head. 1.2.6 ++++++++++++++++++ diff --git a/src/k8s-extension/azext_k8s_extension/partner_extensions/AzureMLKubernetes.py b/src/k8s-extension/azext_k8s_extension/partner_extensions/AzureMLKubernetes.py index a260580cf8d..6d4a36a347e 100644 --- a/src/k8s-extension/azext_k8s_extension/partner_extensions/AzureMLKubernetes.py +++ b/src/k8s-extension/azext_k8s_extension/partner_extensions/AzureMLKubernetes.py @@ -46,6 +46,9 @@ # pylint: disable=too-many-instance-attributes class AzureMLKubernetes(DefaultExtension): def __init__(self): + # tsg link + self.TSG_LINK = 'https://aka.ms/arcmltsg' + # constants for configuration settings. self.DEFAULT_RELEASE_NAMESPACE = 'azureml' self.RELAY_CONNECTION_STRING_KEY = 'relayserver.relayConnectionString' @@ -112,10 +115,13 @@ def Create(self, cmd, client, resource_group_name, cluster_name, name, cluster_t extension_type, scope, auto_upgrade_minor_version, release_train, version, target_namespace, release_namespace, configuration_settings, configuration_protected_settings, configuration_settings_file, configuration_protected_settings_file): + + logger.warning("Trouble shooting:{}".format(self.TSG_LINK)) + if scope == 'namespace': raise InvalidArgumentValueError("Invalid scope '{}'. This extension can't be installed " "only at 'cluster' scope. " - "Check https://aka.ms/arcmltsg for more information.".format(scope)) + "Check {} for more information.".format(scope, self.TSG_LINK)) # set release name explicitly to azureml release_namespace = self.DEFAULT_RELEASE_NAMESPACE scope_cluster = ScopeCluster(release_namespace=release_namespace) @@ -217,10 +223,14 @@ def Create(self, cmd, client, resource_group_name, cluster_name, name, cluster_t return extension, name, create_identity def Delete(self, cmd, client, resource_group_name, cluster_name, name, cluster_type, cluster_rp, yes): + logger.warning("Trouble shooting:{}".format(self.TSG_LINK)) user_confirmation_factory(cmd, yes) def Update(self, cmd, resource_group_name, cluster_name, auto_upgrade_minor_version, release_train, version, configuration_settings, configuration_protected_settings, original_extension, yes=False): + + logger.warning("Trouble shooting:{}".format(self.TSG_LINK)) + input_configuration_settings = copy.deepcopy(configuration_settings) input_configuration_protected_settings = copy.deepcopy(configuration_protected_settings) # configuration_settings and configuration_protected_settings can be none, so need to set them to empty dict @@ -335,9 +345,9 @@ def Update(self, cmd, resource_group_name, cluster_name, auto_upgrade_minor_vers except azure.mgmt.relay.models.ErrorResponseException as ex: if ex.response.status_code == 404: raise ResourceNotFoundError("Relay server not found. " - "Check https://aka.ms/arcmltsg for more information.") from ex + "Check {} for more information.".format(self.TSG_LINK)) from ex raise AzureResponseError("Failed to get relay connection string." - "Check https://aka.ms/arcmltsg for more information.") from ex + "Check {} for more information.".format(self.TSG_LINK)) from ex if original_extension_config_settings.get(self.SERVICE_BUS_ENABLED).lower() != 'false' \ and self.SERVICE_BUS_CONNECTION_STRING not in configuration_protected_settings: @@ -349,9 +359,9 @@ def Update(self, cmd, resource_group_name, cluster_name, auto_upgrade_minor_vers except azure.core.exceptions.HttpResponseError as ex: if ex.response.status_code == 404: raise ResourceNotFoundError("Service bus not found." - "Check https://aka.ms/arcmltsg for more information.") from ex + "Check {} for more information.".format(self.TSG_LINK)) from ex raise AzureResponseError("Failed to get service bus connection string." - "Check https://aka.ms/arcmltsg for more information.") from ex + "Check {} for more information.".format(self.TSG_LINK)) from ex configuration_protected_settings = _dereference(self.reference_mapping, configuration_protected_settings) @@ -384,7 +394,7 @@ def __normalize_config(self, configuration_settings, configuration_protected_set if not _is_valid_service_type(inferenceRouterServiceType): raise InvalidArgumentValueError( "inferenceRouterServiceType only supports NodePort or LoadBalancer or ClusterIP." - "Check https://aka.ms/arcmltsg for more information.") + "Check {} for more information.".format(self.TSG_LINK)) feIsNodePort = str(inferenceRouterServiceType).lower() == 'nodeport' configuration_settings['scoringFe.serviceType.nodePort'] = feIsNodePort @@ -407,7 +417,7 @@ def __validate_config(self, configuration_settings, configuration_protected_sett logger.warning( 'Duplicate keys found in both configuration settings and configuration protected setttings: %s', key) raise InvalidArgumentValueError("Duplicate keys found." - "Check https://aka.ms/arcmltsg for more information.") + "Check {} for more information.".format(self.TSG_LINK)) enable_training = _get_value_from_config_protected_config( self.ENABLE_TRAINING, configuration_settings, configuration_protected_settings) @@ -425,7 +435,7 @@ def __validate_config(self, configuration_settings, configuration_protected_sett "To create Microsoft.AzureML.Kubernetes extension, either " "enable Machine Learning training or inference by specifying " f"'--configuration-settings {self.ENABLE_TRAINING}=true' or '--configuration-settings {self.ENABLE_INFERENCE}=true'." - "Please check https://aka.ms/arcmltsg for more information.") + "Please check {} for more information.".format(self.TSG_LINK)) configuration_settings[self.ENABLE_TRAINING] = configuration_settings.get(self.ENABLE_TRAINING, enable_training) configuration_settings[self.ENABLE_INFERENCE] = configuration_settings.get( @@ -461,7 +471,7 @@ def __validate_scoring_fe_settings(self, configuration_settings, configuration_p if not sslCname: raise InvalidArgumentValueError( "To enable HTTPs endpoint, " - "please specify sslCname parameter in --configuration-settings. Check https://aka.ms/arcmltsg for more information.") + "please specify sslCname parameter in --configuration-settings. Check {} for more information.".format(self.TSG_LINK)) inferenceRouterServiceType = _get_value_from_config_protected_config( self.inferenceRouterServiceType, configuration_settings, configuration_protected_settings) @@ -469,7 +479,7 @@ def __validate_scoring_fe_settings(self, configuration_settings, configuration_p raise InvalidArgumentValueError( "To use inference, " "please specify inferenceRouterServiceType=ClusterIP or inferenceRouterServiceType=NodePort or inferenceRouterServiceType=LoadBalancer in --configuration-settings and also set internalLoadBalancerProvider=azure if your aks only supports internal load balancer." - "Check https://aka.ms/arcmltsg for more information.") + "Check {} for more information.".format(self.TSG_LINK)) feIsNodePort = str(inferenceRouterServiceType).lower() == 'nodeport' internalLoadBalancerProvider = _get_value_from_config_protected_config( @@ -479,7 +489,7 @@ def __validate_scoring_fe_settings(self, configuration_settings, configuration_p if feIsNodePort and feIsInternalLoadBalancer: raise MutuallyExclusiveArgumentError( "When using nodePort as inferenceRouterServiceType, no need to specify internalLoadBalancerProvider." - "Check https://aka.ms/arcmltsg for more information.") + "Check {} for more information.".format(self.TSG_LINK)) if feIsNodePort: configuration_settings['scoringFe.serviceType.nodePort'] = feIsNodePort elif feIsInternalLoadBalancer: From 7b4c039841a39341a699109c20e0a6ca8d58636a Mon Sep 17 00:00:00 2001 From: Ubuntu Date: Tue, 9 Aug 2022 05:42:02 +0000 Subject: [PATCH 2/5] refine tsg message --- .../partner_extensions/AzureMLKubernetes.py | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/k8s-extension/azext_k8s_extension/partner_extensions/AzureMLKubernetes.py b/src/k8s-extension/azext_k8s_extension/partner_extensions/AzureMLKubernetes.py index 6d4a36a347e..4e6200e1246 100644 --- a/src/k8s-extension/azext_k8s_extension/partner_extensions/AzureMLKubernetes.py +++ b/src/k8s-extension/azext_k8s_extension/partner_extensions/AzureMLKubernetes.py @@ -116,7 +116,7 @@ def Create(self, cmd, client, resource_group_name, cluster_name, name, cluster_t release_namespace, configuration_settings, configuration_protected_settings, configuration_settings_file, configuration_protected_settings_file): - logger.warning("Trouble shooting:{}".format(self.TSG_LINK)) + logger.warning("Trouble shooting: {}".format(self.TSG_LINK)) if scope == 'namespace': raise InvalidArgumentValueError("Invalid scope '{}'. This extension can't be installed " @@ -223,13 +223,13 @@ def Create(self, cmd, client, resource_group_name, cluster_name, name, cluster_t return extension, name, create_identity def Delete(self, cmd, client, resource_group_name, cluster_name, name, cluster_type, cluster_rp, yes): - logger.warning("Trouble shooting:{}".format(self.TSG_LINK)) + logger.warning("Trouble shooting: {}".format(self.TSG_LINK)) user_confirmation_factory(cmd, yes) def Update(self, cmd, resource_group_name, cluster_name, auto_upgrade_minor_version, release_train, version, configuration_settings, configuration_protected_settings, original_extension, yes=False): - logger.warning("Trouble shooting:{}".format(self.TSG_LINK)) + logger.warning("Trouble shooting: {}".format(self.TSG_LINK)) input_configuration_settings = copy.deepcopy(configuration_settings) input_configuration_protected_settings = copy.deepcopy(configuration_protected_settings) From 3bb72b45151f677f5e51732ef07ab3dbb0bf8eb7 Mon Sep 17 00:00:00 2001 From: Ubuntu Date: Tue, 9 Aug 2022 05:57:51 +0000 Subject: [PATCH 3/5] refine tsg message --- .../partner_extensions/AzureMLKubernetes.py | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/k8s-extension/azext_k8s_extension/partner_extensions/AzureMLKubernetes.py b/src/k8s-extension/azext_k8s_extension/partner_extensions/AzureMLKubernetes.py index 4e6200e1246..0745d87023e 100644 --- a/src/k8s-extension/azext_k8s_extension/partner_extensions/AzureMLKubernetes.py +++ b/src/k8s-extension/azext_k8s_extension/partner_extensions/AzureMLKubernetes.py @@ -116,7 +116,7 @@ def Create(self, cmd, client, resource_group_name, cluster_name, name, cluster_t release_namespace, configuration_settings, configuration_protected_settings, configuration_settings_file, configuration_protected_settings_file): - logger.warning("Trouble shooting: {}".format(self.TSG_LINK)) + logger.warning("Troubleshooting: {}".format(self.TSG_LINK)) if scope == 'namespace': raise InvalidArgumentValueError("Invalid scope '{}'. This extension can't be installed " @@ -223,13 +223,13 @@ def Create(self, cmd, client, resource_group_name, cluster_name, name, cluster_t return extension, name, create_identity def Delete(self, cmd, client, resource_group_name, cluster_name, name, cluster_type, cluster_rp, yes): - logger.warning("Trouble shooting: {}".format(self.TSG_LINK)) + logger.warning("Troubleshooting: {}".format(self.TSG_LINK)) user_confirmation_factory(cmd, yes) def Update(self, cmd, resource_group_name, cluster_name, auto_upgrade_minor_version, release_train, version, configuration_settings, configuration_protected_settings, original_extension, yes=False): - logger.warning("Trouble shooting: {}".format(self.TSG_LINK)) + logger.warning("Troubleshooting: {}".format(self.TSG_LINK)) input_configuration_settings = copy.deepcopy(configuration_settings) input_configuration_protected_settings = copy.deepcopy(configuration_protected_settings) From d13303ce2b049dc6e148043e9d91694964a29c42 Mon Sep 17 00:00:00 2001 From: Ubuntu Date: Fri, 12 Aug 2022 03:29:52 +0000 Subject: [PATCH 4/5] move to 1.3.1 release --- src/k8s-extension/HISTORY.rst | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/src/k8s-extension/HISTORY.rst b/src/k8s-extension/HISTORY.rst index dc6c36a814a..cdf0e881ee6 100644 --- a/src/k8s-extension/HISTORY.rst +++ b/src/k8s-extension/HISTORY.rst @@ -3,10 +3,13 @@ Release History =============== +1.3.1 +++++++++++++++++++ +* microsoft.azureml.kubernetes: Always show TSG link for AzureMLKubernetes extension at the head. + 1.3.0 ++++++++++++++++++ * Add support for provisionedClusters -* microsoft.azureml.kubernetes: Always show TSG link for AzureMLKubernetes extension at the head. 1.2.6 ++++++++++++++++++ From 40e749f8b1f44cdbdeeb0eceabfa171c13ff17f9 Mon Sep 17 00:00:00 2001 From: Ubuntu Date: Fri, 12 Aug 2022 06:08:34 +0000 Subject: [PATCH 5/5] remove space --- .../partner_extensions/AzureMLKubernetes.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/k8s-extension/azext_k8s_extension/partner_extensions/AzureMLKubernetes.py b/src/k8s-extension/azext_k8s_extension/partner_extensions/AzureMLKubernetes.py index 0745d87023e..a3ddb6ebe33 100644 --- a/src/k8s-extension/azext_k8s_extension/partner_extensions/AzureMLKubernetes.py +++ b/src/k8s-extension/azext_k8s_extension/partner_extensions/AzureMLKubernetes.py @@ -117,7 +117,7 @@ def Create(self, cmd, client, resource_group_name, cluster_name, name, cluster_t configuration_settings_file, configuration_protected_settings_file): logger.warning("Troubleshooting: {}".format(self.TSG_LINK)) - + if scope == 'namespace': raise InvalidArgumentValueError("Invalid scope '{}'. This extension can't be installed " "only at 'cluster' scope. " @@ -228,7 +228,7 @@ def Delete(self, cmd, client, resource_group_name, cluster_name, name, cluster_t def Update(self, cmd, resource_group_name, cluster_name, auto_upgrade_minor_version, release_train, version, configuration_settings, configuration_protected_settings, original_extension, yes=False): - + logger.warning("Troubleshooting: {}".format(self.TSG_LINK)) input_configuration_settings = copy.deepcopy(configuration_settings)