Class: Google::Apis::NotebooksV1::Instance

Inherits:
Object
  • Object
show all
Includes:
Core::Hashable, Core::JsonObjectSupport
Defined in:
lib/google/apis/notebooks_v1/classes.rb,
lib/google/apis/notebooks_v1/representations.rb,
lib/google/apis/notebooks_v1/representations.rb
more...

Overview

The definition of a notebook instance.

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(**args) ⇒ Instance

Returns a new instance of Instance.

[View source]

1128
1129
1130
# File 'lib/google/apis/notebooks_v1/classes.rb', line 1128

def initialize(**args)
   update!(**args)
end

Instance Attribute Details

#accelerator_configGoogle::Apis::NotebooksV1::AcceleratorConfig

Definition of a hardware accelerator. Note that not all combinations of type and core_count are valid. See GPUs on Compute Engine to find a valid combination. TPUs are not supported. Corresponds to the JSON property acceleratorConfig


892
893
894
# File 'lib/google/apis/notebooks_v1/classes.rb', line 892

def accelerator_config
  @accelerator_config
end

#boot_disk_size_gbFixnum

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. Corresponds to the JSON property bootDiskSizeGb

Returns:

  • (Fixnum)

899
900
901
# File 'lib/google/apis/notebooks_v1/classes.rb', line 899

def boot_disk_size_gb
  @boot_disk_size_gb
end

#boot_disk_typeString

Input only. The type of the boot disk attached to this instance, defaults to standard persistent disk (PD_STANDARD). Corresponds to the JSON property bootDiskType

Returns:

  • (String)

905
906
907
# File 'lib/google/apis/notebooks_v1/classes.rb', line 905

def boot_disk_type
  @boot_disk_type
end

#can_ip_forwardBoolean Also known as: can_ip_forward?

Optional. Flag to enable ip forwarding or not, default false/off. https:// cloud.google.com/vpc/docs/using-routes#canipforward Corresponds to the JSON property canIpForward

Returns:

  • (Boolean)

911
912
913
# File 'lib/google/apis/notebooks_v1/classes.rb', line 911

def can_ip_forward
  @can_ip_forward
end

#container_imageGoogle::Apis::NotebooksV1::ContainerImage

Definition of a container image for starting a notebook instance with the environment installed in a container. Corresponds to the JSON property containerImage


918
919
920
# File 'lib/google/apis/notebooks_v1/classes.rb', line 918

def container_image
  @container_image
end

#create_timeString

Output only. Instance creation time. Corresponds to the JSON property createTime

Returns:

  • (String)

923
924
925
# File 'lib/google/apis/notebooks_v1/classes.rb', line 923

def create_time
  @create_time
end

#creatorString

Output only. Email address of entity that sent original CreateInstance request. Corresponds to the JSON property creator

Returns:

  • (String)

928
929
930
# File 'lib/google/apis/notebooks_v1/classes.rb', line 928

def creator
  @creator
end

#custom_gpu_driver_pathString

Specify a custom Cloud Storage path where the GPU driver is stored. If not specified, we'll automatically choose from official GPU drivers. Corresponds to the JSON property customGpuDriverPath

Returns:

  • (String)

934
935
936
# File 'lib/google/apis/notebooks_v1/classes.rb', line 934

def custom_gpu_driver_path
  @custom_gpu_driver_path
end

#data_disk_size_gbFixnum

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. Corresponds to the JSON property dataDiskSizeGb

Returns:

  • (Fixnum)

941
942
943
# File 'lib/google/apis/notebooks_v1/classes.rb', line 941

def data_disk_size_gb
  @data_disk_size_gb
end

#data_disk_typeString

Input only. The type of the data disk attached to this instance, defaults to standard persistent disk (PD_STANDARD). Corresponds to the JSON property dataDiskType

Returns:

  • (String)

947
948
949
# File 'lib/google/apis/notebooks_v1/classes.rb', line 947

def data_disk_type
  @data_disk_type
end

#disk_encryptionString

Input only. Disk encryption method used on the boot and data disks, defaults to GMEK. Corresponds to the JSON property diskEncryption

