Google Distributed Cloud runs in your data center in a vSphere environment. This document describes requirements for your vSphere environment.
Version compatibility
The vSphere requirements vary according to which version of Google Distributed Cloud you are usin. For more information, see the version compatibility matrix for fully supported versions and earlier versions.
vSphere is VMware's server virtualization software. vSphere includes ESXi and vCenter Server.
Supported versions
Google Distributed Cloud supports these versions of ESXi and vCenter Server::
- 6.5 Update 3 and later builds of version 6.5
- 6.7 Update 3 and later builds of version 6.7
- 7.0 Update 1 and later builds of version 7.0
If you use the vSphere CSI driver, the version for both ESXi and vCenter Server must be 6.7 Update 3 (or later) or 7.0 Update 1 (or later).
License requirements
You need the following vSphere licenses:
- A vSphere Enterprise Plus or vSphere Standard license. - We recommend The Enterprise Plus license, because it allows you to enable the Distributed Resource Scheduler (DRS) - Along with this license, you must purchase a support subscription for at least one year. 
- A vCenter Server Standard license. Along with this license, you must purchase a support subscription for at least one year. 
Hardware requirements
Google Distributed Cloud runs on a set of physical hosts that run the VMware ESXi hypervisor. To learn about the hardware requirements for ESXi, see ESXi Hardware Requirements.
By default, Google Distributed Cloud automatically creates Distributed Resource Scheduler (DRS) anti-affinity rules for your admin cluster and user cluster's nodes, causing them to be spread across at least three physical hosts in your datacenter.
This feature requires that your vSphere environment meets the following conditions:
- VMware DRS is enabled. VMware DRS requires vSphere Enterprise Plus license edition. 
- Your vSphere user account has the - Host.Inventory.Modify clusterprivilege.
- There are at least three physical hosts available. 
Recall that if you have a vSphere Standard license, you cannot enable DRS.
If you do not have DRS enabled, or if you do not have at least three hosts where
vSphere VMs can be scheduled, set antiAffinityGroups.enabled to false in
admin cluster
and
user cluster
configuration filess.
vCenter user account privileges
You can define custom roles in vCenter or use vCenter system roles for the various users in your organization, including your Anthos cluster administrator and the users who develop on those clusters.
The vCenter user account that you use to install Google Distributed Cloud must have sufficient privileges. For example, a user account that is assigned the vCenter's Administrator role has privileges for complete access to all vCenter objects and provides an Anthos cluster administrator with full access.
For other vCenter user accounts, you create custom roles to assign the necessary privileges to your cluster's users.
- Use the following table to understand what the minimum required set of privileges are for your Anthos cluster users.
- A user account with administrator privileges can use the following commands to create a custom vCenter role, define the minimum required privileges to that role, and then assign that custom role to an existing vCenter user account.
To learn how to manage privileges, refer to Managing Permissions for vCenter Components.
vCenter user account privileges with folders
Starting with Google Distributed Cloud version 1.4, you can place VM images and templates in a separate VM folder, as opposed to the global datacenter folder. This is only supported in the v1 format of the admin cluster configuration.
In your
admin cluster configuration file,
create a new key called folder. Set the value of folder to the name of the
vCenter folder that you want to use for this Google Distributed Cloud deployment.
All user clusters will inherit the folder automatically. Do not specify a folder
in your
user cluster configuration files.
If the folder key is not specified, or if the value is left blank, the top
level Datacenter VM folder is used. Like other vCenter resources, the folder
must be created prior to deployment, with the appropriate permissions.
For example, in the admin-cluster.yaml for your deployment:
apiVersion: v1 kind: AdminCluster #... vCenter: address: mtv-example-vc01.anthos datacenter: mtv-example-vc01 cluster: admin-permissions resourcePool: example-cluster-resourcepool datastore: example-cluster-datastore # insert the following new line with the path to the vcenter folder here. folder: my-vm-folder
Setting permissions when using a folder
In Google Distributed Cloud versions older than 1.4, we required a set of permissions to be applied to the entire vCenter cluster. While this was simpler to configure, these permissions did not constrain the Google Distributed Cloud vCenter user sufficiently. While the set of permissions remain the same in Google Distributed Cloud 1.4, we can now apply them to a much smaller set of objects, provided a folder is specified for the deployment, as described above.
The following is a set of roles, their permissions, and the objects the roles must be applied to. Entries marked "(recursively)" must be applied with the Propagate field set to true, so the permissions are inherited by all child objects.
Role: ClusterEditor
Description: Apply DRS rules to Clusters + Read Only Access
Objects: $VCenter.Cluster(recursively)
Privileges: System.Read System.View System.Anonymous Host.Inventory.EditCluster
Role: SessionValidator
Description: Validate an existing VCenter session + Read Only Access
Objects: $VCenter.Root
Privileges: System.Read System.View System.Anonymous Session.ValidateSessions
Role: ReadOnly
Description: Built in role that permits enumerating objects
Objects: $VCenter.Datacenter(recursively), $VCenter "VM Network"
Privileges: System.Read System.View System.Anonymous
Role: Anthos
Description: Set of permissions required to deploy, manage and monitor clusters.
Objects: $VCenter.Datastore(recursively), $VCenter.ResourcePool(recursively), $VCenter.Folder(recursively), $VCenter.Network(recursively)
Known issue: installer fails when creating vSphere datadisk
(Issue ID 156233307)
The Google Distributed Cloud installer can fail if custom roles are bound at the wrong permissions level.
When the role binding is incorrect, creating a vSphere datadisk with
govc hangs and the disk is created with a size equal to 0.
To fix the issue, you should bind the custom role at the
vSphere vcenter level (root).
If you want to bind the custom role at the DC level (or lower than root), you also need to bind the read-only role to the user at the root vCenter level.
For more information on role creation, see vCenter user account privileges.
Resource requirements for admin workstation, admin cluster, and user clusters
The physical ESXi hosts in your data center must provide enough storage, CPU, and RAM resources to fulfill the needs of the virtual machines that you will create during your initial installation of Google Distributed Cloud. Your data center must also provide enough virtual disk space to fulfill PersistentVolumeClaims (PVCs) created by Prometheus and Google Cloud Observability.
The initial installation of Google Distributed Cloud requires these resources:
- 36 vCPU
- 98241 MB RAM
- 2280 GB virtual disk space
For more detailed information on resource requirements, see CPU, RAM, and Storage requirements.