asmcli reference
Overview
The asmcli is a Google-provided tool that you can use to install or
upgrade Cloud Service Mesh. If you let it, asmcli will configure your
project and cluster as follows:
- Grant you the required Identity and Access Management (IAM) permissions on your Google Cloud project.
- Enable the required Google APIs on your Google Cloud project.
- Set a label on the cluster that identifies the mesh.
- Create a service account that lets data plane components, such as the sidecar proxy, securely access your project's data and resources.
- Register the cluster to the fleet if it isn't already registered.
Just include the --enable_all flag when you run asmcli to let it configure
your project and cluster. For more information about asmcli options and flags,
see the asmcli reference.
Next, asmcli configures YAML files with your project and cluster information.
These configuration files are needed to install the Cloud Service Mesh
control plane.
If you are new to Cloud Service Mesh and Istio, skip ahead to Supported platforms. The next section is intended to help existing Cloud Service Mesh upgrade to 1.23.
Transitioning to asmcli
The asmcli takes the place of istioctl install and install_asm. Although
you can still use the legacy tools in Cloud Service Mesh 1.11, we are deprecating
them and they will no longer be supported in Cloud Service Mesh 1.12 and later.
Please update your scripts and tools to use asmcli.
All clusters must be registered to a fleet. See Fleet requirements for details.
Transitioning from install_asm
If you are familiar with install_asm, asmcli is similar but with the
following notable differences:
- You use - asmcli installfor new installations and upgrades. There isn't a- --modeoption like with- install_asm. When you run- asmcli install, it checks to see if there's an existing control plane on the cluster. If there isn't an existing control plane,- asmcliinstalls Cloud Service Mesh. If the cluster has an existing control plane (either a Cloud Service Mesh control plane or an open source Istio control plane):- If the revision label on the existing control plane doesn't match the revision label for the new control plane, - asmclidoes a canary upgrade.
- If the control plane revision labels are the same, - asmclidoes an in-place upgrade.
 
- Most of the - asmclioptions and flags behave the same as the ones for- install_asm.
Transitioning from istioctl install
If you are familiar with istioctl install, if you normally pass an
IstioOperator YAML file via the -f command-line argument to configure the
control plane, you can pass the file to asmcli using the --custom_overlay
option.  In the Cloud Service Mesh documentation, we refer to these files as
overlay files.
Supported platforms
Cloud Service Mesh installations on the list of 
Supported platforms can be configured
or upgraded by asmcli.
However, not all features are available on the platforms outside of Google Cloud. For details, see In-cluster control plane supported features.
asmcli reference
This section describes the available arguments to asmcli.
Options
Identify the cluster You have the following options to identify the cluster:
GKE only
- -p|--project_id CLUSTER_PROJECT_ID
- The project ID that the cluster was created in.
- -n|--cluster_name CLUSTER_NAME
- The name of the cluster.
- -l|--cluster_location CLUSTER_LOCATION
- Either the zone (for single-zone clusters) or region (for regional clusters) that the cluster was created in.
All platforms
--kubeconfig KUBECONFIG_FILE
The full path to the kubeconfig file. The environment
variable $PWD doesn't work here.
--ctx|--context KUBE_CONTEXT
The kubeconfig context to use. If not specified,
asmcli uses the default context.
- -c|--ca {mesh_ca|gcp_cas|citadel}
- The certificate authority (CA) to use to manage mutual TLS certificates. Specify - mesh_cato use Cloud Service Mesh certificate authority (Cloud Service Mesh certificate authority),- gcp_casto use Certificate Authority Service, or- citadelto use the Istio CA. Managed Cloud Service Mesh does not support Istio CA. See the following for additional information:
- --channel CLOUD_SERVICE_MESH_CHANNEL
- Use - --channelwith a specific Cloud Service Mesh release channel to provision the Control Plane revision associated with that release channel. For example,- --channel rapid,- --channel regular, and- --channel stable. This flag is required when configuring certain Cloud Service Mesh features on GKE Autopilot clusters.
--channel option is no longer supported for Managed Cloud Service Mesh as
mentioned in CSM Release Notes.
Release channel is determined based on your GKE cluster release channel.
For more information, see Managed Cloud Service Mesh release channels.
- --co|--custom_overlay OVERLAY_FILE
- Use --custom_overlywith the name of a YAML file (referred to as an overlay file) containing theIstioOperatorcustom resource to configure the in-cluster control plane. You specify an overlay file to enable a feature that isn't enabled by default. Managed Cloud Service Mesh doesn't support theIstioOperatorAPI, so you can't use--custom_overlayto configure the managed control plane.asmclimust be able to locate the overlay file, so it either needs to be in the same directory asasmcli, or you can specify a relative path. To add multiple files, specify--co|--custom_overlayand the filename, for example:--co overlay_file1.yaml --co overlay_file2.yaml --co overlay_file3.yaml
- --hub-registration-extra-flags HUB_REGISTRATION_EXTRA_FLAGS
- If using attached Amazon EKS clusters, use --hub-registration-extra-flagsto register the cluster to the fleet if it isn't already registered.
- -k|--key_file FILE_PATH
- The key file for a service account. Omit this option if you aren't using a service account.
- --network_id NETWORK_ID
- Use --network_idto set thetopology.istio.io/networklabel applied to theistio-systemnamespace. For GKE,--network_iddefaults to the network name for the cluster. For other environments,defaultwill be used.
- -o|--option OVERLAY_FILE
- The name of the overlay file (without the - .yamlextension) that- asmclidownloads from the- anthos-service-meshrepository to enable an optional feature. You need internet connectivity to use- --option. The- --optionand- --custom_overlayoptions are similar, but they have slightly different behavior:- Use - --custom_overlaywhen you need to change the settings in the overlay file.
- Use - --optionto enable a feature that doesn't require changes to the overlay file, for example, to configure audit policies for your services.
 - To add multiple files, specify - -o|--optionand the filename, for example:- -o option_file1 -o option_file2 -o option_file3
