Index
GkeHub
(interface)ApplianceCluster
(message)Authority
(message)ConnectAgentResource
(message)CreateMembershipRequest
(message)DeleteMembershipRequest
(message)EdgeCluster
(message)GenerateConnectManifestRequest
(message)GenerateConnectManifestResponse
(message)GetMembershipRequest
(message)GkeCluster
(message)InitializeHubRequest
(message)InitializeHubResponse
(message)KubernetesMetadata
(message)KubernetesResource
(message)ListMembershipsRequest
(message)ListMembershipsResponse
(message)Membership
(message)Membership.InfrastructureType
(enum)MembershipEndpoint
(message)MembershipState
(message)MembershipState.Code
(enum)MonitoringConfig
(message)MultiCloudCluster
(message)OnPremCluster
(message)OnPremCluster.ClusterType
(enum)OperationMetadata
(message)ResourceManifest
(message)ResourceOptions
(message)TypeMeta
(message)UpdateMembershipRequest
(message)
GkeHub
The GKE Hub service handles the registration of many Kubernetes clusters to Google Cloud, represented with the Membership
resource.
GKE Hub is currently available in the global region and all regions in https://cloud.google.com/compute/docs/regions-zones. Feature is only available in global region while membership is global region and all the regions.
Membership management may be non-trivial: it is recommended to use one of the Google-provided client libraries or tools where possible when working with Membership resources.
CreateMembership |
---|
Creates a new Membership. This is currently only supported for GKE clusters on Google Cloud. To register other clusters, follow the instructions at https://cloud.google.com/kubernetes-engine/enterprise/multicluster-management/connect/registering-a-cluster.
|
DeleteMembership |
---|
Removes a Membership. This is currently only supported for GKE clusters on Google Cloud. To unregister other clusters, follow the instructions at https://cloud.google.com/kubernetes-engine/enterprise/multicluster-management/connect/unregistering-a-cluster.
|
GenerateConnectManifest |
---|
Generates the manifest for deployment of the GKE connect agent. This method is used internally by Google-provided libraries. Most clients should not need to call this method directly.
|
GetMembership |
---|
Gets the details of a Membership.
|
InitializeHub |
---|
Initializes the Hub in this project, which includes creating the default Hub Service Account and the Hub Workload Identity Pool. Initialization is optional, and happens automatically when the first Membership is created. InitializeHub should be called when the first Membership cannot be registered without these resources. A common example is granting the Hub Service Account access to another project, which requires the account to exist first.
|
ListMemberships |
---|
Lists Memberships in a given project and location.
|
UpdateMembership |
---|
Updates an existing Membership.
|
ApplianceCluster
ApplianceCluster contains information specific to GDC Edge Appliance Clusters.
Fields | |
---|---|
resource_link |
Immutable. Self-link of the Google Cloud resource for the Appliance Cluster. For example: //transferappliance.googleapis.com/projects/my-project/locations/us-west1-a/appliances/my-appliance |
Authority
Authority encodes how Google will recognize identities from this Membership. See the workload identity documentation for more details: https://cloud.google.com/kubernetes-engine/docs/how-to/workload-identity
Fields | |
---|---|
issuer |
Optional. A JSON Web Token (JWT) issuer URI. If set, then Google will allow valid OIDC tokens from this issuer to authenticate within the workload_identity_pool. OIDC discovery will be performed on this URI to validate tokens from the issuer, unless Clearing |
oidc_jwks |
Optional. OIDC verification keys for this Membership in JWKS format (RFC 7517). When this field is set, OIDC discovery will NOT be performed on |
identity_provider |
Output only. An identity provider that reflects the |
workload_identity_pool |
Output only. The name of the workload identity pool in which There is a single Workload Identity Pool per Hub that is shared between all Memberships that belong to that Hub. For a Hub hosted in {PROJECT_ID}, the workload pool format is |
ConnectAgentResource
ConnectAgentResource represents a Kubernetes resource manifest for Connect Agent deployment.
Fields | |
---|---|
type |
Kubernetes type of the resource. |
manifest |
YAML manifest of the resource. |
CreateMembershipRequest
Request message for the GkeHub.CreateMembership
method.
Fields | |
---|---|
parent |
Required. The parent (project and location) where the Memberships will be created. Specified in the format Authorization requires the following IAM permission on the specified resource
|
membership_id |
Required. Client chosen ID for the membership.
Which can be expressed as the regex: |
resource |
Required. The membership to create. |
DeleteMembershipRequest
Request message for GkeHub.DeleteMembership
method.
Fields | |
---|---|
name |
Required. The Membership resource name in the format Authorization requires the following IAM permission on the specified resource
|
force |
Optional. If set to true, any subresource from this Membership will also be deleted. Otherwise, the request will only work if the Membership has no subresource. |
EdgeCluster
EdgeCluster contains information specific to Google Edge Clusters.
Fields | |
---|---|
resource_link |
Immutable. Self-link of the Google Cloud resource for the Edge Cluster. For example: //edgecontainer.googleapis.com/projects/my-project/locations/us-west1-a/clusters/my-cluster |
GenerateConnectManifestRequest
Request message for GkeHub.GenerateConnectManifest
method. .
Fields | |
---|---|
name |
Required. The Membership resource name the Agent will associate with, in the format Authorization requires the following IAM permission on the specified resource
|
namespace |
Optional. Namespace for GKE Connect agent resources. Defaults to The Connect Agent is authorized automatically when run in the default namespace. Otherwise, explicit authorization must be granted with an additional IAM binding. |
proxy |
Optional. URI of a proxy if connectivity from the agent to gkeconnect.googleapis.com requires the use of a proxy. Format must be in the form |
version |
Optional. The Connect agent version to use. Defaults to the most current version. |
is_upgrade |
Optional. If true, generate the resources for upgrade only. Some resources generated only for installation (e.g. secrets) will be excluded. |
registry |
Optional. The registry to fetch the connect agent image from. Defaults to gcr.io/gkeconnect. |
image_pull_secret_content |
Optional. The image pull secret content for the registry, if not public. |
GenerateConnectManifestResponse
GenerateConnectManifestResponse contains manifest information for installing/upgrading a Connect agent.
Fields | |
---|---|
manifest[] |
The ordered list of Kubernetes resources that need to be applied to the cluster for GKE Connect agent installation/upgrade. |
GetMembershipRequest
Request message for GkeHub.GetMembership
method.
Fields | |
---|---|
name |
Required. The Membership resource name in the format Authorization requires the following IAM permission on the specified resource
|
GkeCluster
GkeCluster contains information specific to GKE clusters.
Fields | |
---|---|
resource_link |
Immutable. Self-link of the Google Cloud resource for the GKE cluster. For example:
Zonal clusters are also supported. |
cluster_missing |
Output only. If cluster_missing is set then it denotes that the GKE cluster no longer exists in the GKE Control Plane. |
InitializeHubRequest
Request message for the InitializeHub method.
Fields | |
---|---|
project |
Required. The Hub to initialize, in the format |
InitializeHubResponse
Response message for the InitializeHub method.
Fields | |
---|---|
service_identity |
Name of the Hub default service identity, in the format:
The service account has |
workload_identity_pool |
The Workload Identity Pool used for Workload Identity-enabled clusters registered with this Hub. Format: |
KubernetesMetadata
KubernetesMetadata provides informational metadata for Memberships that are created from Kubernetes Endpoints (currently, these are equivalent to Kubernetes clusters).
Fields | |
---|---|
kubernetes_api_server_version |
Output only. Kubernetes API server version string as reported by '/version'. |
node_provider_id |
Output only. Node providerID as reported by the first node in the list of nodes on the Kubernetes endpoint. On Kubernetes platforms that support zero-node clusters (like GKE-on-GCP), the node_count will be zero and the node_provider_id will be empty. |
node_count |
Output only. Node count as reported by Kubernetes nodes resources. |
vcpu_count |
Output only. vCPU count as reported by Kubernetes nodes resources. |
memory_mb |
Output only. The total memory capacity as reported by the sum of all Kubernetes nodes resources, defined in MB. |
update_time |
Output only. The time at which these details were last updated. This update_time is different from the Membership-level update_time since EndpointDetails are updated internally for API consumers. |
KubernetesResource
KubernetesResource contains the YAML manifests and configuration for Membership Kubernetes resources in the cluster. After CreateMembership or UpdateMembership, these resources should be re-applied in the cluster.
Fields | |
---|---|
membership_cr_manifest |
Input only. The YAML representation of the Membership CR. This field is ignored for GKE clusters where Hub can read the CR directly. Callers should provide the CR that is currently present in the cluster during Create or Update, or leave this field empty if none exists. The CR manifest is used to validate the cluster has not been registered with another Membership. |
membership_resources[] |
Output only. Additional Kubernetes resources that need to be applied to the cluster after Membership creation, and after every update. This field is only populated in the Membership returned from a successful long-running operation from CreateMembership or UpdateMembership. It is not populated during normal GetMembership or ListMemberships requests. To get the resource manifest after the initial registration, the caller should make a UpdateMembership call with an empty field mask. |
connect_resources[] |
Output only. The Kubernetes resources for installing the GKE Connect agent. This field is only populated in the Membership returned from a successful long-running operation from CreateMembership or UpdateMembership. It is not populated during normal GetMembership or ListMemberships requests. To get the resource manifest after the initial registration, the caller should make a UpdateMembership call with an empty field mask. |
resource_options |
Optional. Options for Kubernetes resource generation. |
ListMembershipsRequest
Request message for GkeHub.ListMemberships
method.
Fields | |
---|---|
parent |
Required. The parent (project and location) where the Memberships will be listed. Specified in the format Authorization requires the following IAM permission on the specified resource
|
page_size |
Optional. When requesting a 'page' of resources, |
page_token |
Optional. Token returned by previous call to |
filter |
Optional. Lists Memberships that match the filter expression, following the syntax outlined in https://google.aip.dev/160. Examples:
|
order_by |
Optional. One or more fields to compare and use to sort the output. See https://google.aip.dev/132#ordering. |
ListMembershipsResponse
Response message for the GkeHub.ListMemberships
method.
Fields | |
---|---|
resources[] |
The list of matching Memberships. |
next_page_token |
A token to request the next page of resources from the |
unreachable[] |
List of locations that could not be reached while fetching this list. |
Membership
Membership contains information about a member cluster.
Fields | |
---|---|
name |
Output only. The full, unique name of this Membership resource in the format
Which can be expressed as the regex: |
labels |
Optional. Labels for this membership. |
description |
Output only. Description of this membership, limited to 63 characters. Must match the regex: This field is present for legacy purposes. |
state |
Output only. State of the Membership resource. |
create_time |
Output only. When the Membership was created. |
update_time |
Output only. When the Membership was last updated. |
delete_time |
Output only. When the Membership was deleted. |
external_id |
Optional. An externally-generated and managed ID for this Membership. This ID may be modified after creation, but this is not recommended. For GKE clusters, external_id is managed by the Hub API and updates will be ignored. The ID must match the regex: If this Membership represents a Kubernetes cluster, this value should be set to the UID of the |
authority |
Optional. How to identify workloads from this Membership. See the documentation on Workload Identity for more details: https://cloud.google.com/kubernetes-engine/docs/how-to/workload-identity |
last_connection_time |
Output only. For clusters using Connect, the timestamp of the most recent connection established with Google Cloud. This time is updated every several minutes, not continuously. For clusters that do not use GKE Connect, or that have never connected successfully, this field will be unset. |
unique_id |
Output only. Google-generated UUID for this resource. This is unique across all Membership resources. If a Membership resource is deleted and another resource with the same name is created, it gets a different unique_id. |
infrastructure_type |
Optional. The infrastructure type this Membership is running on. |
monitoring_config |
Optional. The monitoring config information for this membership. |
Union field type . Type of resource represented by this Membership type can be only one of the following: |
|
endpoint |
Optional. Endpoint information to reach this member. |
InfrastructureType
Specifies the infrastructure type of a Membership. Infrastructure type is used by Hub to control infrastructure-specific behavior, including pricing.
Each GKE distribution (on-GCP, on-Prem, on-X,...) will set this field automatically, but Attached Clusters customers should specify a type during registration.
Enums | |
---|---|
INFRASTRUCTURE_TYPE_UNSPECIFIED |
No type was specified. Some Hub functionality may require a type be specified, and will not support Memberships with this value. |
ON_PREM |
Private infrastructure that is owned or operated by customer. This includes GKE distributions such as GKE-OnPrem and GKE-OnBareMetal. |
MULTI_CLOUD |
Public cloud infrastructure. |
MembershipEndpoint
MembershipEndpoint contains information needed to contact a Kubernetes API, endpoint and any additional Kubernetes metadata.
Fields | |
---|---|
kubernetes_metadata |
Output only. Useful Kubernetes-specific metadata. |
kubernetes_resource |
Optional. The in-cluster Kubernetes Resources that should be applied for a correctly registered cluster, in the steady state. These resources:
|
Union field type . Cluster information of the registered cluster. type can be only one of the following: |
|
gke_cluster |
Optional. Specific information for a GKE-on-GCP cluster. |
on_prem_cluster |
Optional. Specific information for a GKE On-Prem cluster. An onprem user-cluster who has no resourceLink is not allowed to use this field, it should have a nil "type" instead. |
multi_cloud_cluster |
Optional. Specific information for a GKE Multi-Cloud cluster. |
edge_cluster |
Optional. Specific information for a Google Edge cluster. |
appliance_cluster |
Optional. Specific information for a GDC Edge Appliance cluster. |
MembershipState
MembershipState describes the state of a Membership resource.
Fields | |
---|---|
code |
Output only. The current state of the Membership resource. |
Code
Code describes the state of a Membership resource.
Enums | |
---|---|
CODE_UNSPECIFIED |
The code is not set. |
CREATING |
The cluster is being registered. |
READY |
The cluster is registered. |
DELETING |
The cluster is being unregistered. |
UPDATING |
The Membership is being updated. |
SERVICE_UPDATING |
The Membership is being updated by the Hub Service. |
MonitoringConfig
MonitoringConfig informs Fleet-based applications/services/UIs how the metrics for the underlying cluster is reported to cloud monitoring services. It can be set from empty to non-empty, but can't be mutated directly to prevent accidentally breaking the constinousty of metrics.
Fields | |
---|---|
project_id |
Optional. Project used to report Metrics |
location |
Optional. Location used to report Metrics |
cluster |
Optional. Cluster name used to report metrics. For Anthos on VMWare/Baremetal/MultiCloud clusters, it would be in format {cluster_type}/{cluster_name}, e.g., "awsClusters/cluster_1". |
kubernetes_metrics_prefix |
Optional. Kubernetes system metrics, if available, are written to this prefix. This defaults to kubernetes.io for GKE, and kubernetes.io/anthos for Anthos eventually. Noted: Anthos MultiCloud will have kubernetes.io prefix today but will migration to be under kubernetes.io/anthos. |
cluster_hash |
Optional. For GKE and Multicloud clusters, this is the UUID of the cluster resource. For VMWare and Baremetal clusters, this is the kube-system UID. |
MultiCloudCluster
MultiCloudCluster contains information specific to GKE Multi-Cloud clusters.
Fields | |
---|---|
resource_link |
Immutable. Self-link of the Google Cloud resource for the GKE Multi-Cloud cluster. For example: //gkemulticloud.googleapis.com/projects/my-project/locations/us-west1-a/awsClusters/my-cluster //gkemulticloud.googleapis.com/projects/my-project/locations/us-west1-a/azureClusters/my-cluster //gkemulticloud.googleapis.com/projects/my-project/locations/us-west1-a/attachedClusters/my-cluster |
cluster_missing |
Output only. If cluster_missing is set then it denotes that API(gkemulticloud.googleapis.com) resource for this GKE Multi-Cloud cluster no longer exists. |
OnPremCluster
OnPremCluster contains information specific to GKE On-Prem clusters.
Fields | |
---|---|
resource_link |
Immutable. Self-link of the Google Cloud resource for the GKE On-Prem cluster. For example: //gkeonprem.googleapis.com/projects/my-project/locations/us-west1-a/vmwareClusters/my-cluster //gkeonprem.googleapis.com/projects/my-project/locations/us-west1-a/bareMetalClusters/my-cluster |
cluster_missing |
Output only. If cluster_missing is set then it denotes that API(gkeonprem.googleapis.com) resource for this GKE On-Prem cluster no longer exists. |
admin_cluster |
Immutable. Whether the cluster is an admin cluster. |
cluster_type |
Immutable. The on prem cluster's type. |
ClusterType
ClusterType describes on prem cluster's type.
Enums | |
---|---|
CLUSTERTYPE_UNSPECIFIED |
The ClusterType is not set. |
BOOTSTRAP |
The ClusterType is bootstrap cluster. |
HYBRID |
The ClusterType is baremetal hybrid cluster. |
STANDALONE |
The ClusterType is baremetal standalone cluster. |
USER |
The ClusterType is user cluster. |
OperationMetadata
Represents the metadata of the long-running operation.
Fields | |
---|---|
create_time |
Output only. The time the operation was created. |
end_time |
Output only. The time the operation finished running. |
target |
Output only. Server-defined resource path for the target of the operation. |
verb |
Output only. Name of the verb executed by the operation. |
status_detail |
Output only. Human-readable status of the operation, if any. |
cancel_requested |
Output only. Identifies whether the user has requested cancellation of the operation. Operations that have successfully been cancelled have [Operation.error][] value with a |
api_version |
Output only. API version used to start the operation. |
ResourceManifest
ResourceManifest represents a single Kubernetes resource to be applied to the cluster.
Fields | |
---|---|
manifest |
YAML manifest of the resource. |
cluster_scoped |
Whether the resource provided in the manifest is This field is used for REST mapping when applying the resource in a cluster. |
ResourceOptions
ResourceOptions represent options for Kubernetes resource generation.
Fields | |
---|---|
connect_version |
Optional. The Connect agent version to use for connect_resources. Defaults to the latest GKE Connect version. The version must be a currently supported version, obsolete versions will be rejected. |
v1beta1_crd |
Optional. Use |
k8s_version |
Optional. Major version of the Kubernetes cluster. This is only used to determine which version to use for the CustomResourceDefinition resources, |
TypeMeta
TypeMeta is the type information needed for content unmarshalling of Kubernetes resources in the manifest.
Fields | |
---|---|
kind |
Kind of the resource (e.g. Deployment). |
api_version |
APIVersion of the resource (e.g. v1). |
UpdateMembershipRequest
Request message for GkeHub.UpdateMembership
method.
Fields | |
---|---|
name |
Required. The Membership resource name in the format Authorization requires the following IAM permission on the specified resource
|
update_mask |
Required. Mask of fields to update. |
resource |
Required. Only fields specified in update_mask are updated. If you specify a field in the update_mask but don't specify its value here that field will be deleted. If you are updating a map field, set the value of a key to null or empty string to delete the key from the map. It's not possible to update a key's value to the empty string. If you specify the update_mask to be a special path "*", fully replaces all user-modifiable fields to match |