Class: Google::Apis::TpuV1::Node

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

Overview

A TPU instance.

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(**args) ⇒ Node

Returns a new instance of Node.



401
402
403
# File 'lib/google/apis/tpu_v1/classes.rb', line 401

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

Instance Attribute Details

#accelerator_typeString

Required. The type of hardware accelerators associated with this node. Corresponds to the JSON property acceleratorType

Returns:

  • (String)


288
289
290
# File 'lib/google/apis/tpu_v1/classes.rb', line 288

def accelerator_type
  @accelerator_type
end

#api_versionString

Output only. The API version that created this Node. Corresponds to the JSON property apiVersion

Returns:

  • (String)


293
294
295
# File 'lib/google/apis/tpu_v1/classes.rb', line 293

def api_version
  @api_version
end

#cidr_blockString

The CIDR block that the TPU node will use when selecting an IP address. This CIDR block must be a /29 block; the Compute Engine networks API forbids a smaller block, and using a larger block would be wasteful (a node can only consume one IP address). Errors will occur if the CIDR block has already been used for a currently existing TPU node, the CIDR block conflicts with any subnetworks in the user's provided network, or the provided network is peered with another network that is using that CIDR block. Corresponds to the JSON property cidrBlock

Returns:

  • (String)


304
305
306
# File 'lib/google/apis/tpu_v1/classes.rb', line 304

def cidr_block
  @cidr_block
end

#create_timeString

Output only. The time when the node was created. Corresponds to the JSON property createTime

Returns:

  • (String)


309
310
311
# File 'lib/google/apis/tpu_v1/classes.rb', line 309

def create_time
  @create_time
end

#descriptionString

The user-supplied description of the TPU. Maximum of 512 characters. Corresponds to the JSON property description

Returns:

  • (String)


314
315
316
# File 'lib/google/apis/tpu_v1/classes.rb', line 314

def description
  @description
end

#healthString

The health status of the TPU node. Corresponds to the JSON property health

Returns:

  • (String)


319
320
321
# File 'lib/google/apis/tpu_v1/classes.rb', line 319

def health
  @health
end

#health_descriptionString

Output only. If this field is populated, it contains a description of why the TPU Node is unhealthy. Corresponds to the JSON property healthDescription

Returns:

  • (String)


325
326
327
# File 'lib/google/apis/tpu_v1/classes.rb', line 325

def health_description
  @health_description
end

#ip_addressString

Output only. DEPRECATED! Use network_endpoints instead. The network address for the TPU Node as visible to Compute Engine instances. Corresponds to the JSON property ipAddress

Returns:

  • (String)


331
332
333
# File 'lib/google/apis/tpu_v1/classes.rb', line 331

def ip_address
  @ip_address
end

#labelsHash<String,String>

Resource labels to represent user-provided metadata. Corresponds to the JSON property labels

Returns:

  • (Hash<String,String>)


336
337
338
# File 'lib/google/apis/tpu_v1/classes.rb', line 336

def labels
  @labels
end

#nameString

Output only. Immutable. The name of the TPU Corresponds to the JSON property name

Returns:

  • (String)


341
342
343
# File 'lib/google/apis/tpu_v1/classes.rb', line 341

def name
  @name
end

#networkString

The name of a network they wish to peer the TPU node to. It must be a preexisting Compute Engine network inside of the project on which this API has been activated. If none is provided, "default" will be used. Corresponds to the JSON property network

Returns:

  • (String)


348
349
350
# File 'lib/google/apis/tpu_v1/classes.rb', line 348

def network
  @network
end

#network_endpointsArray<Google::Apis::TpuV1::NetworkEndpoint>

Output only. The network endpoints where TPU workers can be accessed and sent work. It is recommended that Tensorflow clients of the node reach out to the 0th entry in this map first. Corresponds to the JSON property networkEndpoints



355
356
357
# File 'lib/google/apis/tpu_v1/classes.rb', line 355

def network_endpoints
  @network_endpoints
end

#portString

Output only. DEPRECATED! Use network_endpoints instead. The network port for the TPU Node as visible to Compute Engine instances. Corresponds to the JSON property port

Returns:

  • (String)


361
362
363
# File 'lib/google/apis/tpu_v1/classes.rb', line 361

def port
  @port
end

#scheduling_configGoogle::Apis::TpuV1::SchedulingConfig

Sets the scheduling options for this node. Corresponds to the JSON property schedulingConfig



366
367
368
# File 'lib/google/apis/tpu_v1/classes.rb', line 366

def scheduling_config
  @scheduling_config
end

#service_accountString

Output only. The service account used to run the tensor flow services within the node. To share resources, including Google Cloud Storage data, with the Tensorflow job running in the Node, this account must have permissions to that data. Corresponds to the JSON property serviceAccount

Returns:

  • (String)


374
375
376
# File 'lib/google/apis/tpu_v1/classes.rb', line 374

def 
  @service_account
end

#stateString

Output only. The current state for the TPU Node. Corresponds to the JSON property state

Returns:

  • (String)


379
380
381
# File 'lib/google/apis/tpu_v1/classes.rb', line 379

def state
  @state
end

#symptomsArray<Google::Apis::TpuV1::Symptom>

Output only. The Symptoms that have occurred to the TPU Node. Corresponds to the JSON property symptoms

Returns:



384
385
386
# File 'lib/google/apis/tpu_v1/classes.rb', line 384

def symptoms
  @symptoms
end

#tensorflow_versionString

Required. The version of Tensorflow running in the Node. Corresponds to the JSON property tensorflowVersion

Returns:

  • (String)


389
390
391
# File 'lib/google/apis/tpu_v1/classes.rb', line 389

def tensorflow_version
  @tensorflow_version
end

#use_service_networkingBoolean Also known as: use_service_networking?

Whether the VPC peering for the node is set up through Service Networking API. The VPC Peering should be set up before provisioning the node. If this field is set, cidr_block field should not be specified. If the network, that you want to peer the TPU Node to, is Shared VPC networks, the node must be created with this this field enabled. Corresponds to the JSON property useServiceNetworking

Returns:

  • (Boolean)


398
399
400
# File 'lib/google/apis/tpu_v1/classes.rb', line 398

def use_service_networking
  @use_service_networking
end

Instance Method Details

#update!(**args) ⇒ Object

Update properties of this object



406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
# File 'lib/google/apis/tpu_v1/classes.rb', line 406

def update!(**args)
  @accelerator_type = args[:accelerator_type] if args.key?(:accelerator_type)
  @api_version = args[:api_version] if args.key?(:api_version)
  @cidr_block = args[:cidr_block] if args.key?(:cidr_block)
  @create_time = args[:create_time] if args.key?(:create_time)
  @description = args[:description] if args.key?(:description)
  @health = args[:health] if args.key?(:health)
  @health_description = args[:health_description] if args.key?(:health_description)
  @ip_address = args[:ip_address] if args.key?(:ip_address)
  @labels = args[:labels] if args.key?(:labels)
  @name = args[:name] if args.key?(:name)
  @network = args[:network] if args.key?(:network)
  @network_endpoints = args[:network_endpoints] if args.key?(:network_endpoints)
  @port = args[:port] if args.key?(:port)
  @scheduling_config = args[:scheduling_config] if args.key?(:scheduling_config)
  @service_account = args[:service_account] if args.key?(:service_account)
  @state = args[:state] if args.key?(:state)
  @symptoms = args[:symptoms] if args.key?(:symptoms)
  @tensorflow_version = args[:tensorflow_version] if args.key?(:tensorflow_version)
  @use_service_networking = args[:use_service_networking] if args.key?(:use_service_networking)
end