Skip to content

Commit

Permalink
Add Google Spanner Support (google_spanner_instance) (hashicorp#270)
Browse files Browse the repository at this point in the history
  • Loading branch information
nickithewatt authored and rosbo committed Aug 14, 2017
1 parent 020816d commit 896e4d9
Show file tree
Hide file tree
Showing 2 changed files with 82 additions and 0 deletions.
73 changes: 73 additions & 0 deletions docs/r/spanner_instance.html.markdown
Original file line number Diff line number Diff line change
@@ -0,0 +1,73 @@
---
layout: "google"
page_title: "Google: google_spanner_instance"
sidebar_current: "docs-google-spanner-instance"
description: |-
Creates and manages a Google Spanner Instance.
---

# google\_spanner\_instance

Creates and manages a Google Spanner Instance. For more information, see the [official documentation](https://cloud.google.com/spanner/), or the [JSON API](https://cloud.google.com/spanner/docs/reference/rest/v1/projects.instances).

## Example Usage

Example creating a Spanner instance.

```hcl
resource "google_spanner_instance" "main" {
config = "regional-europe-west1"
display_name = "main-instance"
name = "main-instance"
num_nodes = 1
}
```

## Argument Reference

The following arguments are supported:

* `config` - (Required) The name of the instance's configuration (similar but not
quite the same as a region) which defines defines the geographic placement and
replication of your databases in this instance. It determines where your data
is stored. Values are typically of the form `regional-europe-west1` , `us-central` etc.
In order to obtain a valid list please consult the
[Configuration section of the docs](https://cloud.google.com/spanner/docs/instances).

* `display_name` - (Required) The descriptive name for this instance as it appears
in UIs. Can be updated, however should be kept globally unique to avoid confusion.

- - -

* `name` - (Optional, Computed) The unique name (ID) of the instance. If the name is left
blank, Terraform will randomly generate one when the instance is first
created.

* `num_nodes` - (Optional, Computed) The number of nodes allocated to this instance.
Defaults to `1`. This can be updated after creation.

* `project` - (Optional) The project in which the resource belongs. If it
is not provided, the provider project is used.

* `labels` - (Optional) A mapping (key/value pairs) of labels to assign to the instance.

## Attributes Reference

In addition to the arguments listed above, the following computed attributes are
exported:

* `state` - The current state of the instance.

## Import

Instances can be imported using their `name` and optionally
the `project` in which it is defined (Often used when the project is different
to that defined in the provider), The format is thus either `{instanceId}` or
`{projectId}/{instanceId}`. e.g.

```
$ terraform import google_spanner_instance.master instance123
$ terraform import google_spanner_instance.master project123/instance456
```
9 changes: 9 additions & 0 deletions google.erb
Original file line number Diff line number Diff line change
Expand Up @@ -279,6 +279,15 @@
</ul>
</li>

<li<%= sidebar_current("docs-google-spanner") %>>
<a href="#">Google Spanner Resources</a>
<ul class="nav nav-visible">
<li<%= sidebar_current("docs-google-spanner-instance") %>>
<a href="/docs/providers/google/r/spanner_instance.html">google_spanner_instance</a>
</li>
</ul>
</li>

<li<%= sidebar_current("docs-google-sql") %>>
<a href="#">Google SQL Resources</a>
<ul class="nav nav-visible">
Expand Down

0 comments on commit 896e4d9

Please sign in to comment.