Returns:

  • (String)

953
954
955
# File 'lib/google/apis/notebooks_v1/classes.rb', line 953

def disk_encryption
  @disk_encryption
end

#disksArray<Google::Apis::NotebooksV1::Disk>

Output only. Attached disks to notebook instance. Corresponds to the JSON property disks


958
959
960
# File 'lib/google/apis/notebooks_v1/classes.rb', line 958

def disks
  @disks
end

#install_gpu_driverBoolean Also known as: install_gpu_driver?

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. Corresponds to the JSON property installGpuDriver

Returns:

  • (Boolean)

965
966
967
# File 'lib/google/apis/notebooks_v1/classes.rb', line 965

def install_gpu_driver
  @install_gpu_driver
end

#instance_migration_eligibilityGoogle::Apis::NotebooksV1::InstanceMigrationEligibility

InstanceMigrationEligibility represents the feasibility information of a migration from UmN to WbI. Corresponds to the JSON property instanceMigrationEligibility


972
973
974
# File 'lib/google/apis/notebooks_v1/classes.rb', line 972

def instance_migration_eligibility
  @instance_migration_eligibility
end

#instance_ownersArray<String>

Input only. The owner of this instance after creation. Format: alias@example. com 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. Corresponds to the JSON property instanceOwners

Returns:

  • (Array<String>)

979
980
981
# File 'lib/google/apis/notebooks_v1/classes.rb', line 979

def instance_owners
  @instance_owners
end

