Class: Google::Apis::ComputeAlpha::FutureReservation
- Inherits:
-
Object
- Object
- Google::Apis::ComputeAlpha::FutureReservation
- 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
Instance Attribute Summary collapse
-
#aggregate_reservation ⇒ Google::Apis::ComputeAlpha::AllocationAggregateReservation
This reservation type is specified by total resource amounts (e.g. total count of CPUs) and can account for multiple instance SKUs.
-
#auto_created_reservations_delete_time ⇒ String
Future timestamp when the FR auto-created reservations will be deleted by Compute Engine.
-
#auto_created_reservations_duration ⇒ Google::Apis::ComputeAlpha::Duration
A Duration represents a fixed-length span of time represented as a count of seconds and fractions of seconds at nanosecond resolution.
-
#auto_delete_auto_created_reservations ⇒ Boolean
(also: #auto_delete_auto_created_reservations?)
Setting for enabling or disabling automatic deletion for auto-created reservation.
-
#commitment_info ⇒ Google::Apis::ComputeAlpha::FutureReservationCommitmentInfo
If not present, then FR will not deliver a new commitment or update an existing commitment.
-
#creation_timestamp ⇒ String
[Output Only] The creation timestamp for this future reservation in RFC3339 text format.
-
#deployment_type ⇒ String
Type of the deployment requested as part of future reservation.
-
#description ⇒ String
An optional description of this resource.
-
#enable_emergent_maintenance ⇒ Boolean
(also: #enable_emergent_maintenance?)
Indicates if this group of VMs have emergent maintenance enabled.
-
#id ⇒ Fixnum
[Output Only] A unique identifier for this future reservation.
-
#kind ⇒ String
[Output Only] Type of the resource.
-
#name ⇒ String
The name of the resource, provided by the client when initially creating the resource.
-
#name_prefix ⇒ String
Name prefix for the reservations to be created at the time of delivery.
-
#planning_status ⇒ String
Planning state before being submitted for evaluation Corresponds to the JSON property
planningStatus. -
#protection_tier ⇒ String
Protection tier for the workload.
-
#reservation_mode ⇒ String
The reservation mode which determines reservation-termination behavior and expected pricing.
-
#reservation_name ⇒ String
Name of reservations where the capacity is provisioned at the time of delivery of future reservations.
-
#scheduling_type ⇒ String
Maintenance information for this reservation Corresponds to the JSON property
schedulingType. -
#self_link ⇒ String
[Output Only] Server-defined fully-qualified URL for this resource.
-
#self_link_with_id ⇒ String
[Output Only] Server-defined URL for this resource with the resource id.
-
#share_settings ⇒ Google::Apis::ComputeAlpha::ShareSettings
The share setting for reservations and sole tenancy node groups.
-
#specific_reservation_required ⇒ Boolean
(also: #specific_reservation_required?)
Indicates whether the auto-created reservation can be consumed by VMs with affinity for "any" reservation.
-
#specific_sku_properties ⇒ Google::Apis::ComputeAlpha::FutureReservationSpecificSkuProperties
Future Reservation configuration to indicate instance properties and total count.
-
#status ⇒ Google::Apis::ComputeAlpha::FutureReservationStatus
[Output only] Represents status related to the future reservation.
-
#time_window ⇒ Google::Apis::ComputeAlpha::FutureReservationTimeWindow
Time window for this Future Reservation.
-
#zone ⇒ String
[Output Only] URL of the Zone where this future reservation resides.
Instance Method Summary collapse
-
#initialize(**args) ⇒ FutureReservation
constructor
A new instance of FutureReservation.
-
#update!(**args) ⇒ Object
Update properties of this object.
Constructor Details
#initialize(**args) ⇒ FutureReservation
Returns a new instance of FutureReservation.
14175 14176 14177 |
# File 'lib/google/apis/compute_alpha/classes.rb', line 14175 def initialize(**args) update!(**args) end |
Instance Attribute Details
#aggregate_reservation ⇒ Google::Apis::ComputeAlpha::AllocationAggregateReservation
This reservation type is specified by total resource amounts (e.g. total count
of CPUs) and can account for multiple instance SKUs. In other words, one can
create instances of varying shapes against this reservation.
Corresponds to the JSON property aggregateReservation
14014 14015 14016 |
# File 'lib/google/apis/compute_alpha/classes.rb', line 14014 def aggregate_reservation @aggregate_reservation end |
#auto_created_reservations_delete_time ⇒ String
Future timestamp when the FR auto-created reservations will be deleted by
Compute Engine. Format of this field must be a valid href="https://www.ietf.
org/rfc/rfc3339.txt">RFC3339 value.
Corresponds to the JSON property autoCreatedReservationsDeleteTime
14021 14022 14023 |
# File 'lib/google/apis/compute_alpha/classes.rb', line 14021 def auto_created_reservations_delete_time @auto_created_reservations_delete_time end |
#auto_created_reservations_duration ⇒ Google::Apis::ComputeAlpha::Duration
A Duration represents a fixed-length span of time represented as a count of
seconds and fractions of seconds at nanosecond resolution. It is independent
of any calendar and concepts like "day" or "month". Range is approximately 10,
000 years.
Corresponds to the JSON property autoCreatedReservationsDuration
14029 14030 14031 |
# File 'lib/google/apis/compute_alpha/classes.rb', line 14029 def auto_created_reservations_duration @auto_created_reservations_duration end |
#auto_delete_auto_created_reservations ⇒ Boolean Also known as: auto_delete_auto_created_reservations?
Setting for enabling or disabling automatic deletion for auto-created
reservation. If set to true, auto-created reservations will be deleted at
Future Reservation's end time (default) or at user's defined timestamp if any
of the [auto_created_reservations_delete_time,
auto_created_reservations_duration] values is specified. For keeping auto-
created reservation indefinitely, this value should be set to false.
Corresponds to the JSON property autoDeleteAutoCreatedReservations
14039 14040 14041 |
# File 'lib/google/apis/compute_alpha/classes.rb', line 14039 def auto_delete_auto_created_reservations @auto_delete_auto_created_reservations end |
#commitment_info ⇒ Google::Apis::ComputeAlpha::FutureReservationCommitmentInfo
If not present, then FR will not deliver a new commitment or update an
existing commitment.
Corresponds to the JSON property commitmentInfo
14046 14047 14048 |
# File 'lib/google/apis/compute_alpha/classes.rb', line 14046 def commitment_info @commitment_info end |
#creation_timestamp ⇒ String
[Output Only] The creation timestamp for this future reservation in RFC3339
text format.
Corresponds to the JSON property creationTimestamp
14052 14053 14054 |
# File 'lib/google/apis/compute_alpha/classes.rb', line 14052 def @creation_timestamp end |
#deployment_type ⇒ String
Type of the deployment requested as part of future reservation.
Corresponds to the JSON property deploymentType
14057 14058 14059 |
# File 'lib/google/apis/compute_alpha/classes.rb', line 14057 def deployment_type @deployment_type end |
#description ⇒ String
An optional description of this resource. Provide this property when you
create the future reservation.
Corresponds to the JSON property description
14063 14064 14065 |
# File 'lib/google/apis/compute_alpha/classes.rb', line 14063 def description @description end |
#enable_emergent_maintenance ⇒ Boolean Also known as: enable_emergent_maintenance?
Indicates if this group of VMs have emergent maintenance enabled.
Corresponds to the JSON property enableEmergentMaintenance
14068 14069 14070 |
# File 'lib/google/apis/compute_alpha/classes.rb', line 14068 def enable_emergent_maintenance @enable_emergent_maintenance end |
#id ⇒ Fixnum
[Output Only] A unique identifier for this future reservation. The server
defines this identifier.
Corresponds to the JSON property id
14075 14076 14077 |
# File 'lib/google/apis/compute_alpha/classes.rb', line 14075 def id @id end |
#kind ⇒ String
[Output Only] Type of the resource. Always compute#futureReservation for
future reservations.
Corresponds to the JSON property kind
14081 14082 14083 |
# File 'lib/google/apis/compute_alpha/classes.rb', line 14081 def kind @kind end |
#name ⇒ String
The name of the resource, provided by the client when initially creating the
resource. The resource 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])? which means the first
character must be a lowercase letter, and all following characters must be a
dash, lowercase letter, or digit, except the last character, which cannot be a
dash.
Corresponds to the JSON property name
14092 14093 14094 |
# File 'lib/google/apis/compute_alpha/classes.rb', line 14092 def name @name end |
#name_prefix ⇒ String
Name prefix for the reservations to be created at the time of delivery. The
name prefix must comply with RFC1035. Maximum allowed length for name prefix
is 20. Automatically created reservations name format will be -date-####.
Corresponds to the JSON property namePrefix
14099 14100 14101 |
# File 'lib/google/apis/compute_alpha/classes.rb', line 14099 def name_prefix @name_prefix end |
#planning_status ⇒ String
Planning state before being submitted for evaluation
Corresponds to the JSON property planningStatus
14104 14105 14106 |
# File 'lib/google/apis/compute_alpha/classes.rb', line 14104 def planning_status @planning_status end |
#protection_tier ⇒ String
Protection tier for the workload.
Corresponds to the JSON property protectionTier
14109 14110 14111 |
# File 'lib/google/apis/compute_alpha/classes.rb', line 14109 def protection_tier @protection_tier end |
#reservation_mode ⇒ String
The reservation mode which determines reservation-termination behavior and
expected pricing.
Corresponds to the JSON property reservationMode
14115 14116 14117 |
# File 'lib/google/apis/compute_alpha/classes.rb', line 14115 def reservation_mode @reservation_mode end |
#reservation_name ⇒ String
Name of reservations where the capacity is provisioned at the time of delivery
of future reservations. If the reservation with the given name does not exist
already, it is created automatically at the time of Approval with INACTIVE
state till specified start-time. Either provide the reservation_name or a
name_prefix.
Corresponds to the JSON property reservationName
14124 14125 14126 |
# File 'lib/google/apis/compute_alpha/classes.rb', line 14124 def reservation_name @reservation_name end |
#scheduling_type ⇒ String
Maintenance information for this reservation
Corresponds to the JSON property schedulingType
14129 14130 14131 |
# File 'lib/google/apis/compute_alpha/classes.rb', line 14129 def scheduling_type @scheduling_type end |
#self_link ⇒ String
[Output Only] Server-defined fully-qualified URL for this resource.
Corresponds to the JSON property selfLink
14134 14135 14136 |
# File 'lib/google/apis/compute_alpha/classes.rb', line 14134 def self_link @self_link end |
#self_link_with_id ⇒ String
[Output Only] Server-defined URL for this resource with the resource id.
Corresponds to the JSON property selfLinkWithId
14139 14140 14141 |
# File 'lib/google/apis/compute_alpha/classes.rb', line 14139 def self_link_with_id @self_link_with_id end |
#share_settings ⇒ Google::Apis::ComputeAlpha::ShareSettings
The share setting for reservations and sole tenancy node groups.
Corresponds to the JSON property shareSettings
14144 14145 14146 |
# File 'lib/google/apis/compute_alpha/classes.rb', line 14144 def share_settings @share_settings end |
#specific_reservation_required ⇒ Boolean Also known as: specific_reservation_required?
Indicates whether the auto-created reservation can be consumed by VMs with
affinity for "any" reservation. If the field is set, then only VMs that target
the reservation by name can consume from the delivered reservation.
Corresponds to the JSON property specificReservationRequired
14151 14152 14153 |
# File 'lib/google/apis/compute_alpha/classes.rb', line 14151 def specific_reservation_required @specific_reservation_required end |
#specific_sku_properties ⇒ Google::Apis::ComputeAlpha::FutureReservationSpecificSkuProperties
Future Reservation configuration to indicate instance properties and total
count.
Corresponds to the JSON property specificSkuProperties
14158 14159 14160 |
# File 'lib/google/apis/compute_alpha/classes.rb', line 14158 def specific_sku_properties @specific_sku_properties end |
#status ⇒ Google::Apis::ComputeAlpha::FutureReservationStatus
[Output only] Represents status related to the future reservation.
Corresponds to the JSON property status
14163 14164 14165 |
# File 'lib/google/apis/compute_alpha/classes.rb', line 14163 def status @status end |
#time_window ⇒ Google::Apis::ComputeAlpha::FutureReservationTimeWindow
Time window for this Future Reservation.
Corresponds to the JSON property timeWindow
14168 14169 14170 |
# File 'lib/google/apis/compute_alpha/classes.rb', line 14168 def time_window @time_window end |
#zone ⇒ String
[Output Only] URL of the Zone where this future reservation resides.
Corresponds to the JSON property zone
14173 14174 14175 |
# File 'lib/google/apis/compute_alpha/classes.rb', line 14173 def zone @zone end |
Instance Method Details
#update!(**args) ⇒ Object
Update properties of this object
14180 14181 14182 14183 14184 14185 14186 14187 14188 14189 14190 14191 14192 14193 14194 14195 14196 14197 14198 14199 14200 14201 14202 14203 14204 14205 14206 14207 |
# File 'lib/google/apis/compute_alpha/classes.rb', line 14180 def update!(**args) @aggregate_reservation = args[:aggregate_reservation] if args.key?(:aggregate_reservation) @auto_created_reservations_delete_time = args[:auto_created_reservations_delete_time] if args.key?(:auto_created_reservations_delete_time) @auto_created_reservations_duration = args[:auto_created_reservations_duration] if args.key?(:auto_created_reservations_duration) @auto_delete_auto_created_reservations = args[:auto_delete_auto_created_reservations] if args.key?(:auto_delete_auto_created_reservations) @commitment_info = args[:commitment_info] if args.key?(:commitment_info) @creation_timestamp = args[:creation_timestamp] if args.key?(:creation_timestamp) @deployment_type = args[:deployment_type] if args.key?(:deployment_type) @description = args[:description] if args.key?(:description) @enable_emergent_maintenance = args[:enable_emergent_maintenance] if args.key?(:enable_emergent_maintenance) @id = args[:id] if args.key?(:id) @kind = args[:kind] if args.key?(:kind) @name = args[:name] if args.key?(:name) @name_prefix = args[:name_prefix] if args.key?(:name_prefix) @planning_status = args[:planning_status] if args.key?(:planning_status) @protection_tier = args[:protection_tier] if args.key?(:protection_tier) @reservation_mode = args[:reservation_mode] if args.key?(:reservation_mode) @reservation_name = args[:reservation_name] if args.key?(:reservation_name) @scheduling_type = args[:scheduling_type] if args.key?(:scheduling_type) @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) @share_settings = args[:share_settings] if args.key?(:share_settings) @specific_reservation_required = args[:specific_reservation_required] if args.key?(:specific_reservation_required) @specific_sku_properties = args[:specific_sku_properties] if args.key?(:specific_sku_properties) @status = args[:status] if args.key?(:status) @time_window = args[:time_window] if args.key?(:time_window) @zone = args[:zone] if args.key?(:zone) end |