google.cloud.notebooks.v1.instance.proto Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of proto-google-cloud-notebooks-v1 Show documentation
Show all versions of proto-google-cloud-notebooks-v1 Show documentation
Proto library for google-cloud-notebooks
The newest version!
// Copyright 2024 Google LLC
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
syntax = "proto3";
package google.cloud.notebooks.v1;
import "google/api/field_behavior.proto";
import "google/api/resource.proto";
import "google/cloud/notebooks/v1/environment.proto";
import "google/protobuf/timestamp.proto";
option csharp_namespace = "Google.Cloud.Notebooks.V1";
option go_package = "cloud.google.com/go/notebooks/apiv1/notebookspb;notebookspb";
option java_multiple_files = true;
option java_outer_classname = "InstanceProto";
option java_package = "com.google.cloud.notebooks.v1";
option php_namespace = "Google\\Cloud\\Notebooks\\V1";
option ruby_package = "Google::Cloud::Notebooks::V1";
// Reservation Affinity for consuming Zonal reservation.
message ReservationAffinity {
// Indicates whether to consume capacity from an reservation or not.
enum Type {
// Default type.
TYPE_UNSPECIFIED = 0;
// Do not consume from any allocated capacity.
NO_RESERVATION = 1;
// Consume any reservation available.
ANY_RESERVATION = 2;
// Must consume from a specific reservation. Must specify key value fields
// for specifying the reservations.
SPECIFIC_RESERVATION = 3;
}
// Optional. Type of reservation to consume
Type consume_reservation_type = 1 [(google.api.field_behavior) = OPTIONAL];
// Optional. Corresponds to the label key of reservation resource.
string key = 2 [(google.api.field_behavior) = OPTIONAL];
// Optional. Corresponds to the label values of reservation resource.
repeated string values = 3 [(google.api.field_behavior) = OPTIONAL];
}
// The definition of a notebook instance.
message Instance {
option (google.api.resource) = {
type: "notebooks.googleapis.com/Instance"
pattern: "projects/{project}/instances/{instance}"
};
// Definition of the types of hardware accelerators that can be used on this
// instance.
enum AcceleratorType {
// Accelerator type is not specified.
ACCELERATOR_TYPE_UNSPECIFIED = 0;
// Accelerator type is Nvidia Tesla K80.
NVIDIA_TESLA_K80 = 1;
// Accelerator type is Nvidia Tesla P100.
NVIDIA_TESLA_P100 = 2;
// Accelerator type is Nvidia Tesla V100.
NVIDIA_TESLA_V100 = 3;
// Accelerator type is Nvidia Tesla P4.
NVIDIA_TESLA_P4 = 4;
// Accelerator type is Nvidia Tesla T4.
NVIDIA_TESLA_T4 = 5;
// Accelerator type is Nvidia Tesla A100.
NVIDIA_TESLA_A100 = 11;
// Accelerator type is NVIDIA Tesla T4 Virtual Workstations.
NVIDIA_TESLA_T4_VWS = 8;
// Accelerator type is NVIDIA Tesla P100 Virtual Workstations.
NVIDIA_TESLA_P100_VWS = 9;
// Accelerator type is NVIDIA Tesla P4 Virtual Workstations.
NVIDIA_TESLA_P4_VWS = 10;
// (Coming soon) Accelerator type is TPU V2.
TPU_V2 = 6;
// (Coming soon) Accelerator type is TPU V3.
TPU_V3 = 7;
}
// Definition of a hardware accelerator. Note that not all combinations
// of `type` and `core_count` are valid. Check [GPUs on Compute
// Engine](https://cloud.google.com/compute/docs/gpus/#gpus-list) to find a
// valid combination. TPUs are not supported.
message AcceleratorConfig {
// Type of this accelerator.
AcceleratorType type = 1;
// Count of cores of this accelerator.
int64 core_count = 2;
}
// The definition of the states of this instance.
enum State {
// State is not specified.
STATE_UNSPECIFIED = 0;
// The control logic is starting the instance.
STARTING = 1;
// The control logic is installing required frameworks and registering the
// instance with notebook proxy
PROVISIONING = 2;
// The instance is running.
ACTIVE = 3;
// The control logic is stopping the instance.
STOPPING = 4;
// The instance is stopped.
STOPPED = 5;
// The instance is deleted.
DELETED = 6;
// The instance is upgrading.
UPGRADING = 7;
// The instance is being created.
INITIALIZING = 8;
// The instance is getting registered.
REGISTERING = 9;
// The instance is suspending.
SUSPENDING = 10;
// The instance is suspended.
SUSPENDED = 11;
}
// Possible disk types for notebook instances.
enum DiskType {
// Disk type not set.
DISK_TYPE_UNSPECIFIED = 0;
// Standard persistent disk type.
PD_STANDARD = 1;
// SSD persistent disk type.
PD_SSD = 2;
// Balanced persistent disk type.
PD_BALANCED = 3;
// Extreme persistent disk type.
PD_EXTREME = 4;
}
// Definition of the disk encryption options.
enum DiskEncryption {
// Disk encryption is not specified.
DISK_ENCRYPTION_UNSPECIFIED = 0;
// Use Google managed encryption keys to encrypt the boot disk.
GMEK = 1;
// Use customer managed encryption keys to encrypt the boot disk.
CMEK = 2;
}
// An instance-attached disk resource.
message Disk {
// Guest OS features for boot disk.
message GuestOsFeature {
// The ID of a supported feature. Read Enabling guest operating system
// features to see a list of available options.
// Valid values:
//
// * `FEATURE_TYPE_UNSPECIFIED`
// * `MULTI_IP_SUBNET`
// * `SECURE_BOOT`
// * `UEFI_COMPATIBLE`
// * `VIRTIO_SCSI_MULTIQUEUE`
// * `WINDOWS`
string type = 1;
}
// Indicates whether the disk will be auto-deleted when the instance is
// deleted (but not when the disk is detached from the instance).
bool auto_delete = 1;
// Indicates that this is a boot disk. The virtual machine will use the
// first partition of the disk for its root filesystem.
bool boot = 2;
// Indicates a unique device name of your choice that is reflected into the
// `/dev/disk/by-id/google-*` tree of a Linux operating system running
// within the instance. This name can be used to reference the device for
// mounting, resizing, and so on, from within the instance.
//
// If not specified, the server chooses a default device name to apply to
// this disk, in the form persistent-disk-x, where x is a number assigned by
// Google Compute Engine.This field is only applicable for persistent disks.
string device_name = 3;
// Indicates the size of the disk in base-2 GB.
int64 disk_size_gb = 4;
// Indicates a list of features to enable on the guest operating system.
// Applicable only for bootable images. Read Enabling guest operating
// system features to see a list of available options.
repeated GuestOsFeature guest_os_features = 5;
// A zero-based index to this disk, where 0 is reserved for the
// boot disk. If you have many disks attached to an instance, each disk
// would have a unique index number.
int64 index = 6;
// Indicates the disk interface to use for attaching this disk, which is
// either SCSI or NVME. The default is SCSI. Persistent disks must always
// use SCSI and the request will fail if you attempt to attach a persistent
// disk in any other format than SCSI. Local SSDs can use either NVME or
// SCSI. For performance characteristics of SCSI over NVMe, see Local SSD
// performance.
// Valid values:
//
// * `NVME`
// * `SCSI`
string interface = 7;
// Type of the resource. Always compute#attachedDisk for attached
// disks.
string kind = 8;
// A list of publicly visible licenses. Reserved for Google's use.
// A License represents billing and aggregate usage data for public
// and marketplace images.
repeated string licenses = 9;
// The mode in which to attach this disk, either `READ_WRITE` or
// `READ_ONLY`. If not specified, the default is to attach the disk in
// `READ_WRITE` mode. Valid values:
//
// * `READ_ONLY`
// * `READ_WRITE`
string mode = 10;
// Indicates a valid partial or full URL to an existing Persistent Disk
// resource.
string source = 11;
// Indicates the type of the disk, either `SCRATCH` or `PERSISTENT`.
// Valid values:
//
// * `PERSISTENT`
// * `SCRATCH`
string type = 12;
}
// A set of Shielded Instance options.
// Check [Images using supported Shielded VM
// features](https://cloud.google.com/compute/docs/instances/modifying-shielded-vm).
// Not all combinations are valid.
message ShieldedInstanceConfig {
// Defines whether the instance has Secure Boot enabled.
//
// Secure Boot helps ensure that the system only runs authentic software by
// verifying the digital signature of all boot components, and halting the
// boot process if signature verification fails. Disabled by default.
bool enable_secure_boot = 1;
// Defines whether the instance has the vTPM enabled. Enabled by default.
bool enable_vtpm = 2;
// Defines whether the instance has integrity monitoring enabled.
//
// Enables monitoring and attestation of the boot integrity of the instance.
// The attestation is performed against the integrity policy baseline. This
// baseline is initially derived from the implicitly trusted boot image when
// the instance is created. Enabled by default.
bool enable_integrity_monitoring = 3;
}
// The entry of VM image upgrade history.
message UpgradeHistoryEntry {
// The definition of the states of this upgrade history entry.
enum State {
// State is not specified.
STATE_UNSPECIFIED = 0;
// The instance upgrade is started.
STARTED = 1;
// The instance upgrade is succeeded.
SUCCEEDED = 2;
// The instance upgrade is failed.
FAILED = 3;
}
// The definition of operations of this upgrade history entry.
enum Action {
// Operation is not specified.
ACTION_UNSPECIFIED = 0;
// Upgrade.
UPGRADE = 1;
// Rollback.
ROLLBACK = 2;
}
// The snapshot of the boot disk of this notebook instance before upgrade.
string snapshot = 1;
// The VM image before this instance upgrade.
string vm_image = 2;
// The container image before this instance upgrade.
string container_image = 3;
// The framework of this notebook instance.
string framework = 4;
// The version of the notebook instance before this upgrade.
string version = 5;
// The state of this instance upgrade history entry.
State state = 6;
// The time that this instance upgrade history entry is created.
google.protobuf.Timestamp create_time = 7;
// Target VM Image. Format: `ainotebooks-vm/project/image-name/name`.
string target_image = 8 [deprecated = true];
// Action. Rolloback or Upgrade.
Action action = 9;
// Target VM Version, like m63.
string target_version = 10;
}
// The type of vNIC driver.
// Default should be UNSPECIFIED_NIC_TYPE.
enum NicType {
// No type specified.
UNSPECIFIED_NIC_TYPE = 0;
// VIRTIO
VIRTIO_NET = 1;
// GVNIC
GVNIC = 2;
}
// Output only. The name of this notebook instance. Format:
// `projects/{project_id}/locations/{location}/instances/{instance_id}`
string name = 1 [(google.api.field_behavior) = OUTPUT_ONLY];
// Type of the environment; can be one of VM image, or container image.
oneof environment {
// Use a Compute Engine VM image to start the notebook instance.
VmImage vm_image = 2;
// Use a container image to start the notebook instance.
ContainerImage container_image = 3;
}
// Path to a Bash script that automatically runs after a notebook instance
// fully boots up. The path must be a URL or
// Cloud Storage path (`gs://path-to-file/file-name`).
string post_startup_script = 4;
// Output only. The proxy endpoint that is used to access the Jupyter notebook.
string proxy_uri = 5 [(google.api.field_behavior) = OUTPUT_ONLY];
// Input only. The owner of this instance after creation. Format: `[email protected]`
//
// Currently supports one owner only. If not specified, all of the service
// account users of your VM instance's service account can use
// the instance.
repeated string instance_owners = 6 [(google.api.field_behavior) = INPUT_ONLY];
// The service account on this instance, giving access to other Google
// Cloud services.
// You can use any service account within the same project, but you
// must have the service account user permission to use the instance.
//
// If not specified, the [Compute Engine default service
// account](https://cloud.google.com/compute/docs/access/service-accounts#default_service_account)
// is used.
string service_account = 7;
// Optional. The URIs of service account scopes to be included in
// Compute Engine instances.
//
// If not specified, the following
// [scopes](https://cloud.google.com/compute/docs/access/service-accounts#accesscopesiam)
// are defined:
// - https://www.googleapis.com/auth/cloud-platform
// - https://www.googleapis.com/auth/userinfo.email
// If not using default scopes, you need at least:
// https://www.googleapis.com/auth/compute
repeated string service_account_scopes = 31 [(google.api.field_behavior) = OPTIONAL];
// Required. The [Compute Engine machine
// type](https://cloud.google.com/compute/docs/machine-types) of this
// instance.
string machine_type = 8 [(google.api.field_behavior) = REQUIRED];
// The hardware accelerator used on this instance. If you use
// accelerators, make sure that your configuration has
// [enough vCPUs and memory to support the `machine_type` you have
// selected](https://cloud.google.com/compute/docs/gpus/#gpus-list).
AcceleratorConfig accelerator_config = 9;
// Output only. The state of this instance.
State state = 10 [(google.api.field_behavior) = OUTPUT_ONLY];
// Whether the end user authorizes Google Cloud to install GPU driver
// on this instance.
// If this field is empty or set to false, the GPU driver won't be installed.
// Only applicable to instances with GPUs.
bool install_gpu_driver = 11;
// Specify a custom Cloud Storage path where the GPU driver is stored.
// If not specified, we'll automatically choose from official GPU drivers.
string custom_gpu_driver_path = 12;
// Input only. The type of the boot disk attached to this instance, defaults to
// standard persistent disk (`PD_STANDARD`).
DiskType boot_disk_type = 13 [(google.api.field_behavior) = INPUT_ONLY];
// Input only. The size of the boot disk in GB attached to this instance, up to a maximum
// of 64000 GB (64 TB). The minimum recommended value is 100 GB. If not
// specified, this defaults to 100.
int64 boot_disk_size_gb = 14 [(google.api.field_behavior) = INPUT_ONLY];
// Input only. The type of the data disk attached to this instance, defaults to
// standard persistent disk (`PD_STANDARD`).
DiskType data_disk_type = 25 [(google.api.field_behavior) = INPUT_ONLY];
// Input only. The size of the data disk in GB attached to this instance, up to a maximum
// of 64000 GB (64 TB). You can choose the size of the data disk based on how
// big your notebooks and data are. If not specified, this defaults to 100.
int64 data_disk_size_gb = 26 [(google.api.field_behavior) = INPUT_ONLY];
// Input only. If true, the data disk will not be auto deleted when deleting the instance.
bool no_remove_data_disk = 27 [(google.api.field_behavior) = INPUT_ONLY];
// Input only. Disk encryption method used on the boot and data disks, defaults to GMEK.
DiskEncryption disk_encryption = 15 [(google.api.field_behavior) = INPUT_ONLY];
// Input only. The KMS key used to encrypt the disks, only applicable if disk_encryption
// is CMEK.
// Format:
// `projects/{project_id}/locations/{location}/keyRings/{key_ring_id}/cryptoKeys/{key_id}`
//
// Learn more about [using your own encryption keys](/kms/docs/quickstart).
string kms_key = 16 [(google.api.field_behavior) = INPUT_ONLY];
// Output only. Attached disks to notebook instance.
repeated Disk disks = 28 [(google.api.field_behavior) = OUTPUT_ONLY];
// Optional. Shielded VM configuration.
// [Images using supported Shielded VM
// features](https://cloud.google.com/compute/docs/instances/modifying-shielded-vm).
ShieldedInstanceConfig shielded_instance_config = 30 [(google.api.field_behavior) = OPTIONAL];
// If true, no public IP will be assigned to this instance.
bool no_public_ip = 17;
// If true, the notebook instance will not register with the proxy.
bool no_proxy_access = 18;
// The name of the VPC that this instance is in.
// Format:
// `projects/{project_id}/global/networks/{network_id}`
string network = 19;
// The name of the subnet that this instance is in.
// Format:
// `projects/{project_id}/regions/{region}/subnetworks/{subnetwork_id}`
string subnet = 20;
// Labels to apply to this instance.
// These can be later modified by the setLabels method.
map labels = 21;
// Custom metadata to apply to this instance.
map metadata = 22;
// Optional. The Compute Engine tags to add to runtime (see [Tagging
// instances](https://cloud.google.com/compute/docs/label-or-tag-resources#tags)).
repeated string tags = 32 [(google.api.field_behavior) = OPTIONAL];
// The upgrade history of this instance.
repeated UpgradeHistoryEntry upgrade_history = 29;
// Optional. The type of vNIC to be used on this interface. This may be gVNIC or
// VirtioNet.
NicType nic_type = 33 [(google.api.field_behavior) = OPTIONAL];
// Optional. The optional reservation affinity. Setting this field will apply
// the specified [Zonal Compute
// Reservation](https://cloud.google.com/compute/docs/instances/reserving-zonal-resources)
// to this notebook instance.
ReservationAffinity reservation_affinity = 34 [(google.api.field_behavior) = OPTIONAL];
// Output only. Email address of entity that sent original CreateInstance request.
string creator = 36 [(google.api.field_behavior) = OUTPUT_ONLY];
// Optional. Flag to enable ip forwarding or not, default false/off.
// https://cloud.google.com/vpc/docs/using-routes#canipforward
bool can_ip_forward = 39 [(google.api.field_behavior) = OPTIONAL];
// Output only. Instance creation time.
google.protobuf.Timestamp create_time = 23 [(google.api.field_behavior) = OUTPUT_ONLY];
// Output only. Instance update time.
google.protobuf.Timestamp update_time = 24 [(google.api.field_behavior) = OUTPUT_ONLY];
}