- -D|--output_dir DIR_PATH
- If not specified, - asmclicreates a temporary directory where it downloads files and configurations necessary for installing Cloud Service Mesh. Specify the- --output-dirflag to specify a relative path to a directory to use instead. Upon completion, the specified directory contains the- asmand the- istio-1.23.6-asm.11subdirectories. The- asmdirectory contains the configuration for the installation. The- istio-1.23.6-asm.11directory contains the extracted contents of installation file, which contains- istioctl, samples, and manifests. If you specify- --output-dirand the directory already contains the necessary files,- asmcliuses those files instead of downloading them again.
- --platform PLATFORM {gcp|multicloud}
- The platform or the provider of the Kubernetes cluster. Defaults to - gcp(for GKE clusters). For all other platforms use,- multicloud.
- -r|--revision_name REVISION NAME
- A revision label is a key-value pair that is set on the control plane. The revision label key is always - istio.io/rev. By default,- asmclisets the value for the revision label based on the Cloud Service Mesh version, for example:- asm-1236-11. Include this option if you want to override the default value and specify your own. The- REVISION NAMEargument must be a DNS-1035 label. This means the name must:- contain at most 63 characters
- contain only lowercase alphanumeric characters or '-'
- start with an alphabetic character
- end with an alphanumeric character
 
