Class: Google::Apis::ComputeBeta::Address
- Inherits:
-
Object
- Object
- Google::Apis::ComputeBeta::Address
- Includes:
- Google::Apis::Core::Hashable, Google::Apis::Core::JsonObjectSupport
- Defined in:
- generated/google/apis/compute_beta/classes.rb,
generated/google/apis/compute_beta/representations.rb,
generated/google/apis/compute_beta/representations.rb
Overview
Use global external addresses for GFE-based external HTTP(S) load balancers in Premium Tier. Use global internal addresses for reserved peering network range. Use regional external addresses for the following resources:
- External IP addresses for VM instances - Regional external forwarding rules - Cloud NAT external IP addresses - GFE based LBs in Standard Tier - Network LBs in Premium or Standard Tier - Cloud VPN gateways (both Classic and HA) Use regional internal IP addresses for subnet IP ranges (primary and secondary) . This includes:
- Internal IP addresses for VM instances - Alias IP ranges of VM instances (/
32 only) - Regional internal forwarding rules - Internal TCP/UDP load balancer
addresses - Internal HTTP(S) load balancer addresses - Cloud DNS inbound
forwarding IP addresses
For more information, read reserved IP address.
(== resource_for
$api_version
.addresses ==) (== resource_for$api_version
. globalAddresses ==)
Instance Attribute Summary collapse
-
#address ⇒ String
The static IP address represented by this resource.
-
#address_type ⇒ String
The type of address to reserve, either INTERNAL or EXTERNAL.
-
#creation_timestamp ⇒ String
[Output Only] Creation timestamp in RFC3339 text format.
-
#description ⇒ String
An optional description of this resource.
-
#id ⇒ Fixnum
[Output Only] The unique identifier for the resource.
-
#ip_version ⇒ String
The IP version that will be used by this address.
-
#kind ⇒ String
[Output Only] Type of the resource.
-
#label_fingerprint ⇒ String
A fingerprint for the labels being applied to this Address, which is essentially a hash of the labels set used for optimistic locking.
-
#labels ⇒ Hash<String,String>
Labels for this resource.
-
#name ⇒ String
Name of the resource.
-
#network ⇒ String
The URL of the network in which to reserve the address.
-
#network_tier ⇒ String
This signifies the networking tier used for configuring this address and can only take the following values: PREMIUM or STANDARD.
-
#prefix_length ⇒ Fixnum
The prefix length if the resource reprensents an IP range.
-
#purpose ⇒ String
The purpose of this resource, which can be one of the following values: -
GCE_ENDPOINT
for addresses that are used by VM instances, alias IP ranges, internal load balancers, and similar resources. -
#region ⇒ String
[Output Only] The URL of the region where the regional address resides.
-
#self_link ⇒ String
[Output Only] Server-defined URL for the resource.
-
#status ⇒ String
[Output Only] The status of the address, which can be one of RESERVING, RESERVED, or IN_USE.
-
#subnetwork ⇒ String
The URL of the subnetwork in which to reserve the address.
-
#users ⇒ Array<String>
[Output Only] The URLs of the resources that are using this address.
Instance Method Summary collapse
-
#initialize(**args) ⇒ Address
constructor
A new instance of Address.
-
#update!(**args) ⇒ Object
Update properties of this object.
Constructor Details
#initialize(**args) ⇒ Address
Returns a new instance of Address.
691 692 693 |
# File 'generated/google/apis/compute_beta/classes.rb', line 691 def initialize(**args) update!(**args) end |
Instance Attribute Details
#address ⇒ String
The static IP address represented by this resource.
Corresponds to the JSON property address
557 558 559 |
# File 'generated/google/apis/compute_beta/classes.rb', line 557 def address @address end |
#address_type ⇒ String
The type of address to reserve, either INTERNAL or EXTERNAL. If unspecified,
defaults to EXTERNAL.
Corresponds to the JSON property addressType
563 564 565 |
# File 'generated/google/apis/compute_beta/classes.rb', line 563 def address_type @address_type end |
#creation_timestamp ⇒ String
[Output Only] Creation timestamp in RFC3339 text format.
Corresponds to the JSON property creationTimestamp
568 569 570 |
# File 'generated/google/apis/compute_beta/classes.rb', line 568 def @creation_timestamp end |
#description ⇒ String
An optional description of this resource. Provide this field when you create
the resource.
Corresponds to the JSON property description
574 575 576 |
# File 'generated/google/apis/compute_beta/classes.rb', line 574 def description @description end |
#id ⇒ Fixnum
[Output Only] The unique identifier for the resource. This identifier is
defined by the server.
Corresponds to the JSON property id
580 581 582 |
# File 'generated/google/apis/compute_beta/classes.rb', line 580 def id @id end |
#ip_version ⇒ String
The IP version that will be used by this address. Valid options are IPV4 or
IPV6. This can only be specified for a global address.
Corresponds to the JSON property ipVersion
586 587 588 |
# File 'generated/google/apis/compute_beta/classes.rb', line 586 def ip_version @ip_version end |
#kind ⇒ String
[Output Only] Type of the resource. Always compute#address for addresses.
Corresponds to the JSON property kind
591 592 593 |
# File 'generated/google/apis/compute_beta/classes.rb', line 591 def kind @kind end |
#label_fingerprint ⇒ String
A fingerprint for the labels being applied to this Address, which is
essentially a hash of the labels set used for optimistic locking. The
fingerprint is initially generated by Compute Engine and changes after every
request to modify or update labels. You must always provide an up-to-date
fingerprint hash in order to update or change labels, otherwise the request
will fail with error 412 conditionNotMet.
To see the latest fingerprint, make a get() request to retrieve an Address.
Corresponds to the JSON property labelFingerprint
NOTE: Values are automatically base64 encoded/decoded in the client library.
603 604 605 |
# File 'generated/google/apis/compute_beta/classes.rb', line 603 def label_fingerprint @label_fingerprint end |
#labels ⇒ Hash<String,String>
Labels for this resource. These can only be added or modified by the setLabels
method. Each label key/value pair must comply with RFC1035. Label values may
be empty.
Corresponds to the JSON property labels
610 611 612 |
# File 'generated/google/apis/compute_beta/classes.rb', line 610 def labels @labels end |
#name ⇒ String
Name of the resource. Provided by the client when the resource is created. The
name must be 1-63 characters long, and comply with RFC1035. Specifically, the
name must be 1-63 characters long and match the regular expression [a-z]([-a-
z0-9]*[a-z0-9])?
. The first character must be a lowercase letter, and all
following characters (except for the last character) must be a dash, lowercase
letter, or digit. The last character must be a lowercase letter or digit.
Corresponds to the JSON property name
620 621 622 |
# File 'generated/google/apis/compute_beta/classes.rb', line 620 def name @name end |
#network ⇒ String
The URL of the network in which to reserve the address. This field can only be
used with INTERNAL type with the VPC_PEERING purpose.
Corresponds to the JSON property network
626 627 628 |
# File 'generated/google/apis/compute_beta/classes.rb', line 626 def network @network end |
#network_tier ⇒ String
This signifies the networking tier used for configuring this address and can
only take the following values: PREMIUM or STANDARD. Global forwarding rules
can only be Premium Tier. Regional forwarding rules can be either Premium or
Standard Tier. Standard Tier addresses applied to regional forwarding rules
can be used with any external load balancer. Regional forwarding rules in
Premium Tier can only be used with a network load balancer.
If this field is not specified, it is assumed to be PREMIUM.
Corresponds to the JSON property networkTier
637 638 639 |
# File 'generated/google/apis/compute_beta/classes.rb', line 637 def network_tier @network_tier end |
#prefix_length ⇒ Fixnum
The prefix length if the resource reprensents an IP range.
Corresponds to the JSON property prefixLength
642 643 644 |
# File 'generated/google/apis/compute_beta/classes.rb', line 642 def prefix_length @prefix_length end |
#purpose ⇒ String
The purpose of this resource, which can be one of the following values:
GCE_ENDPOINT
for addresses that are used by VM instances, alias IP ranges, internal load balancers, and similar resources.DNS_RESOLVER
for a DNS resolver address in a subnetworkVPC_PEERING
for addresses that are reserved for VPC peer networks.NAT_AUTO
for addresses that are external IP addresses automatically reserved for Cloud NAT.IPSEC_INTERCONNECT
for addresses created from a private IP range that are reserved for a VLAN attachment in an IPsec encrypted Interconnect configuration. These addresses are regional resources. Corresponds to the JSON propertypurpose
656 657 658 |
# File 'generated/google/apis/compute_beta/classes.rb', line 656 def purpose @purpose end |
#region ⇒ String
[Output Only] The URL of the region where the regional address resides. This
field is not applicable to global addresses. You must specify this field as
part of the HTTP request URL.
Corresponds to the JSON property region
663 664 665 |
# File 'generated/google/apis/compute_beta/classes.rb', line 663 def region @region end |
#self_link ⇒ String
[Output Only] Server-defined URL for the resource.
Corresponds to the JSON property selfLink
668 669 670 |
# File 'generated/google/apis/compute_beta/classes.rb', line 668 def self_link @self_link end |
#status ⇒ String
[Output Only] The status of the address, which can be one of RESERVING,
RESERVED, or IN_USE. An address that is RESERVING is currently in the process
of being reserved. A RESERVED address is currently reserved and available to
use. An IN_USE address is currently being used by another resource and is not
available.
Corresponds to the JSON property status
677 678 679 |
# File 'generated/google/apis/compute_beta/classes.rb', line 677 def status @status end |
#subnetwork ⇒ String
The URL of the subnetwork in which to reserve the address. If an IP address is
specified, it must be within the subnetwork's IP range. This field can only be
used with INTERNAL type with a GCE_ENDPOINT or DNS_RESOLVER purpose.
Corresponds to the JSON property subnetwork
684 685 686 |
# File 'generated/google/apis/compute_beta/classes.rb', line 684 def subnetwork @subnetwork end |
#users ⇒ Array<String>
[Output Only] The URLs of the resources that are using this address.
Corresponds to the JSON property users
689 690 691 |
# File 'generated/google/apis/compute_beta/classes.rb', line 689 def users @users end |
Instance Method Details
#update!(**args) ⇒ Object
Update properties of this object
696 697 698 699 700 701 702 703 704 705 706 707 708 709 710 711 712 713 714 715 716 |
# File 'generated/google/apis/compute_beta/classes.rb', line 696 def update!(**args) @address = args[:address] if args.key?(:address) @address_type = args[:address_type] if args.key?(:address_type) @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp) @description = args[:description] if args.key?(:description) @id = args[:id] if args.key?(:id) @ip_version = args[:ip_version] if args.key?(:ip_version) @kind = args[:kind] if args.key?(:kind) @label_fingerprint = args[:label_fingerprint] if args.key?(:label_fingerprint) @labels = args[:labels] if args.key?(:labels) @name = args[:name] if args.key?(:name) @network = args[:network] if args.key?(:network) @network_tier = args[:network_tier] if args.key?(:network_tier) @prefix_length = args[:prefix_length] if args.key?(:prefix_length) @purpose = args[:purpose] if args.key?(:purpose) @region = args[:region] if args.key?(:region) @self_link = args[:self_link] if args.key?(:self_link) @status = args[:status] if args.key?(:status) @subnetwork = args[:subnetwork] if args.key?(:subnetwork) @users = args[:users] if args.key?(:users) end |