annotations
Optional
|
list (object)
Optional. Client-specified annotations.
|
annotations[]
Optional
|
object
|
annotations[].key
Optional
|
string
Key for the annotation.
|
annotations[].value
Optional
|
string
Value for the annotation.
|
container
Optional
|
object
Optional. Container that runs upon startup for each workstation using this workstation configuration.
|
container.args
Optional
|
list (string)
Optional. Arguments passed to the entrypoint.
|
container.args[]
Optional
|
string
|
container.command
Optional
|
list (string)
Optional. If set, overrides the default ENTRYPOINT specified by the image.
|
container.command[]
Optional
|
string
|
container.env
Optional
|
list (object)
Optional. Environment variables passed to the container's entrypoint.
|
container.env[]
Optional
|
object
|
container.env[].name
Optional
|
string
Name is the name of the environment variable.
|
container.env[].value
Optional
|
string
Value is the value of the environment variable.
|
container.image
Optional
|
string
Optional. A Docker container image that defines a custom environment.
Cloud Workstations provides a number of
[preconfigured
images](https://cloud.google.com/workstations/docs/preconfigured-base-images),
but you can create your own
[custom container
images](https://cloud.google.com/workstations/docs/custom-container-images).
If using a private image, the `host.gceInstance.serviceAccount` field
must be specified in the workstation configuration and must have
permission to pull the specified image. Otherwise, the image must be
publicly accessible.
|
container.runAsUser
Optional
|
integer
Optional. If set, overrides the USER specified in the image with the given uid.
|
container.workingDir
Optional
|
string
Optional. If set, overrides the default DIR specified by the image.
|
displayName
Optional
|
string
Optional. Human-readable name for this workstation configuration.
|
encryptionKey
Optional
|
object
Immutable. Encrypts resources of this workstation configuration using a
customer-managed encryption key (CMEK).
If specified, the boot disk of the Compute Engine instance and the
persistent disk are encrypted using this encryption key. If
this field is not set, the disks are encrypted using a generated
key. Customer-managed encryption keys do not protect disk metadata.
If the customer-managed encryption key is rotated, when the workstation
instance is stopped, the system attempts to recreate the
persistent disk with the new version of the key. Be sure to keep
older versions of the key until the persistent disk is recreated.
Otherwise, data on the persistent disk might be lost.
If the encryption key is revoked, the workstation session automatically
stops within 7 hours.
Immutable after the workstation configuration is created.
|
encryptionKey.kmsCryptoKeyRef
Optional
|
object
Immutable. A reference to the Google Cloud KMS encryption key. For example, `"projects/PROJECT_ID/locations/REGION/keyRings/KEY_RING/cryptoKeys/KEY_NAME"`. The key must be in the same region as the workstation configuration.
|
encryptionKey.kmsCryptoKeyRef.external
Optional
|
string
A reference to an externally managed KMSCryptoKey. Should be in the format `projects/[kms_project_id]/locations/[region]/keyRings/[key_ring_id]/cryptoKeys/[key]`.
|
encryptionKey.kmsCryptoKeyRef.name
Optional
|
string
The `name` of a `KMSCryptoKey` resource.
|
encryptionKey.kmsCryptoKeyRef.namespace
Optional
|
string
The `namespace` of a `KMSCryptoKey` resource.
|
encryptionKey.serviceAccountRef
Optional
|
object
Immutable. A reference to a service account to use with the specified KMS key. We recommend that you use a separate service account and follow KMS best practices. For more information, see [Separation of duties](https://cloud.google.com/kms/docs/separation-of-duties) and `gcloud kms keys add-iam-policy-binding` [`--member`](https://cloud.google.com/sdk/gcloud/reference/kms/keys/add-iam-policy-binding#--member).
|
encryptionKey.serviceAccountRef.external
Optional
|
string
The `email` field of an `IAMServiceAccount` resource.
|
encryptionKey.serviceAccountRef.name
Optional
|
string
Name of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names
|
encryptionKey.serviceAccountRef.namespace
Optional
|
string
Namespace of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/namespaces/
|
host
Optional
|
object
Optional. Runtime host for the workstation.
|
host.gceInstance
Optional
|
object
Specifies a Compute Engine instance as the host.
|
host.gceInstance.bootDiskSizeGB
Optional
|
integer
Optional. The size of the boot disk for the VM in gigabytes (GB). The minimum boot disk size is `30` GB. Defaults to `50` GB.
|
host.gceInstance.confidentialInstanceConfig
Optional
|
object
Optional. A set of Compute Engine Confidential VM instance options.
|
host.gceInstance.confidentialInstanceConfig.enableConfidentialCompute
Optional
|
boolean
Optional. Whether the instance has confidential compute enabled.
|
host.gceInstance.disablePublicIPAddresses
Optional
|
boolean
Optional. When set to true, disables public IP addresses for VMs. If you disable public IP addresses, you must set up Private Google Access or Cloud NAT on your network. If you use Private Google Access and you use `private.googleapis.com` or `restricted.googleapis.com` for Container Registry and Artifact Registry, make sure that you set up DNS records for domains `*.gcr.io` and `*.pkg.dev`. Defaults to false (VMs have public IP addresses).
|
host.gceInstance.enableNestedVirtualization
Optional
|
boolean
Optional. Whether to enable nested virtualization on Cloud Workstations
VMs created under this workstation configuration.
Nested virtualization lets you run virtual machine (VM) instances
inside your workstation. Before enabling nested virtualization,
consider the following important considerations. Cloud Workstations
instances are subject to the [same restrictions as Compute Engine
instances](https://cloud.google.com/compute/docs/instances/nested-virtualization/overview#restrictions):
* **Organization policy**: projects, folders, or
organizations may be restricted from creating nested VMs if the
**Disable VM nested virtualization** constraint is enforced in
the organization policy. For more information, see the
Compute Engine section,
[Checking whether nested virtualization is
allowed](https://cloud.google.com/compute/docs/instances/nested-virtualization/managing-constraint#checking_whether_nested_virtualization_is_allowed).
* **Performance**: nested VMs might experience a 10% or greater
decrease in performance for workloads that are CPU-bound and
possibly greater than a 10% decrease for workloads that are
input/output bound.
* **Machine Type**: nested virtualization can only be enabled on
workstation configurations that specify a
[machine_type][google.cloud.workstations.v1.WorkstationConfig.Host.GceInstance.machine_type]
in the N1 or N2 machine series.
* **GPUs**: nested virtualization may not be enabled on workstation
configurations with accelerators.
* **Operating System**: Because
[Container-Optimized
OS](https://cloud.google.com/compute/docs/images/os-details#container-optimized_os_cos)
does not support nested virtualization, when nested virtualization is
enabled, the underlying Compute Engine VM instances boot from an
[Ubuntu
LTS](https://cloud.google.com/compute/docs/images/os-details#ubuntu_lts)
image.
|
host.gceInstance.machineType
Optional
|
string
Optional. The type of machine to use for VM instances—for example, `"e2-standard-4"`. For more information about machine types that Cloud Workstations supports, see the list of [available machine types](https://cloud.google.com/workstations/docs/available-machine-types).
|
host.gceInstance.poolSize
Optional
|
integer
Optional. The number of VMs that the system should keep idle so that new workstations can be started quickly for new users. Defaults to `0` in the API.
|
host.gceInstance.serviceAccountRef
Optional
|
object
Optional. A reference to the service account for Cloud
Workstations VMs created with this configuration. When specified, be
sure that the service account has `logginglogEntries.create` permission
on the project so it can write logs out to Cloud Logging. If using a
custom container image, the service account must have permissions to
pull the specified image.
If you as the administrator want to be able to `ssh` into the
underlying VM, you need to set this value to a service account
for which you have the `iam.serviceAccounts.actAs` permission.
Conversely, if you don't want anyone to be able to `ssh` into the
underlying VM, use a service account where no one has that
permission.
If not set, VMs run with a service account provided by the
Cloud Workstations service, and the image must be publicly
accessible.
|
host.gceInstance.serviceAccountRef.external
Optional
|
string
The `email` field of an `IAMServiceAccount` resource.
|
host.gceInstance.serviceAccountRef.name
Optional
|
string
Name of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names
|
host.gceInstance.serviceAccountRef.namespace
Optional
|
string
Namespace of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/namespaces/
|
host.gceInstance.serviceAccountScopes
Optional
|
list (string)
Optional. Scopes to grant to the [service_account][google.cloud.workstations.v1.WorkstationConfig.Host.GceInstance.service_account]. Various scopes are automatically added based on feature usage. When specified, users of workstations under this configuration must have `iam.serviceAccounts.actAs` on the service account.
|
host.gceInstance.serviceAccountScopes[]
Optional
|
string
|
host.gceInstance.shieldedInstanceConfig
Optional
|
object
Optional. A set of Compute Engine Shielded instance options.
|
host.gceInstance.shieldedInstanceConfig.enableIntegrityMonitoring
Optional
|
boolean
Optional. Whether the instance has integrity monitoring enabled.
|
host.gceInstance.shieldedInstanceConfig.enableSecureBoot
Optional
|
boolean
Optional. Whether the instance has Secure Boot enabled.
|
host.gceInstance.shieldedInstanceConfig.enableVTPM
Optional
|
boolean
Optional. Whether the instance has the vTPM enabled.
|
host.gceInstance.tags
Optional
|
list (string)
Optional. Network tags to add to the Compute Engine VMs backing the workstations. This option applies [network tags](https://cloud.google.com/vpc/docs/add-remove-network-tags) to VMs created with this configuration. These network tags enable the creation of [firewall rules](https://cloud.google.com/workstations/docs/configure-firewall-rules).
|
host.gceInstance.tags[]
Optional
|
string
|
idleTimeout
Optional
|
string
Optional. Number of seconds to wait before automatically stopping a
workstation after it last received user traffic.
A value of `"0s"` indicates that Cloud Workstations VMs created with this
configuration should never time out due to idleness.
Provide
[duration](https://developers.google.com/protocol-buffers/docs/reference/google.protobuf#duration)
terminated by `s` for seconds—for example, `"7200s"` (2 hours).
The default is `"1200s"` (20 minutes).
|
labels
Optional
|
list (object)
Optional. [Labels](https://cloud.google.com/workstations/docs/label-resources) that are applied to the workstation configuration and that are also propagated to the underlying Compute Engine resources.
|
labels[]
Optional
|
object
|
labels[].key
Optional
|
string
Key for the label.
|
labels[].value
Optional
|
string
Value for the label.
|
parentRef
Required*
|
object
Parent is a reference to the parent WorkstationCluster for this WorkstationConfig.
|
parentRef.external
Optional
|
string
A reference to an externally managed WorkstationCluster resource. Should be in the format "projects/{{projectID}}/locations/{{location}}/workstationClusters/{{workstationclusterID}}".
|
parentRef.name
Optional
|
string
The name of a WorkstationCluster resource.
|
parentRef.namespace
Optional
|
string
The namespace of a WorkstationCluster resource.
|
persistentDirectories
Optional
|
list (object)
Optional. Directories to persist across workstation sessions.
|
persistentDirectories[]
Optional
|
object
|
persistentDirectories[].gcePD
Optional
|
object
A PersistentDirectory backed by a Compute Engine persistent disk.
|
persistentDirectories[].gcePD.diskType
Optional
|
string
Optional. The [type of the persistent disk](https://cloud.google.com/compute/docs/disks#disk-types) for the home directory. Defaults to `"pd-standard"`.
|
persistentDirectories[].gcePD.fsType
Optional
|
string
Optional. Type of file system that the disk should be formatted with. The workstation image must support this file system type. Must be empty if [source_snapshot][google.cloud.workstations.v1.WorkstationConfig.PersistentDirectory.GceRegionalPersistentDisk.source_snapshot] is set. Defaults to `"ext4"`.
|
persistentDirectories[].gcePD.reclaimPolicy
Optional
|
string
Optional. Whether the persistent disk should be deleted when the workstation is deleted. Valid values are `DELETE` and `RETAIN`. Defaults to `DELETE`.
|
persistentDirectories[].gcePD.sizeGB
Optional
|
integer
Optional. The GB capacity of a persistent home directory for each
workstation created with this configuration. Must be empty if
[source_snapshot][google.cloud.workstations.v1.WorkstationConfig.PersistentDirectory.GceRegionalPersistentDisk.source_snapshot]
is set.
Valid values are `10`, `50`, `100`, `200`, `500`, or `1000`.
Defaults to `200`. If less than `200` GB, the
[disk_type][google.cloud.workstations.v1.WorkstationConfig.PersistentDirectory.GceRegionalPersistentDisk.disk_type]
must be
`"pd-balanced"` or `"pd-ssd"`.
|
persistentDirectories[].gcePD.sourceSnapshot
Optional
|
string
Optional. Name of the snapshot to use as the source for the disk. If set, [size_gb][google.cloud.workstations.v1.WorkstationConfig.PersistentDirectory.GceRegionalPersistentDisk.size_gb] and [fs_type][google.cloud.workstations.v1.WorkstationConfig.PersistentDirectory.GceRegionalPersistentDisk.fs_type] must be empty.
|
persistentDirectories[].mountPath
Optional
|
string
Optional. Location of this directory in the running workstation.
|
readinessChecks
Optional
|
list (object)
Optional. Readiness checks to perform when starting a workstation using this workstation configuration. Mark a workstation as running only after all specified readiness checks return 200 status codes.
|
readinessChecks[]
Optional
|
object
|
readinessChecks[].path
Optional
|
string
Optional. Path to which the request should be sent.
|
readinessChecks[].port
Optional
|
integer
Optional. Port to which the request should be sent.
|
replicaZones
Optional
|
list (string)
Optional. Immutable. Specifies the zones used to replicate the VM and disk
resources within the region. If set, exactly two zones within the
workstation cluster's region must be specified—for example,
`['us-central1-a', 'us-central1-f']`. If this field is empty, two default
zones within the region are used.
Immutable after the workstation configuration is created.
|
replicaZones[]
Optional
|
string
|
resourceID
Optional
|
string
Immutable. The WorkstationConfig name. If not given, the metadata.name will be used.
|
runningTimeout
Optional
|
string
Optional. Number of seconds that a workstation can run until it is
automatically shut down. We recommend that workstations be shut down daily
to reduce costs and so that security updates can be applied upon restart.
The
[idle_timeout][google.cloud.workstations.v1.WorkstationConfig.idle_timeout]
and
[running_timeout][google.cloud.workstations.v1.WorkstationConfig.running_timeout]
fields are independent of each other. Note that the
[running_timeout][google.cloud.workstations.v1.WorkstationConfig.running_timeout]
field shuts down VMs after the specified time, regardless of whether or not
the VMs are idle.
Provide duration terminated by `s` for seconds—for example, `"54000s"`
(15 hours). Defaults to `"43200s"` (12 hours). A value of `"0s"` indicates
that workstations using this configuration should never time out. If
[encryption_key][google.cloud.workstations.v1.WorkstationConfig.encryption_key]
is set, it must be greater than `"0s"` and less than
`"86400s"` (24 hours).
Warning: A value of `"0s"` indicates that Cloud Workstations VMs created
with this configuration have no maximum running time. This is strongly
discouraged because you incur costs and will not pick up security updates.
|