The regex used for validation is: '[a-z]([-a-z0-9]*[a-z0-9])?'
- -s|--service_account ACCOUNT
- The name of a service account used to install Cloud Service Mesh. If not
specified, the active user account in the current gcloudconfiguration is used. If you need to change the active user account, run gcloud auth login.
Options for Istio CA custom certificate
If you specified --ca citadel and you are using a custom CA, include the
following options:
- --ca_cert FILE_PATH: The intermediate certificate
- --ca_key FILE_PATH: The key for the intermediate certificate
- --root_cert FILE_PATH: The root certificate
- --cert_chain FILE_PATH: The certificate chain
For more information, see Plugging in existing CA Certificates.
Enablement flags
The flags that start with --enable let asmcli enable the required Google
APIs, set
required Identity and Access Management (IAM) permissions,
and update your cluster. If you prefer, you can
update your project and cluster yourself
before running asmcli. All of the enablement flags are incompatible with
asmcli validate. If you specify an enablement flag when you run
asmcli validate, the command terminates with an error.
- -e|--enable_all
- Allow asmclito perform all of the individual enable actions described below.
- --enable_cluster_roles
- Allow asmclito attempt to bind the Google Cloud user or service account runningasmclito thecluster-adminrole on your cluster.asmclidetermines the user account from thegcloud config get core/accountcommand. If you are runningasmclilocally with a user account, make sure that you call thegcloud auth logincommand before runningasmcli. If you need to change the user account, run thegcloud config set core/account GCP_EMAIL_ADDRESScommand where GCP_EMAIL_ADDRESS is the account that you use to log in to Google Cloud.
- --enable_cluster_labels
- Allow asmclito set required cluster labels.
- --enable_gcp_components
- Allow - asmclito enable the following required Google Cloud managed services and components:- Workload Identity, which lets GKE applications safely access Google Cloud services. 
 
- --enable_gcp_apis
- Allow - asmclito enable all required Google APIs.
- --enable_gcp_iam_roles
- Allow - asmclito set the required IAM permissions.
- --enable_meshconfig_init
- Allow the script to initialize the meshconfig endpoint on your behalf. Implied by - --enable_gcp_componentsand- --managed.
- --enable_namespace_creation
- Allow - asmclito create the root- istio-systemnamespace.
- --enable_registration
- Allow - asmclito register the cluster to the project that the cluster is in. If you don't include this flag, follow the steps in Registering a cluster to manually register the cluster. Note that unlike the other enablement flags,- --enable_registrationis only included in- --enable_allwhen you specify an option (such as- --option hub-meshca) that requires cluster registration. Otherwise, you need to specify this flag separately.
Other flags
- --dry_run
- Print commands, but don't execute them.
- --fleet_id
- Register a cluster to a fleet using the fleet's host project ID. This flag is
required for non-Google Cloud clusters. When not provided for
Google Cloud clusters, it defaults to the cluster's project ID. You can
run asmcli installalong with--fleet_idprior to the installation, or as part of the installation by passing the--enable-registrationand--fleet-idflags. This setting cannot be changed after it is configured.
- --managed
- Deprecated. Provision a remote, managed control plane instead of installing one in-cluster.
- --offline
- Perform an offline installation using the pre-downloaded package in the output directory. If the directory is not specified or does not contain the required files, the script will exit with error.
- --only_enable
- Perform the specified steps to set up the current user/cluster but doesn't install anything.
- --only_validate
- Run validation but don't update the project or cluster and don't install
Cloud Service Mesh. This flag is incompatible with the
enablement flags. asmcliterminates with an error if you specify--only_validatewith any enablement flag.
- --print_config
- Instead of installing Cloud Service Mesh, print all of the compiled YAML to
standard output (stdout). All other output is written to standard error
(stderr), even if it would normally go to stdout. asmcliskips all validations and setup when you specify this flag.
- --disable_canonical_service
- By default, asmclideploys the Canonical Service controller to your cluster. If you don't wantasmclito deploy the controller, specify--disable_canonical_service. For more information, refer to Enabling and disabling the Canonical Service controller.
- -h|--help
- Show a help message describing the options and flags and exit.
- --use_managed_cni
- Use the managed CNI. If this flag is
not passed, asmcliwill apply the static CNI manifests.
- --use_vpcsc
- If your organization enforces
VPC Service Controls for your project, you must
configure managed Cloud Service Mesh with the --use_vpcscflag. Otherwise the installation will fail security controls.
- -v|--verbose
- As asmcliruns, it prints the command that it will run next. With the--verboseflag,asmcliprints the command after execution as well.
- --version
- Print the version of asmcliand exit. If you don't have the most recent version, you can download the most recent version ofasmcli_1.23.