This module creates a Google Cloud Storage (GCS) bucket.
For more information on this and other network storage options in the Cluster Toolkit, see the extended Network Storage documentation.
The following example will create a bucket named simulation-results-xxxxxxxx
,
where xxxxxxxx
is a randomly generated id.
- id: bucket
source: community/modules/file-system/cloud-storage-bucket
settings:
name_prefix: simulation-results
random_suffix: true
NOTE: Use of
random_suffix
may cause the following error when used with other modules:value depends on resource attributes that cannot be determined until apply
. To resolve this setrandom_suffix
tofalse
(default).
NOTE: Bucket namespace is shared by all users of Google Cloud so it is possible to have a bucket name clash with an existing bucket that is not in your project. To resolve this try to use a more unique name, or set the
random_suffix
variable totrue
.
There are potentially three parts to the bucket name. Each of these parts are configurable in the blueprint.
-
A custom prefix, provided by the user in the blueprint
Provide the custom prefix using thename_prefix
setting. -
The deployment name, included by default
The deployment name can be excluded by settinguse_deployment_name_in_bucket_name: false
. -
A random id suffix, excluded by default
The random id can be included by settingrandom_suffix: true
.
If none of these are provided (no name_prefix
,
use_deployment_name_in_bucket_name: false
, & random_suffix: false
), then the
bucket name will default to no-bucket-name-provided
.
Since bucket namespace is shared by all users of Google Cloud, it is more likely
to experience naming clashes than with other resources. In many cases, adding
the random_suffix
will resolve the naming clash issue.
Warning: If a bucket is created with a
random_suffix
and then used as the bucket for a startup script in the same deployment group this will cause anot known at apply time
error in terraform. The solution is to either create the bucket in a separate deployment group or to remove the random suffix.
To mount the Cloud Storage bucket you must first ensure that the GCS Fuse client
has been installed and then call the proper mount
command.
Both of these steps are automatically handled with the use of the use
command
in a selection of Cluster Toolkit modules. See the compatibility matrix in
the network storage doc for a complete list of supported modules.
If mounting is not automatically handled as described above, the
cloud-storage-bucket
module outputs runners that can be used with the
startup-script
module to install the client and mount the file system. See the
following example:
- id: bucket
source: community/modules/file-system/cloud-storage-bucket
settings: {local_mount: /data}
- id: mount-at-startup
source: modules/scripts/startup-script
settings:
runners:
- $(bucket.client_install_runner)
- $(bucket.mount_runner)
Copyright 2023 Google LLC
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
Name | Version |
---|---|
terraform | >= 0.14.0 |
>= 3.83 | |
google-beta | >= 6.9.0 |
random | ~> 3.0 |
Name | Version |
---|---|
>= 3.83 | |
google-beta | >= 6.9.0 |
random | ~> 3.0 |
No modules.
Name | Type |
---|---|
google-beta_google_storage_bucket.bucket | resource |
google_storage_bucket_iam_binding.viewers | resource |
random_id.resource_name_suffix | resource |
Name | Description | Type | Default | Required |
---|---|---|---|---|
deployment_name | Name of the HPC deployment; used as part of name of the GCS bucket. | string |
n/a | yes |
enable_hierarchical_namespace | If true, enables hierarchical namespace for the bucket. This option must be configured during the initial creation of the bucket. | bool |
false |
no |
force_destroy | If true will destroy bucket with all objects stored within. | bool |
false |
no |
labels | Labels to add to the GCS bucket. Key-value pairs. | map(string) |
n/a | yes |
local_mount | The mount point where the contents of the device may be accessed after mounting. | string |
"/mnt" |
no |
mount_options | Mount options to be put in fstab. Note: implicit_dirs makes it easier to work with objects added by other tools, but there is a performance impact. See: more information |
string |
"defaults,_netdev,implicit_dirs" |
no |
name_prefix | Name Prefix. | string |
null |
no |
project_id | ID of project in which GCS bucket will be created. | string |
n/a | yes |
random_suffix | If true, a random id will be appended to the suffix of the bucket name. | bool |
false |
no |
region | The region to deploy to | string |
n/a | yes |
use_deployment_name_in_bucket_name | If true, the deployment name will be included as part of the bucket name. This helps prevent naming clashes across multiple deployments. | bool |
true |
no |
viewers | A list of additional accounts that can read packages from this bucket | set(string) |
[] |
no |
Name | Description |
---|---|
client_install_runner | Runner that performs client installation needed to use gcs fuse. |
gcs_bucket_name | Bucket name. |
gcs_bucket_path | The gsutil bucket path with format of gs://<bucket-name> . |
mount_runner | Runner that mounts the cloud storage bucket with gcs fuse. |
network_storage | Describes a remote network storage to be mounted by fs-tab. |