class Google::Apis::SpannerV1::Instance

An isolated set of Cloud Spanner resources on which databases can be hosted.

Attributes

config[RW]

Required. The name of the instance's configuration. Values are of the form ` projects//instanceConfigs/`. See also InstanceConfig and ListInstanceConfigs. Corresponds to the JSON property `config` @return [String]

display_name[RW]

Required. The descriptive name for this instance as it appears in UIs. Must be unique per project and between 4 and 30 characters in length. Corresponds to the JSON property `displayName` @return [String]

endpoint_uris[RW]

Deprecated. This field is not populated. Corresponds to the JSON property `endpointUris` @return [Array<String>]

labels[RW]

Cloud Labels are a flexible and lightweight mechanism for organizing cloud resources into groups that reflect a customer's organizational needs and deployment strategies. Cloud Labels can be used to filter collections of resources. They can be used to control how resource metrics are aggregated. And they can be used as arguments to policy management rules (e.g. route, firewall, load balancing, etc.). * Label keys must be between 1 and 63 characters long and must conform to the following regular expression: `a-z`0, 62“. * Label values must be between 0 and 63 characters long and must conform to the regular expression `[a-z0-9_-]`0,63“. * No more than 64 labels can be associated with a given resource. See goo.gl/xmQnxf for more information on and examples of labels. If you plan to use labels in your own code, please note that additional characters may be allowed in the future. And so you are advised to use an internal label representation, such as JSON, which doesn't rely upon specific characters being disallowed. For example, representing labels as the string: name + “_” + value would prove problematic if we were to allow “_” in a future release. Corresponds to the JSON property `labels` @return [Hash<String,String>]

name[RW]

Required. A unique identifier for the instance, which cannot be changed after the instance is created. Values are of the form `projects//instances/a-z*[a-z0- 9]`. The final segment of the name must be between 2 and 64 characters in length. Corresponds to the JSON property `name` @return [String]

node_count[RW]

The number of nodes allocated to this instance. At most one of either node_count or processing_units should be present in the message. This may be zero in API responses for instances that are not yet in state `READY`. See [ the documentation](cloud.google.com/spanner/docs/compute-capacity) for more information about nodes and processing units. Corresponds to the JSON property `nodeCount` @return [Fixnum]

processing_units[RW]

The number of processing units allocated to this instance. At most one of processing_units or node_count should be present in the message. This may be zero in API responses for instances that are not yet in state `READY`. See [ the documentation](cloud.google.com/spanner/docs/compute-capacity) for more information about nodes and processing units. Corresponds to the JSON property `processingUnits` @return [Fixnum]

state[RW]

Output only. The current instance state. For CreateInstance, the state must be either omitted or set to `CREATING`. For UpdateInstance, the state must be either omitted or set to `READY`. Corresponds to the JSON property `state` @return [String]

Public Class Methods

new(**args) click to toggle source
# File lib/google/apis/spanner_v1/classes.rb, line 1701
def initialize(**args)
   update!(**args)
end

Public Instance Methods

update!(**args) click to toggle source

Update properties of this object

# File lib/google/apis/spanner_v1/classes.rb, line 1706
def update!(**args)
  @config = args[:config] if args.key?(:config)
  @display_name = args[:display_name] if args.key?(:display_name)
  @endpoint_uris = args[:endpoint_uris] if args.key?(:endpoint_uris)
  @labels = args[:labels] if args.key?(:labels)
  @name = args[:name] if args.key?(:name)
  @node_count = args[:node_count] if args.key?(:node_count)
  @processing_units = args[:processing_units] if args.key?(:processing_units)
  @state = args[:state] if args.key?(:state)
end