Class: Google::Apis::ComputeAlpha::InstanceGroup

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

Overview

Represents an Instance Group resource. Instance Groups can be used to configure a target for load balancing. Instance groups can either be managed or unmanaged. To create managed instance groups, use the instanceGroupManager or regionInstanceGroupManager resource instead. Use zonal unmanaged instance groups if you need to apply load balancing to groups of heterogeneous instances or if you need to manage the instances yourself. You cannot create regional unmanaged instance groups. For more information, read Instance groups.

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(**args) ⇒ InstanceGroup

Returns a new instance of InstanceGroup.



17626
17627
17628
# File 'lib/google/apis/compute_alpha/classes.rb', line 17626

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

Instance Attribute Details

#creation_timestampString

[Output Only] The creation timestamp for this instance group in RFC3339 text format. Corresponds to the JSON property creationTimestamp

Returns:

  • (String)


17540
17541
17542
# File 'lib/google/apis/compute_alpha/classes.rb', line 17540

def creation_timestamp
  @creation_timestamp
end

#descriptionString

An optional description of this resource. Provide this property when you create the resource. Corresponds to the JSON property description

Returns:

  • (String)


17546
17547
17548
# File 'lib/google/apis/compute_alpha/classes.rb', line 17546

def description
  @description
end

#fingerprintString

[Output Only] The fingerprint of the named ports. The system uses this fingerprint to detect conflicts when multiple users change the named ports concurrently. Corresponds to the JSON property fingerprint NOTE: Values are automatically base64 encoded/decoded in the client library.

Returns:

  • (String)


17554
17555
17556
# File 'lib/google/apis/compute_alpha/classes.rb', line 17554

def fingerprint
  @fingerprint
end

#idFixnum

[Output Only] A unique identifier for this instance group, generated by the server. Corresponds to the JSON property id

Returns:

  • (Fixnum)


17560
17561
17562
# File 'lib/google/apis/compute_alpha/classes.rb', line 17560

def id
  @id
end

#kindString

[Output Only] The resource type, which is always compute#instanceGroup for instance groups. Corresponds to the JSON property kind

Returns:

  • (String)


17566
17567
17568
# File 'lib/google/apis/compute_alpha/classes.rb', line 17566

def kind
  @kind
end

#nameString

The name of the instance group. The name must be 1-63 characters long, and comply with RFC1035. Corresponds to the JSON property name

Returns:

  • (String)


17572
17573
17574
# File 'lib/google/apis/compute_alpha/classes.rb', line 17572

def name
  @name
end

#named_portsArray<Google::Apis::ComputeAlpha::NamedPort>

Assigns a name to a port number. For example: name: "http", port: 80 This allows the system to reference ports by the assigned name instead of a port number. Named ports can also contain multiple ports. For example: [name: " app1", port: 8080, name: "app1", port: 8081, name: "app2", port: 8082] Named ports apply to all instances in this instance group. Corresponds to the JSON property namedPorts



17581
17582
17583
# File 'lib/google/apis/compute_alpha/classes.rb', line 17581

def named_ports
  @named_ports
end

#networkString

[Output Only] The URL of the network to which all instances in the instance group belong. If your instance has multiple network interfaces, then the network and subnetwork fields only refer to the network and subnet used by your primary interface (nic0). Corresponds to the JSON property network

Returns:

  • (String)


17589
17590
17591
# File 'lib/google/apis/compute_alpha/classes.rb', line 17589

def network
  @network
end

#regionString

[Output Only] The URL of the region where the instance group is located (for regional resources). Corresponds to the JSON property region

Returns:

  • (String)


17595
17596
17597
# File 'lib/google/apis/compute_alpha/classes.rb', line 17595

def region
  @region
end

[Output Only] The URL for this instance group. The server generates this URL. Corresponds to the JSON property selfLink

Returns:

  • (String)


17600
17601
17602
# File 'lib/google/apis/compute_alpha/classes.rb', line 17600

def self_link
  @self_link
end

[Output Only] Server-defined URL for this resource with the resource id. Corresponds to the JSON property selfLinkWithId

Returns:

  • (String)


17605
17606
17607
# File 'lib/google/apis/compute_alpha/classes.rb', line 17605

def self_link_with_id
  @self_link_with_id
end

#sizeFixnum

[Output Only] The total number of instances in the instance group. Corresponds to the JSON property size

Returns:

  • (Fixnum)


17610
17611
17612
# File 'lib/google/apis/compute_alpha/classes.rb', line 17610

def size
  @size
end

#subnetworkString

[Output Only] The URL of the subnetwork to which all instances in the instance group belong. If your instance has multiple network interfaces, then the network and subnetwork fields only refer to the network and subnet used by your primary interface (nic0). Corresponds to the JSON property subnetwork

Returns:

  • (String)


17618
17619
17620
# File 'lib/google/apis/compute_alpha/classes.rb', line 17618

def subnetwork
  @subnetwork
end

#zoneString

[Output Only] The URL of the zone where the instance group is located (for zonal resources). Corresponds to the JSON property zone

Returns:

  • (String)


17624
17625
17626
# File 'lib/google/apis/compute_alpha/classes.rb', line 17624

def zone
  @zone
end

Instance Method Details

#update!(**args) ⇒ Object

Update properties of this object



17631
17632
17633
17634
17635
17636
17637
17638
17639
17640
17641
17642
17643
17644
17645
17646
# File 'lib/google/apis/compute_alpha/classes.rb', line 17631

def update!(**args)
  @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp)
  @description = args[:description] if args.key?(:description)
  @fingerprint = args[:fingerprint] if args.key?(:fingerprint)
  @id = args[:id] if args.key?(:id)
  @kind = args[:kind] if args.key?(:kind)
  @name = args[:name] if args.key?(:name)
  @named_ports = args[:named_ports] if args.key?(:named_ports)
  @network = args[:network] if args.key?(:network)
  @region = args[:region] if args.key?(:region)
  @self_link = args[:self_link] if args.key?(:self_link)
  @self_link_with_id = args[:self_link_with_id] if args.key?(:self_link_with_id)
  @size = args[:size] if args.key?(:size)
  @subnetwork = args[:subnetwork] if args.key?(:subnetwork)
  @zone = args[:zone] if args.key?(:zone)
end