#kms_keyString

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). Corresponds to the JSON propertykmsKey`

Returns:

  • (String)

987
988
989
# File 'lib/google/apis/notebooks_v1/classes.rb', line 987

def kms_key
  @kms_key
end

#labelsHash<String,String>

Labels to apply to this instance. These can be later modified by the setLabels method. Corresponds to the JSON property labels

Returns:

  • (Hash<String,String>)

993
994
995
# File 'lib/google/apis/notebooks_v1/classes.rb', line 993

def labels
  @labels
end

#machine_typeString

Required. The Compute Engine machine type of this instance. Corresponds to the JSON property machineType

Returns:

  • (String)

999
1000
1001
# File 'lib/google/apis/notebooks_v1/classes.rb', line 999

def machine_type
  @machine_type
end

#metadataHash<String,String>

Custom metadata to apply to this instance. For example, to specify a Cloud Storage bucket for automatic backup, you can use the gcs-data-bucket metadata tag. Format: "--metadata=gcs-data-bucket=BUCKET". Corresponds to the JSON property metadata

Returns:

  • (Hash<String,String>)

1006
1007
1008
# File 'lib/google/apis/notebooks_v1/classes.rb', line 1006

def 
  @metadata
end

#migratedBoolean Also known as: migrated?

Output only. Bool indicating whether this notebook has been migrated to a Workbench Instance Corresponds to the JSON property migrated

Returns:

  • (Boolean)

1012
1013
1014
# File 'lib/google/apis/notebooks_v1/classes.rb', line 1012

def migrated
  @migrated
end

#nameString

Output only. The name of this notebook instance. Format: projects/project_id /locations/location/instances/instance_id` Corresponds to the JSON propertyname`

Returns:

  • (String)

1019
1020
1021
# File 'lib/google/apis/notebooks_v1/classes.rb', line 1019

def name
  @name
end

#networkString

The name of the VPC that this instance is in. Format: projects/project_id/ global/networks/network_id` Corresponds to the JSON propertynetwork`

Returns:

  • (String)

1025
1026
1027
# File 'lib/google/apis/notebooks_v1/classes.rb', line 1025

def network
  @network
end

#nic_typeString

Optional. The type of vNIC to be used on this interface. This may be gVNIC or VirtioNet. Corresponds to the JSON property nicType

Returns:

  • (String)

1031
1032
1033
# File 'lib/google/apis/notebooks_v1/classes.rb', line 1031

def nic_type
  @nic_type
end

#no_proxy_accessBoolean Also known as: no_proxy_access?

If true, the notebook instance will not register with the proxy. Corresponds to the JSON property noProxyAccess

Returns:

  • (Boolean)

1036
1037
1038
# File 'lib/google/apis/notebooks_v1/classes.rb', line 1036

def no_proxy_access
  @no_proxy_access
end

#no_public_ipBoolean Also known as: no_public_ip?

If true, no external IP will be assigned to this instance. Corresponds to the JSON property noPublicIp

Returns:

  • (Boolean)

1042
1043
1044
# File 'lib/google/apis/notebooks_v1/classes.rb', line 1042

def no_public_ip
  @no_public_ip
end

#no_remove_data_diskBoolean Also known as: no_remove_data_disk?

Input only. If true, the data disk will not be auto deleted when deleting the instance. Corresponds to the JSON property noRemoveDataDisk

Returns:

  • (Boolean)

1049
1050
1051
# File 'lib/google/apis/notebooks_v1/classes.rb', line 1049

def no_remove_data_disk
  @no_remove_data_disk
end

#post_startup_scriptString

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). Corresponds to the JSON property postStartupScript

Returns:

  • (String)

1057
1058
1059
# File 'lib/google/apis/notebooks_v1/classes.rb', line 1057

def post_startup_script
  @post_startup_script
end

#proxy_uriString

Output only. The proxy endpoint that is used to access the Jupyter notebook. Corresponds to the JSON property proxyUri

Returns:

  • (String)

1062
1063
1064
# File 'lib/google/apis/notebooks_v1/classes.rb', line 1062

def proxy_uri
  @proxy_uri
end

#reservation_affinityGoogle::Apis::NotebooksV1::ReservationAffinity

Reservation Affinity for consuming Zonal reservation. Corresponds to the JSON property reservationAffinity


1067
1068
1069
# File 'lib/google/apis/notebooks_v1/classes.rb', line 1067

def reservation_affinity
  @reservation_affinity
end

#service_accountString

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 is used. Corresponds to the JSON property serviceAccount

Returns:

  • (String)

1076
1077
1078
# File 'lib/google/apis/notebooks_v1/classes.rb', line 1076

def 
  @service_account
end

#service_account_scopesArray<String>

Optional. The URIs of service account scopes to be included in Compute Engine instances. If not specified, the following scopes 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 Corresponds to the JSON property serviceAccountScopes

Returns:

  • (Array<String>)

1086
1087
1088
# File 'lib/google/apis/notebooks_v1/classes.rb', line 1086

def 
  @service_account_scopes
end

#shielded_instance_configGoogle::Apis::NotebooksV1::ShieldedInstanceConfig

A set of Shielded Instance options. See Images using supported Shielded VM features. Not all combinations are valid. Corresponds to the JSON property shieldedInstanceConfig


1093
1094
1095
# File 'lib/google/apis/notebooks_v1/classes.rb', line 1093

def shielded_instance_config
  @shielded_instance_config
end

#stateString

Output only. The state of this instance. Corresponds to the JSON property state

Returns:

  • (String)

1098
1099
1100
# File 'lib/google/apis/notebooks_v1/classes.rb', line 1098

def state
  @state
end

#subnetString

The name of the subnet that this instance is in. Format: projects/project_id /regions/region/subnetworks/subnetwork_id` Corresponds to the JSON propertysubnet`

Returns:

  • (String)

1104
1105
1106
# File 'lib/google/apis/notebooks_v1/classes.rb', line 1104

def subnet
  @subnet
end

#tagsArray<String>

Optional. The Compute Engine network tags to add to runtime (see Add network tags). Corresponds to the JSON property tags

Returns:

  • (Array<String>)

1110
1111
1112
# File 'lib/google/apis/notebooks_v1/classes.rb', line 1110

def tags
  @tags
end

#update_timeString

Output only. Instance update time. Corresponds to the JSON property updateTime

Returns:

  • (String)

1115
1116
1117
# File 'lib/google/apis/notebooks_v1/classes.rb', line 1115

def update_time
  @update_time
end

#upgrade_historyArray<Google::Apis::NotebooksV1::UpgradeHistoryEntry>

The upgrade history of this instance. Corresponds to the JSON property upgradeHistory


1120
1121
1122
# File 'lib/google/apis/notebooks_v1/classes.rb', line 1120

def upgrade_history
  @upgrade_history
end

#vm_imageGoogle::Apis::NotebooksV1::VmImage

Definition of a custom Compute Engine virtual machine image for starting a notebook instance with the environment installed directly on the VM. Corresponds to the JSON property vmImage


1126
1127
1128
# File 'lib/google/apis/notebooks_v1/classes.rb', line 1126

def vm_image
  @vm_image
end

Instance Method Details

#update!(**args) ⇒ Object

Update properties of this object

[View source]

1133
1134
1135
1136
1137
1138
1139
1140
1141
1142
1143
1144
1145
1146
1147
1148
1149
1150
1151
1152
1153
1154
1155
1156
1157
1158
1159
1160
1161
1162
1163
1164
1165
1166
1167
1168
1169
1170
1171
1172
# File 'lib/google/apis/notebooks_v1/classes.rb', line 1133

def update!(**args)
  @accelerator_config = args[:accelerator_config] if args.key?(:accelerator_config)
  @boot_disk_size_gb = args[:boot_disk_size_gb] if args.key?(:boot_disk_size_gb)
  @boot_disk_type = args[:boot_disk_type] if args.key?(:boot_disk_type)
  @can_ip_forward = args[:can_ip_forward] if args.key?(:can_ip_forward)
  @container_image = args[:container_image] if args.key?(:container_image)
  @create_time = args[:create_time] if args.key?(:create_time)
  @creator = args[:creator] if args.key?(:creator)
  @custom_gpu_driver_path = args[:custom_gpu_driver_path] if args.key?(:custom_gpu_driver_path)
  @data_disk_size_gb = args[:data_disk_size_gb] if args.key?(:data_disk_size_gb)
  @data_disk_type = args[:data_disk_type] if args.key?(:data_disk_type)
  @disk_encryption = args[:disk_encryption] if args.key?(:disk_encryption)
  @disks = args[:disks] if args.key?(:disks)
  @install_gpu_driver = args[:install_gpu_driver] if args.key?(:install_gpu_driver)
  @instance_migration_eligibility = args[:instance_migration_eligibility] if args.key?(:instance_migration_eligibility)
  @instance_owners = args[:instance_owners] if args.key?(:instance_owners)
  @kms_key = args[:kms_key] if args.key?(:kms_key)
  @labels = args[:labels] if args.key?(:labels)
  @machine_type = args[:machine_type] if args.key?(:machine_type)
  @metadata = args[:metadata] if args.key?(:metadata)
  @migrated = args[:migrated] if args.key?(:migrated)
  @name = args[:name] if args.key?(:name)
  @network = args[:network] if args.key?(:network)
  @nic_type = args[:nic_type] if args.key?(:nic_type)
  @no_proxy_access = args[:no_proxy_access] if args.key?(:no_proxy_access)
  @no_public_ip = args[:no_public_ip] if args.key?(:no_public_ip)
  @no_remove_data_disk = args[:no_remove_data_disk] if args.key?(:no_remove_data_disk)
  @post_startup_script = args[:post_startup_script] if args.key?(:post_startup_script)
  @proxy_uri = args[:proxy_uri] if args.key?(:proxy_uri)
  @reservation_affinity = args[:reservation_affinity] if args.key?(:reservation_affinity)
  @service_account = args[:service_account] if args.key?(:service_account)
  @service_account_scopes = args[:service_account_scopes] if args.key?(:service_account_scopes)
  @shielded_instance_config = args[:shielded_instance_config] if args.key?(:shielded_instance_config)
  @state = args[:state] if args.key?(:state)
  @subnet = args[:subnet] if args.key?(:subnet)
  @tags = args[:tags] if args.key?(:tags)
  @update_time = args[:update_time] if args.key?(:update_time)
  @upgrade_history = args[:upgrade_history] if args.key?(:upgrade_history)
  @vm_image = args[:vm_image] if args.key?(:vm_image)
end