2014-08-26 23:50:29 +02:00
---
layout: "google"
page_title: "Provider: Google Cloud"
sidebar_current: "docs-google-index"
2014-10-22 05:21:56 +02:00
description: |-
The Google Cloud provider is used to interact with Google Cloud services. The provider needs to be configured with the proper credentials before it can be used.
2014-08-26 23:50:29 +02:00
---
# Google Cloud Provider
The Google Cloud provider is used to interact with
[Google Cloud services ](https://cloud.google.com/ ). The provider needs
to be configured with the proper credentials before it can be used.
Use the navigation to the left to read about the available resources.
## Example Usage
```
# Configure the Google Cloud provider
provider "google" {
2015-11-12 23:13:07 +01:00
credentials = "${file("account.json")}"
project = "my-gce-project"
region = "us-central1"
2014-08-26 23:50:29 +02:00
}
# Create a new instance
resource "google_compute_instance" "default" {
2015-11-12 23:13:07 +01:00
...
2014-08-26 23:50:29 +02:00
}
```
## Configuration Reference
The following keys can be used to configure the provider.
2015-11-12 23:13:07 +01:00
* `credentials` - (Optional) Contents of the JSON file used to describe your
2015-07-27 21:35:52 +02:00
account credentials, downloaded from Google Cloud Console. More details on
2015-11-12 23:13:07 +01:00
retrieving this file are below. Credentials may be blank if you are running
Terraform from a GCE instance with a properly-configured [Compute Engine
2015-07-27 21:35:52 +02:00
Service Account](https://cloud.google.com/compute/docs/authentication). This
2016-04-04 23:56:35 +02:00
can also be specified with the `GOOGLE_CREDENTIALS` or `GOOGLE_CLOUD_KEYFILE_JSON`
shell environment variable, containing the contents of the credentials file.
2014-08-26 23:50:29 +02:00
2015-04-09 21:25:21 +02:00
* `region` - (Required) The region to operate under. This can also be specified
with the `GOOGLE_REGION` shell environment variable.
2014-08-26 23:50:29 +02:00
2016-04-08 17:01:53 +02:00
* `project` - (Optional) The ID of the project to apply resources in. This
can also be specified with the `GOOGLE_PROJECT` shell environment variable.
If unspecified, users will need to specify the `project` attribute for
all resources. If specified, resources which do not depend on a project will
ignore this value.
2015-11-12 23:13:07 +01:00
The following keys are supported for backwards compatibility, and may be
removed in a future version:
* `account_file` - __Deprecated: please use `credentials` instead.__
Path to or contents of the JSON file used to describe your
account credentials, downloaded from Google Cloud Console. More details on
retrieving this file are below. The `account file` can be "" if you are running
terraform from a GCE instance with a properly-configured [Compute Engine
Service Account](https://cloud.google.com/compute/docs/authentication). This
can also be specified with the `GOOGLE_ACCOUNT_FILE` shell environment
variable.
2014-10-14 09:00:44 +02:00
## Authentication JSON File
2014-08-26 23:50:29 +02:00
2014-10-14 09:00:44 +02:00
Authenticating with Google Cloud services requires a JSON
file which we call the _account file_ .
2014-08-26 23:50:29 +02:00
2014-10-14 09:00:44 +02:00
This file is downloaded directly from the
2014-08-26 23:50:29 +02:00
[Google Developers Console ](https://console.developers.google.com ). To make
2014-10-14 09:00:44 +02:00
the process more straightforwarded, it is documented here:
2014-08-26 23:50:29 +02:00
1. Log into the [Google Developers Console ](https://console.developers.google.com )
and select a project.
2015-12-11 19:19:37 +01:00
2. Click the menu button in the top left corner, and navigate to "Permissions",
then "Service accounts", and finally "Create service account".
2014-08-26 23:50:29 +02:00
2015-12-11 19:19:37 +01:00
3. Provide a name and ID in the corresponding fields, select
"Furnish a new private key", and select "JSON" as the key type.
4. Clicking "Create" will download your `credentials` .