def Args(parser): _Args(parser) group = parser.add_mutually_exclusive_group() _AddAdditionalZonesFlag(group, deprecated=True) flags.AddNodeLocationsFlag(group) flags.AddAcceleratorArgs(parser) flags.AddAddonsFlags(parser) flags.AddClusterAutoscalingFlags(parser) flags.AddDiskTypeFlag(parser) flags.AddMaxPodsPerNodeFlag(parser) flags.AddEnableAutoRepairFlag(parser) flags.AddEnableBinAuthzFlag(parser, hidden=True) flags.AddEnableKubernetesAlphaFlag(parser) flags.AddEnableLegacyAuthorizationFlag(parser) flags.AddIPAliasFlags(parser) flags.AddIstioConfigFlag(parser) flags.AddLabelsFlag(parser) flags.AddLocalSSDAndLocalSSDVolumeConfigsFlag(parser) flags.AddMaintenanceWindowFlag(parser) flags.AddMasterAuthorizedNetworksFlags(parser) flags.AddMinCpuPlatformFlag(parser) flags.AddWorkloadMetadataFromNodeFlag(parser) flags.AddNetworkPolicyFlags(parser) flags.AddEnableSharedNetworkFlag(parser, hidden=True) flags.AddAutoprovisioningFlags(parser, hidden=False) flags.AddNodeTaintsFlag(parser) flags.AddPreemptibleFlag(parser) flags.AddPodSecurityPolicyFlag(parser) flags.AddAllowRouteOverlapFlag(parser) flags.AddPrivateClusterFlags(parser, hidden=False) flags.AddClusterNodeIdentityFlags(parser) flags.AddTpuFlags(parser, hidden=False) flags.AddEnableStackdriverKubernetesFlag(parser)
def Args(parser): _Args(parser) flags.AddClusterAutoscalingFlags(parser) flags.AddDiskTypeFlag(parser, suppressed=True) flags.AddLocalSSDFlag(parser) flags.AddPreemptibleFlag(parser, for_node_pool=True) flags.AddEnableAutoRepairFlag(parser, for_node_pool=True) flags.AddMinCpuPlatformFlag(parser, for_node_pool=True) flags.AddNodeTaintsFlag(parser, for_node_pool=True) flags.AddDeprecatedNodePoolNodeIdentityFlags(parser)
def Args(parser): _Args(parser) flags.AddClusterAutoscalingFlags(parser) flags.AddDiskTypeFlag(parser) flags.AddLocalSSDFlag(parser) flags.AddPreemptibleFlag(parser, for_node_pool=True) flags.AddEnableAutoRepairFlag(parser, for_node_pool=True) flags.AddMinCpuPlatformFlag(parser, for_node_pool=True) flags.AddWorkloadMetadataFromNodeFlag(parser) flags.AddNodeTaintsFlag(parser, for_node_pool=True) flags.AddNodePoolNodeIdentityFlags(parser) flags.AddNodePoolAutoprovisioningFlag(parser, hidden=True)
def _Args(parser): """Register flags for this command. Args: parser: An argparse.ArgumentParser-like object. It is mocked out in order to capture some information, but behaves like an ArgumentParser. """ flags.AddNodePoolNameArg(parser, 'The name of the node pool to create.') flags.AddNodePoolClusterFlag(parser, 'The cluster to add the node pool to.') # Timeout in seconds for operation parser.add_argument('--timeout', type=int, default=1800, hidden=True, help='THIS ARGUMENT NEEDS HELP TEXT.') parser.add_argument( '--num-nodes', type=int, help='The number of nodes in the node pool in each of the ' 'cluster\'s zones.', default=3) parser.add_argument( '--machine-type', '-m', help='The type of machine to use for nodes. Defaults to n1-standard-1') parser.add_argument( '--disk-size', type=int, help='Size in GB for node VM boot disks. Defaults to 100GB.') flags.AddImageTypeFlag(parser, 'node pool') flags.AddImageFlag(parser, hidden=True) flags.AddImageProjectFlag(parser, hidden=True) flags.AddImageFamilyFlag(parser, hidden=True) flags.AddNodeLabelsFlag(parser, for_node_pool=True) flags.AddTagsFlag( parser, """\ Applies the given Compute Engine tags (comma separated) on all nodes in the new node-pool. Example: $ {command} node-pool-1 --cluster=example-cluster --tags=tag1,tag2 New nodes, including ones created by resize or recreate, will have these tags on the Compute Engine API instance object and can be used in firewall rules. See https://cloud.google.com/sdk/gcloud/reference/compute/firewall-rules/create for examples. """) # TODO(b/36071127): unhide this flag after we have enough ssd. flags.AddDiskTypeFlag(parser, suppressed=True) flags.AddEnableAutoUpgradeFlag(parser, for_node_pool=True) parser.display_info.AddFormat(util.NODEPOOLS_FORMAT) flags.AddNodeVersionFlag(parser)
def _Args(parser): """Register flags for this command. Args: parser: An argparse.ArgumentParser-like object. It is mocked out in order to capture some information, but behaves like an ArgumentParser. """ flags.AddNodePoolNameArg(parser, 'The name of the node pool to create.') flags.AddNodePoolClusterFlag(parser, 'The cluster to add the node pool to.') parser.add_argument( '--enable-cloud-endpoints', action='store_true', default=True, help='Automatically enable Google Cloud Endpoints to take advantage of ' 'API management features.') # Timeout in seconds for operation parser.add_argument('--timeout', type=int, default=1800, help=argparse.SUPPRESS) parser.add_argument( '--num-nodes', type=int, help='The number of nodes in the node pool in each of the ' 'cluster\'s zones.', default=3) parser.add_argument( '--machine-type', '-m', help='The type of machine to use for nodes. Defaults to n1-standard-1') parser.add_argument( '--disk-size', type=int, help='Size in GB for node VM boot disks. Defaults to 100GB.') flags.AddImageTypeFlag(parser, 'node pool') flags.AddNodeLabelsFlag(parser, for_node_pool=True) flags.AddTagsFlag( parser, """\ Applies the given Compute Engine tags (comma separated) on all nodes in the new node-pool. Example: $ {command} node-pool-1 --cluster=example-cluster --tags=tag1,tag2 New nodes, including ones created by resize or recreate, will have these tags on the Compute Engine API instance object and can be used in firewall rules. See https://cloud.google.com/sdk/gcloud/reference/compute/firewall-rules/create for examples. """) flags.AddDiskTypeFlag(parser, suppressed=True) parser.display_info.AddFormat(util.NODEPOOLS_FORMAT)
def _Args(parser): """Register flags for this command. Args: parser: An argparse.ArgumentParser-like object. It is mocked out in order to capture some information, but behaves like an ArgumentParser. """ flags.AddNodePoolNameArg(parser, 'The name of the node pool to create.') flags.AddNodePoolClusterFlag(parser, 'The cluster to add the node pool to.') # Timeout in seconds for operation parser.add_argument('--timeout', type=int, default=1800, hidden=True, help='THIS ARGUMENT NEEDS HELP TEXT.') parser.add_argument( '--num-nodes', type=int, help='The number of nodes in the node pool in each of the ' 'cluster\'s zones.', default=3) flags.AddMachineTypeFlag(parser) parser.add_argument( '--disk-size', type=arg_parsers.BinarySize(lower_bound='10GB'), help='Size for node VM boot disks in GB. Defaults to 100GB.') flags.AddImageTypeFlag(parser, 'node pool') flags.AddImageFlag(parser, hidden=True) flags.AddImageProjectFlag(parser, hidden=True) flags.AddImageFamilyFlag(parser, hidden=True) flags.AddNodeLabelsFlag(parser, for_node_pool=True) flags.AddTagsFlag( parser, """\ Applies the given Compute Engine tags (comma separated) on all nodes in the new node-pool. Example: $ {command} node-pool-1 --cluster=example-cluster --tags=tag1,tag2 New nodes, including ones created by resize or recreate, will have these tags on the Compute Engine API instance object and can be used in firewall rules. See https://cloud.google.com/sdk/gcloud/reference/compute/firewall-rules/create for examples. """) parser.display_info.AddFormat(util.NODEPOOLS_FORMAT) flags.AddNodeVersionFlag(parser) flags.AddDiskTypeFlag(parser) flags.AddMetadataFlags(parser) flags.AddShieldedInstanceFlags(parser) flags.AddNetworkConfigFlags(parser) flags.AddThreadsPerCore(parser)
def Args(parser): _Args(parser) _AddAdditionalZonesFlag(parser, deprecated=True) flags.AddNodeLocationsFlag(parser) flags.AddAddonsFlags(parser) flags.AddClusterAutoscalingFlags(parser) flags.AddDiskTypeFlag(parser, suppressed=True) flags.AddEnableAutoRepairFlag(parser) flags.AddEnableKubernetesAlphaFlag(parser) flags.AddEnableLegacyAuthorizationFlag(parser) flags.AddIPAliasFlags(parser) flags.AddLabelsFlag(parser) flags.AddLocalSSDFlag(parser) flags.AddMaintenanceWindowFlag(parser) flags.AddMasterAuthorizedNetworksFlags(parser) flags.AddMinCpuPlatformFlag(parser) flags.AddNetworkPolicyFlags(parser) flags.AddNodeTaintsFlag(parser) flags.AddPreemptibleFlag(parser) flags.AddDeprecatedClusterNodeIdentityFlags(parser)
def _Args(parser): """Register flags for this command. Args: parser: An argparse.ArgumentParser-like object. It is mocked out in order to capture some information, but behaves like an ArgumentParser. """ parser.add_argument('name', help="""\ The name of the cluster to create. The name may contain only lowercase alphanumerics and '-', must start with a letter and end with an alphanumeric, and must be no longer than 40 characters. """) # Timeout in seconds for operation parser.add_argument('--timeout', type=int, default=1800, hidden=True, help='THIS ARGUMENT NEEDS HELP TEXT.') flags.AddAsyncFlag(parser) parser.add_argument( '--num-nodes', type=arg_parsers.BoundedInt(1), help= 'The number of nodes to be created in each of the cluster\'s zones.', default=3) flags.AddMachineTypeFlag(parser) parser.add_argument('--subnetwork', help="""\ The Google Compute Engine subnetwork (https://cloud.google.com/compute/docs/subnetworks) to which the cluster is connected. The subnetwork must belong to the network specified by --network. Cannot be used with the "--create-subnetwork" option. """) parser.add_argument( '--network', help='The Compute Engine Network that the cluster will connect to. ' 'Google Kubernetes Engine will use this network when creating routes ' 'and firewalls for the clusters. Defaults to the \'default\' network.') parser.add_argument( '--cluster-ipv4-cidr', help='The IP address range for the pods in this cluster in CIDR ' 'notation (e.g. 10.0.0.0/14). Prior to Kubernetes version 1.7.0 ' 'this must be a subset of 10.0.0.0/8; however, starting with version ' '1.7.0 can be any RFC 1918 IP range.') parser.add_argument('--enable-cloud-logging', action='store_true', default=True, help='Automatically send logs from the cluster to the ' 'Google Cloud Logging API.') parser.set_defaults(enable_cloud_logging=True) parser.add_argument( '--enable-cloud-monitoring', action='store_true', default=True, help='Automatically send metrics from pods in the cluster to the ' 'Google Cloud Monitoring API. VM metrics will be collected by Google ' 'Compute Engine regardless of this setting.') parser.set_defaults(enable_cloud_monitoring=True) parser.add_argument('--disk-size', type=arg_parsers.BinarySize(lower_bound='10GB'), help='Size for node VM boot disks. Defaults to 100GB.') flags.AddBasicAuthFlags(parser) parser.add_argument( '--max-nodes-per-pool', type=arg_parsers.BoundedInt(100, api_adapter.MAX_NODES_PER_POOL), help='The maximum number of nodes to allocate per default initial node ' 'pool. Kubernetes Engine will automatically create enough nodes pools ' 'such that each node pool contains less than ' '--max-nodes-per-pool nodes. Defaults to {nodes} nodes, but can be set ' 'as low as 100 nodes per pool on initial create.'.format( nodes=api_adapter.MAX_NODES_PER_POOL)) flags.AddImageTypeFlag(parser, 'cluster') flags.AddImageFlag(parser, hidden=True) flags.AddImageProjectFlag(parser, hidden=True) flags.AddImageFamilyFlag(parser, hidden=True) flags.AddNodeLabelsFlag(parser) flags.AddTagsFlag( parser, """\ Applies the given Compute Engine tags (comma separated) on all nodes in the new node-pool. Example: $ {command} example-cluster --tags=tag1,tag2 New nodes, including ones created by resize or recreate, will have these tags on the Compute Engine API instance object and can be used in firewall rules. See https://cloud.google.com/sdk/gcloud/reference/compute/firewall-rules/create for examples. """) parser.display_info.AddFormat(util.CLUSTERS_FORMAT) flags.AddIssueClientCertificateFlag(parser) flags.AddAcceleratorArgs(parser) flags.AddDiskTypeFlag(parser) flags.AddMetadataFlags(parser)
def _Args(parser): """Register flags for this command. Args: parser: An argparse.ArgumentParser-like object. It is mocked out in order to capture some information, but behaves like an ArgumentParser. """ parser.add_argument('name', help='The name of this cluster.') # Timeout in seconds for operation parser.add_argument('--timeout', type=int, default=1800, help=argparse.SUPPRESS) flags.AddAsyncFlag(parser) parser.add_argument( '--num-nodes', type=arg_parsers.BoundedInt(1), help= 'The number of nodes to be created in each of the cluster\'s zones.', default=3) parser.add_argument('--additional-zones', type=arg_parsers.ArgList(min_length=1), metavar='ZONE', help="""\ The set of additional zones in which the specified node footprint should be replicated. All zones must be in the same region as the cluster's primary zone. If additional-zones is not specified, all nodes will be in the cluster's primary zone. Note that `NUM_NODES` nodes will be created in each zone, such that if you specify `--num-nodes=4` and choose one additional zone, 8 nodes will be created. Multiple locations can be specified, separated by commas. For example: $ {command} example-cluster --zone us-central1-a --additional-zones us-central1-b,us-central1-c """) parser.add_argument( '--machine-type', '-m', help='The type of machine to use for nodes. Defaults to n1-standard-1.' ) parser.add_argument( '--subnetwork', help='The name of the Google Compute Engine subnetwork ' '(https://cloud.google.com/compute/docs/subnetworks) to which the ' 'cluster is connected. If specified, the cluster\'s network must be a ' '"custom subnet" network.' '' 'Can not be used with the "--create-subnetwork" option.') parser.add_argument( '--disable-addons', type=arg_parsers.ArgList( choices=[api_adapter.INGRESS, api_adapter.HPA]), help='List of cluster addons to disable. Options are {0}'.format( ', '.join([api_adapter.INGRESS, api_adapter.HPA]))) parser.add_argument( '--network', help='The Compute Engine Network that the cluster will connect to. ' 'Google Container Engine will use this network when creating routes ' 'and firewalls for the clusters. Defaults to the \'default\' network.') parser.add_argument( '--cluster-ipv4-cidr', help='The IP address range for the pods in this cluster in CIDR ' 'notation (e.g. 10.0.0.0/14). Prior to Kubernetes version 1.7.0 ' 'this must be a subset of 10.0.0.0/8; however, starting with version ' '1.7.0 can be any RFC 1918 IP range.') parser.add_argument( '--password', help='The password to use for cluster auth. Defaults to a ' 'server-specified randomly-generated string.') parser.add_argument('--scopes', type=arg_parsers.ArgList(min_length=1), metavar='SCOPE', help="""\ Specifies scopes for the node instances. The project's default service account is used. Examples: $ {{command}} example-cluster --scopes https://www.googleapis.com/auth/devstorage.read_only $ {{command}} example-cluster --scopes bigquery,storage-rw,compute-ro Multiple SCOPEs can specified, separated by commas. The scopes necessary for the cluster to function properly (compute-rw, storage-ro), are always added, even if not explicitly specified. SCOPE can be either the full URI of the scope or an alias. Available aliases are: [format="csv",options="header"] |======== Alias,URI {aliases} |======== """.format(aliases=compute_constants.ScopesForHelp())) parser.add_argument( '--enable-cloud-endpoints', action='store_true', default=True, help='Automatically enable Google Cloud Endpoints to take advantage of ' 'API management features.') parser.add_argument('--enable-cloud-logging', action='store_true', default=True, help='Automatically send logs from the cluster to the ' 'Google Cloud Logging API.') parser.set_defaults(enable_cloud_logging=True) parser.add_argument( '--enable-cloud-monitoring', action='store_true', default=True, help='Automatically send metrics from pods in the cluster to the ' 'Google Cloud Monitoring API. VM metrics will be collected by Google ' 'Compute Engine regardless of this setting.') parser.set_defaults(enable_cloud_monitoring=True) parser.add_argument( '--disk-size', type=int, help='Size in GB for node VM boot disks. Defaults to 100GB.') parser.add_argument('--username', '-u', help='The user name to use for cluster auth.', default='admin') parser.add_argument( '--max-nodes-per-pool', type=arg_parsers.BoundedInt(100, api_adapter.MAX_NODES_PER_POOL), help='The maximum number of nodes to allocate per default initial node ' 'pool. Container Engine will automatically create enough nodes pools ' 'such that each node pool contains less than ' '--max-nodes-per-pool nodes. Defaults to {nodes} nodes, but can be set ' 'as low as 100 nodes per pool on initial create.'.format( nodes=api_adapter.MAX_NODES_PER_POOL)) flags.AddImageTypeFlag(parser, 'cluster') flags.AddNodeLabelsFlag(parser) flags.AddTagsFlag( parser, """\ Applies the given Compute Engine tags (comma separated) on all nodes in the new node-pool. Example: $ {command} example-cluster --tags=tag1,tag2 New nodes, including ones created by resize or recreate, will have these tags on the Compute Engine API instance object and can be used in firewall rules. See https://cloud.google.com/sdk/gcloud/reference/compute/firewall-rules/create for examples. """) flags.AddClusterVersionFlag(parser) flags.AddDiskTypeFlag(parser, suppressed=True) parser.display_info.AddFormat(util.CLUSTERS_FORMAT)
def _Args(parser): """Register flags for this command. Args: parser: An argparse.ArgumentParser-like object. It is mocked out in order to capture some information, but behaves like an ArgumentParser. """ parser.add_argument('name', help='The name of this cluster.') # Timeout in seconds for operation parser.add_argument('--timeout', type=int, default=1800, help=argparse.SUPPRESS) flags.AddAsyncFlag(parser) parser.add_argument( '--num-nodes', type=arg_parsers.BoundedInt(1), help= 'The number of nodes to be created in each of the cluster\'s zones.', default=3) parser.add_argument( '--machine-type', '-m', help='The type of machine to use for nodes. Defaults to n1-standard-1.' ) parser.add_argument( '--subnetwork', help='The name of the Google Compute Engine subnetwork ' '(https://cloud.google.com/compute/docs/subnetworks) to which the ' 'cluster is connected. If specified, the cluster\'s network must be a ' '"custom subnet" network.' '' 'Can not be used with the "--create-subnetwork" option.') parser.add_argument( '--network', help='The Compute Engine Network that the cluster will connect to. ' 'Google Container Engine will use this network when creating routes ' 'and firewalls for the clusters. Defaults to the \'default\' network.') parser.add_argument( '--cluster-ipv4-cidr', help='The IP address range for the pods in this cluster in CIDR ' 'notation (e.g. 10.0.0.0/14). Prior to Kubernetes version 1.7.0 ' 'this must be a subset of 10.0.0.0/8; however, starting with version ' '1.7.0 can be any RFC 1918 IP range.') parser.add_argument( '--password', help='The password to use for cluster auth. Defaults to a ' 'server-specified randomly-generated string.') parser.add_argument( '--enable-cloud-endpoints', action='store_true', default=True, help='Automatically enable Google Cloud Endpoints to take advantage of ' 'API management features.') parser.add_argument('--enable-cloud-logging', action='store_true', default=True, help='Automatically send logs from the cluster to the ' 'Google Cloud Logging API.') parser.set_defaults(enable_cloud_logging=True) parser.add_argument( '--enable-cloud-monitoring', action='store_true', default=True, help='Automatically send metrics from pods in the cluster to the ' 'Google Cloud Monitoring API. VM metrics will be collected by Google ' 'Compute Engine regardless of this setting.') parser.set_defaults(enable_cloud_monitoring=True) parser.add_argument( '--disk-size', type=int, help='Size in GB for node VM boot disks. Defaults to 100GB.') parser.add_argument('--username', '-u', help='The user name to use for cluster auth.', default='admin') parser.add_argument( '--max-nodes-per-pool', type=arg_parsers.BoundedInt(100, api_adapter.MAX_NODES_PER_POOL), help='The maximum number of nodes to allocate per default initial node ' 'pool. Container Engine will automatically create enough nodes pools ' 'such that each node pool contains less than ' '--max-nodes-per-pool nodes. Defaults to {nodes} nodes, but can be set ' 'as low as 100 nodes per pool on initial create.'.format( nodes=api_adapter.MAX_NODES_PER_POOL)) flags.AddImageTypeFlag(parser, 'cluster') flags.AddNodeLabelsFlag(parser) flags.AddTagsFlag( parser, """\ Applies the given Compute Engine tags (comma separated) on all nodes in the new node-pool. Example: $ {command} example-cluster --tags=tag1,tag2 New nodes, including ones created by resize or recreate, will have these tags on the Compute Engine API instance object and can be used in firewall rules. See https://cloud.google.com/sdk/gcloud/reference/compute/firewall-rules/create for examples. """) flags.AddClusterVersionFlag(parser) flags.AddDiskTypeFlag(parser, suppressed=True) parser.display_info.AddFormat(util.CLUSTERS_FORMAT)
def _Args(parser): """Register flags for this command. Args: parser: An argparse.ArgumentParser-like object. It is mocked out in order to capture some information, but behaves like an ArgumentParser. """ flags.AddNodePoolNameArg(parser, 'The name of the node pool to create.') flags.AddNodePoolClusterFlag(parser, 'The cluster to add the node pool to.') parser.add_argument( '--enable-cloud-endpoints', action='store_true', default=True, help='Automatically enable Google Cloud Endpoints to take advantage of ' 'API management features.') # Timeout in seconds for operation parser.add_argument('--timeout', type=int, default=1800, help=argparse.SUPPRESS) parser.add_argument( '--num-nodes', type=int, help='The number of nodes in the node pool in each of the ' 'cluster\'s zones.', default=3) parser.add_argument( '--machine-type', '-m', help='The type of machine to use for nodes. Defaults to n1-standard-1') parser.add_argument( '--disk-size', type=int, help='Size in GB for node VM boot disks. Defaults to 100GB.') parser.add_argument('--scopes', type=arg_parsers.ArgList(min_length=1), metavar='SCOPE', help="""\ Specifies scopes for the node instances. The project's default service account is used. Examples: $ {{command}} node-pool-1 --cluster=example-cluster --scopes https://www.googleapis.com/auth/devstorage.read_only $ {{command}} node-pool-1 --cluster=example-cluster --scopes bigquery,storage-rw,compute-ro Multiple SCOPEs can specified, separated by commas. The scopes necessary for the cluster to function properly (compute-rw, storage-ro), are always added, even if not explicitly specified. SCOPE can be either the full URI of the scope or an alias. Available aliases are: [options="header",format="csv",grid="none",frame="none"] |======== Alias,URI {aliases} |======== """.format(aliases=compute_constants.ScopesForHelp())) flags.AddImageTypeFlag(parser, 'node pool') flags.AddNodeLabelsFlag(parser, for_node_pool=True) flags.AddTagsFlag( parser, """\ Applies the given Compute Engine tags (comma separated) on all nodes in the new node-pool. Example: $ {command} node-pool-1 --cluster=example-cluster --tags=tag1,tag2 New nodes, including ones created by resize or recreate, will have these tags on the Compute Engine API instance object and can be used in firewall rules. See https://cloud.google.com/sdk/gcloud/reference/compute/firewall-rules/create for examples. """) flags.AddDiskTypeFlag(parser, suppressed=True)