instances
Creates, updates, deletes, gets or lists an instances
resource.
Overview
Name | instances |
Type | Resource |
Id | google.alloydb.instances |
Fields
The following fields are returned by SELECT
queries:
- get
- list
Successful response
Name | Datatype | Description |
---|---|---|
name | string | Output only. The name of the instance resource with the format: * projects/{project}/locations/{region}/clusters/{cluster_id}/instances/{instance_id} where the cluster and instance ID segments should satisfy the regex expression [a-z]([a-z0-9-]{0,61}[a-z0-9])? , e.g. 1-63 characters of lowercase letters, numbers, and dashes, starting with a letter, and ending with a letter or number. For more details see https://google.aip.dev/122. The prefix of the instance resource name is the name of the parent resource: * projects/{project}/locations/{region}/clusters/{cluster_id} |
activationPolicy | string | Optional. Specifies whether an instance needs to spin up. Once the instance is active, the activation policy can be updated to the NEVER to stop the instance. Likewise, the activation policy can be updated to ALWAYS to start the instance. There are restrictions around when an instance can/cannot be activated (for example, a read pool instance should be stopped before stopping primary etc.). Please refer to the API documentation for more details. |
annotations | object | Annotations to allow client tools to store small amount of arbitrary data. This is distinct from labels. https://google.aip.dev/128 |
availabilityType | string | Availability type of an Instance. If empty, defaults to REGIONAL for primary instances. For read pools, availability_type is always UNSPECIFIED. Instances in the read pools are evenly distributed across available zones within the region (i.e. read pools with more than one node will have a node in at least two zones). |
clientConnectionConfig | object | Optional. Client connection specific configurations (id: ClientConnectionConfig) |
createTime | string (google-datetime) | Output only. Create time stamp |
databaseFlags | object | Database flags. Set at the instance level. They are copied from the primary instance on secondary instance creation. Flags that have restrictions default to the value at primary instance on read instances during creation. Read instances can set new flags or override existing flags that are relevant for reads, for example, for enabling columnar cache on a read instance. Flags set on read instance might or might not be present on the primary instance. This is a list of "key": "value" pairs. "key": The name of the flag. These flags are passed at instance setup time, so include both server options and system variables for Postgres. Flags are specified with underscores, not hyphens. "value": The value of the flag. Booleans are set to on for true and off for false. This field must be omitted if the flag doesn't take a value. |
deleteTime | string (google-datetime) | Output only. Delete time stamp |
displayName | string | User-settable and human-readable display name for the Instance. |
etag | string | For Resource freshness validation (https://google.aip.dev/154) |
gceZone | string | The Compute Engine zone that the instance should serve from, per https://cloud.google.com/compute/docs/regions-zones This can ONLY be specified for ZONAL instances. If present for a REGIONAL instance, an error will be thrown. If this is absent for a ZONAL instance, instance is created in a random zone with available capacity. |
instanceType | string | Required. The type of the instance. Specified at creation time. |
ipAddress | string | Output only. The IP address for the Instance. This is the connection endpoint for an end-user application. |
labels | object | Labels as key value pairs |
machineConfig | object | Configurations for the machines that host the underlying database engine. (id: MachineConfig) |
networkConfig | object | Optional. Instance-level network configuration. (id: InstanceNetworkConfig) |
nodes | array | Output only. List of available read-only VMs in this instance, including the standby for a PRIMARY instance. |
observabilityConfig | object | Configuration for observability. (id: ObservabilityInstanceConfig) |
outboundPublicIpAddresses | array | Output only. All outbound public IP addresses configured for the instance. |
pscInstanceConfig | object | Optional. The configuration for Private Service Connect (PSC) for the instance. (id: PscInstanceConfig) |
publicIpAddress | string | Output only. The public IP addresses for the Instance. This is available ONLY when enable_public_ip is set. This is the connection endpoint for an end-user application. |
queryInsightsConfig | object | Configuration for query insights. (id: QueryInsightsInstanceConfig) |
readPoolConfig | object | Read pool instance configuration. This is required if the value of instanceType is READ_POOL. (id: ReadPoolConfig) |
reconciling | boolean | Output only. Reconciling (https://google.aip.dev/128#reconciliation). Set to true if the current state of Instance does not match the user's intended state, and the service is actively updating the resource to reconcile them. This can happen due to user-triggered updates or system actions like failover or maintenance. |
satisfiesPzs | boolean | Output only. Reserved for future use. |
state | string | Output only. The current serving state of the instance. |
uid | string | Output only. The system-generated UID of the resource. The UID is assigned when the resource is created, and it is retained until it is deleted. |
updateTime | string (google-datetime) | Output only. Update time stamp |
writableNode | object | Output only. This is set for the read-write VM of the PRIMARY instance only. (id: Node) |
Successful response
Name | Datatype | Description |
---|---|---|
name | string | Output only. The name of the instance resource with the format: * projects/{project}/locations/{region}/clusters/{cluster_id}/instances/{instance_id} where the cluster and instance ID segments should satisfy the regex expression [a-z]([a-z0-9-]{0,61}[a-z0-9])? , e.g. 1-63 characters of lowercase letters, numbers, and dashes, starting with a letter, and ending with a letter or number. For more details see https://google.aip.dev/122. The prefix of the instance resource name is the name of the parent resource: * projects/{project}/locations/{region}/clusters/{cluster_id} |
activationPolicy | string | Optional. Specifies whether an instance needs to spin up. Once the instance is active, the activation policy can be updated to the NEVER to stop the instance. Likewise, the activation policy can be updated to ALWAYS to start the instance. There are restrictions around when an instance can/cannot be activated (for example, a read pool instance should be stopped before stopping primary etc.). Please refer to the API documentation for more details. |
annotations | object | Annotations to allow client tools to store small amount of arbitrary data. This is distinct from labels. https://google.aip.dev/128 |
availabilityType | string | Availability type of an Instance. If empty, defaults to REGIONAL for primary instances. For read pools, availability_type is always UNSPECIFIED. Instances in the read pools are evenly distributed across available zones within the region (i.e. read pools with more than one node will have a node in at least two zones). |
clientConnectionConfig | object | Optional. Client connection specific configurations (id: ClientConnectionConfig) |
createTime | string (google-datetime) | Output only. Create time stamp |
databaseFlags | object | Database flags. Set at the instance level. They are copied from the primary instance on secondary instance creation. Flags that have restrictions default to the value at primary instance on read instances during creation. Read instances can set new flags or override existing flags that are relevant for reads, for example, for enabling columnar cache on a read instance. Flags set on read instance might or might not be present on the primary instance. This is a list of "key": "value" pairs. "key": The name of the flag. These flags are passed at instance setup time, so include both server options and system variables for Postgres. Flags are specified with underscores, not hyphens. "value": The value of the flag. Booleans are set to on for true and off for false. This field must be omitted if the flag doesn't take a value. |
deleteTime | string (google-datetime) | Output only. Delete time stamp |
displayName | string | User-settable and human-readable display name for the Instance. |
etag | string | For Resource freshness validation (https://google.aip.dev/154) |
gceZone | string | The Compute Engine zone that the instance should serve from, per https://cloud.google.com/compute/docs/regions-zones This can ONLY be specified for ZONAL instances. If present for a REGIONAL instance, an error will be thrown. If this is absent for a ZONAL instance, instance is created in a random zone with available capacity. |
instanceType | string | Required. The type of the instance. Specified at creation time. |
ipAddress | string | Output only. The IP address for the Instance. This is the connection endpoint for an end-user application. |
labels | object | Labels as key value pairs |
machineConfig | object | Configurations for the machines that host the underlying database engine. (id: MachineConfig) |
networkConfig | object | Optional. Instance-level network configuration. (id: InstanceNetworkConfig) |
nodes | array | Output only. List of available read-only VMs in this instance, including the standby for a PRIMARY instance. |
observabilityConfig | object | Configuration for observability. (id: ObservabilityInstanceConfig) |
outboundPublicIpAddresses | array | Output only. All outbound public IP addresses configured for the instance. |
pscInstanceConfig | object | Optional. The configuration for Private Service Connect (PSC) for the instance. (id: PscInstanceConfig) |
publicIpAddress | string | Output only. The public IP addresses for the Instance. This is available ONLY when enable_public_ip is set. This is the connection endpoint for an end-user application. |
queryInsightsConfig | object | Configuration for query insights. (id: QueryInsightsInstanceConfig) |
readPoolConfig | object | Read pool instance configuration. This is required if the value of instanceType is READ_POOL. (id: ReadPoolConfig) |
reconciling | boolean | Output only. Reconciling (https://google.aip.dev/128#reconciliation). Set to true if the current state of Instance does not match the user's intended state, and the service is actively updating the resource to reconcile them. This can happen due to user-triggered updates or system actions like failover or maintenance. |
satisfiesPzs | boolean | Output only. Reserved for future use. |
state | string | Output only. The current serving state of the instance. |
uid | string | Output only. The system-generated UID of the resource. The UID is assigned when the resource is created, and it is retained until it is deleted. |
updateTime | string (google-datetime) | Output only. Update time stamp |
writableNode | object | Output only. This is set for the read-write VM of the PRIMARY instance only. (id: Node) |
Methods
The following methods are available for this resource:
Name | Accessible by | Required Params | Optional Params | Description |
---|---|---|---|---|
get | select | projectsId , locationsId , clustersId , instancesId | view | Gets details of a single Instance. |
list | select | projectsId , locationsId , clustersId | pageSize , pageToken , filter , orderBy | Lists Instances in a given project and location. |
create | insert | projectsId , locationsId , clustersId | instanceId , requestId , validateOnly | Creates a new Instance in a given project and location. |
patch | update | projectsId , locationsId , clustersId , instancesId | updateMask , requestId , validateOnly , allowMissing | Updates the parameters of a single Instance. |
delete | delete | projectsId , locationsId , clustersId , instancesId | requestId , etag , validateOnly | Deletes a single Instance. |
failover | exec | projectsId , locationsId , clustersId , instancesId | Forces a Failover for a highly available instance. Failover promotes the HA standby instance as the new primary. Imperative only. | |
inject_fault | exec | projectsId , locationsId , clustersId , instancesId | Injects fault in an instance. Imperative only. | |
restart | exec | projectsId , locationsId , clustersId , instancesId | Restart an Instance in a cluster. Imperative only. |
Parameters
Parameters can be passed in the WHERE
clause of a query. Check the Methods section to see which parameters are required or optional for each operation.
Name | Datatype | Description |
---|---|---|
clustersId | string | |
instancesId | string | |
locationsId | string | |
projectsId | string | |
allowMissing | boolean | |
etag | string | |
filter | string | |
instanceId | string | |
orderBy | string | |
pageSize | integer (int32) | |
pageToken | string | |
requestId | string | |
updateMask | string (google-fieldmask) | |
validateOnly | boolean | |
view | string |
SELECT
examples
- get
- list
Gets details of a single Instance.
SELECT
name,
activationPolicy,
annotations,
availabilityType,
clientConnectionConfig,
createTime,
databaseFlags,
deleteTime,
displayName,
etag,
gceZone,
instanceType,
ipAddress,
labels,
machineConfig,
networkConfig,
nodes,
observabilityConfig,
outboundPublicIpAddresses,
pscInstanceConfig,
publicIpAddress,
queryInsightsConfig,
readPoolConfig,
reconciling,
satisfiesPzs,
state,
uid,
updateTime,
writableNode
FROM google.alloydb.instances
WHERE projectsId = '{{ projectsId }}' -- required
AND locationsId = '{{ locationsId }}' -- required
AND clustersId = '{{ clustersId }}' -- required
AND instancesId = '{{ instancesId }}' -- required
AND view = '{{ view }}';
Lists Instances in a given project and location.
SELECT
name,
activationPolicy,
annotations,
availabilityType,
clientConnectionConfig,
createTime,
databaseFlags,
deleteTime,
displayName,
etag,
gceZone,
instanceType,
ipAddress,
labels,
machineConfig,
networkConfig,
nodes,
observabilityConfig,
outboundPublicIpAddresses,
pscInstanceConfig,
publicIpAddress,
queryInsightsConfig,
readPoolConfig,
reconciling,
satisfiesPzs,
state,
uid,
updateTime,
writableNode
FROM google.alloydb.instances
WHERE projectsId = '{{ projectsId }}' -- required
AND locationsId = '{{ locationsId }}' -- required
AND clustersId = '{{ clustersId }}' -- required
AND pageSize = '{{ pageSize }}'
AND pageToken = '{{ pageToken }}'
AND filter = '{{ filter }}'
AND orderBy = '{{ orderBy }}';
INSERT
examples
- create
- Manifest
Creates a new Instance in a given project and location.
INSERT INTO google.alloydb.instances (
data__displayName,
data__labels,
data__instanceType,
data__machineConfig,
data__availabilityType,
data__gceZone,
data__databaseFlags,
data__queryInsightsConfig,
data__observabilityConfig,
data__readPoolConfig,
data__etag,
data__annotations,
data__clientConnectionConfig,
data__pscInstanceConfig,
data__networkConfig,
data__activationPolicy,
projectsId,
locationsId,
clustersId,
instanceId,
requestId,
validateOnly
)
SELECT
'{{ displayName }}',
'{{ labels }}',
'{{ instanceType }}',
'{{ machineConfig }}',
'{{ availabilityType }}',
'{{ gceZone }}',
'{{ databaseFlags }}',
'{{ queryInsightsConfig }}',
'{{ observabilityConfig }}',
'{{ readPoolConfig }}',
'{{ etag }}',
'{{ annotations }}',
'{{ clientConnectionConfig }}',
'{{ pscInstanceConfig }}',
'{{ networkConfig }}',
'{{ activationPolicy }}',
'{{ projectsId }}',
'{{ locationsId }}',
'{{ clustersId }}',
'{{ instanceId }}',
'{{ requestId }}',
'{{ validateOnly }}'
RETURNING
name,
done,
error,
metadata,
response
;
# Description fields are for documentation purposes
- name: instances
props:
- name: projectsId
value: string
description: Required parameter for the instances resource.
- name: locationsId
value: string
description: Required parameter for the instances resource.
- name: clustersId
value: string
description: Required parameter for the instances resource.
- name: displayName
value: string
description: >
User-settable and human-readable display name for the Instance.
- name: labels
value: object
description: >
Labels as key value pairs
- name: instanceType
value: string
description: >
Required. The type of the instance. Specified at creation time.
valid_values: ['INSTANCE_TYPE_UNSPECIFIED', 'PRIMARY', 'READ_POOL', 'SECONDARY']
- name: machineConfig
value: object
description: >
Configurations for the machines that host the underlying database engine.
- name: availabilityType
value: string
description: >
Availability type of an Instance. If empty, defaults to REGIONAL for primary instances. For read pools, availability_type is always UNSPECIFIED. Instances in the read pools are evenly distributed across available zones within the region (i.e. read pools with more than one node will have a node in at least two zones).
valid_values: ['AVAILABILITY_TYPE_UNSPECIFIED', 'ZONAL', 'REGIONAL']
- name: gceZone
value: string
description: >
The Compute Engine zone that the instance should serve from, per https://cloud.google.com/compute/docs/regions-zones This can ONLY be specified for ZONAL instances. If present for a REGIONAL instance, an error will be thrown. If this is absent for a ZONAL instance, instance is created in a random zone with available capacity.
- name: databaseFlags
value: object
description: >
Database flags. Set at the instance level. They are copied from the primary instance on secondary instance creation. Flags that have restrictions default to the value at primary instance on read instances during creation. Read instances can set new flags or override existing flags that are relevant for reads, for example, for enabling columnar cache on a read instance. Flags set on read instance might or might not be present on the primary instance. This is a list of "key": "value" pairs. "key": The name of the flag. These flags are passed at instance setup time, so include both server options and system variables for Postgres. Flags are specified with underscores, not hyphens. "value": The value of the flag. Booleans are set to **on** for true and **off** for false. This field must be omitted if the flag doesn't take a value.
- name: queryInsightsConfig
value: object
description: >
Configuration for query insights.
- name: observabilityConfig
value: object
description: >
Configuration for observability.
- name: readPoolConfig
value: object
description: >
Read pool instance configuration. This is required if the value of instanceType is READ_POOL.
- name: etag
value: string
description: >
For Resource freshness validation (https://google.aip.dev/154)
- name: annotations
value: object
description: >
Annotations to allow client tools to store small amount of arbitrary data. This is distinct from labels. https://google.aip.dev/128
- name: clientConnectionConfig
value: object
description: >
Optional. Client connection specific configurations
- name: pscInstanceConfig
value: object
description: >
Optional. The configuration for Private Service Connect (PSC) for the instance.
- name: networkConfig
value: object
description: >
Optional. Instance-level network configuration.
- name: activationPolicy
value: string
description: >
Optional. Specifies whether an instance needs to spin up. Once the instance is active, the activation policy can be updated to the `NEVER` to stop the instance. Likewise, the activation policy can be updated to `ALWAYS` to start the instance. There are restrictions around when an instance can/cannot be activated (for example, a read pool instance should be stopped before stopping primary etc.). Please refer to the API documentation for more details.
valid_values: ['ACTIVATION_POLICY_UNSPECIFIED', 'ALWAYS', 'NEVER']
- name: instanceId
value: string
- name: requestId
value: string
- name: validateOnly
value: boolean
UPDATE
examples
- patch
Updates the parameters of a single Instance.
UPDATE google.alloydb.instances
SET
data__displayName = '{{ displayName }}',
data__labels = '{{ labels }}',
data__instanceType = '{{ instanceType }}',
data__machineConfig = '{{ machineConfig }}',
data__availabilityType = '{{ availabilityType }}',
data__gceZone = '{{ gceZone }}',
data__databaseFlags = '{{ databaseFlags }}',
data__queryInsightsConfig = '{{ queryInsightsConfig }}',
data__observabilityConfig = '{{ observabilityConfig }}',
data__readPoolConfig = '{{ readPoolConfig }}',
data__etag = '{{ etag }}',
data__annotations = '{{ annotations }}',
data__clientConnectionConfig = '{{ clientConnectionConfig }}',
data__pscInstanceConfig = '{{ pscInstanceConfig }}',
data__networkConfig = '{{ networkConfig }}',
data__activationPolicy = '{{ activationPolicy }}'
WHERE
projectsId = '{{ projectsId }}' --required
AND locationsId = '{{ locationsId }}' --required
AND clustersId = '{{ clustersId }}' --required
AND instancesId = '{{ instancesId }}' --required
AND updateMask = '{{ updateMask}}'
AND requestId = '{{ requestId}}'
AND validateOnly = {{ validateOnly}}
AND allowMissing = {{ allowMissing}}
RETURNING
name,
done,
error,
metadata,
response;
DELETE
examples
- delete
Deletes a single Instance.
DELETE FROM google.alloydb.instances
WHERE projectsId = '{{ projectsId }}' --required
AND locationsId = '{{ locationsId }}' --required
AND clustersId = '{{ clustersId }}' --required
AND instancesId = '{{ instancesId }}' --required
AND requestId = '{{ requestId }}'
AND etag = '{{ etag }}'
AND validateOnly = '{{ validateOnly }}';
Lifecycle Methods
- failover
- inject_fault
- restart
Forces a Failover for a highly available instance. Failover promotes the HA standby instance as the new primary. Imperative only.
EXEC google.alloydb.instances.failover
@projectsId='{{ projectsId }}' --required,
@locationsId='{{ locationsId }}' --required,
@clustersId='{{ clustersId }}' --required,
@instancesId='{{ instancesId }}' --required
@@json=
'{
"requestId": "{{ requestId }}",
"validateOnly": {{ validateOnly }}
}';
Injects fault in an instance. Imperative only.
EXEC google.alloydb.instances.inject_fault
@projectsId='{{ projectsId }}' --required,
@locationsId='{{ locationsId }}' --required,
@clustersId='{{ clustersId }}' --required,
@instancesId='{{ instancesId }}' --required
@@json=
'{
"faultType": "{{ faultType }}",
"requestId": "{{ requestId }}",
"validateOnly": {{ validateOnly }}
}';
Restart an Instance in a cluster. Imperative only.
EXEC google.alloydb.instances.restart
@projectsId='{{ projectsId }}' --required,
@locationsId='{{ locationsId }}' --required,
@clustersId='{{ clustersId }}' --required,
@instancesId='{{ instancesId }}' --required
@@json=
'{
"requestId": "{{ requestId }}",
"validateOnly": {{ validateOnly }},
"nodeIds": "{{ nodeIds }}"
}';