Skip to content
  • Auto
  • Light
  • Dark

Create

Create a New Block Storage Volume
gpu_droplets.volumes.create(VolumeCreateParams**kwargs) -> volumeVolumeVolumeCreateResponse
post/v2/volumes

To create a new volume, send a POST request to /v2/volumes. Optionally, a filesystem_type attribute may be provided in order to automatically format the volume's filesystem. Pre-formatted volumes are automatically mounted when attached to Ubuntu, Debian, Fedora, Fedora Atomic, and CentOS Droplets created on or after April 26, 2018. Attaching pre-formatted volumes to Droplets without support for auto-mounting is not recommended.

Parameters
namestr

A human-readable name for the block storage volume. Must be lowercase and be composed only of numbers, letters and "-", up to a limit of 64 characters. The name must begin with a letter.

regionliteral
Literal["ams1", "ams2", "ams3", 12 more]

The slug identifier for the region where the resource will initially be available.

Hide ParametersShow Parameters
"ams1"
"ams2"
"ams3"
"blr1"
"fra1"
"lon1"
"nyc1"
"nyc2"
"nyc3"
"sfo1"
"sfo2"
"sfo3"
"sgp1"
"tor1"
"syd1"
size_gigabytesint

The size of the block storage volume in GiB (1024^3). This field does not apply when creating a volume from a snapshot.

descriptionstr
optional

An optional free-form text field to describe a block storage volume.

filesystem_labelstr
optional

The label applied to the filesystem. Labels for ext4 type filesystems may contain 16 characters while labels for xfs type filesystems are limited to 12 characters. May only be used in conjunction with filesystem_type.

maxLength16
filesystem_typestr
optional

The name of the filesystem type to be used on the volume. When provided, the volume will automatically be formatted to the specified filesystem type. Currently, the available options are ext4 and xfs. Pre-formatted volumes are automatically mounted when attached to Ubuntu, Debian, Fedora, Fedora Atomic, and CentOS Droplets created on or after April 26, 2018. Attaching pre-formatted volumes to other Droplets is not recommended.

snapshot_idstr
optional

The unique identifier for the volume snapshot from which to create the volume.

tagslist
optional
Optional[List[str]]

A flat array of tag names as strings to be applied to the resource. Tag names may be for either existing or new tags.

Requires tag:create scope.

Returns
VolumeCreateResponseclass
Hide ParametersShow Parameters
volumeidstrcreated_atstrdescriptionstrdroplet_idslistfilesystem_labelstrfilesystem_typestrnamestrregionRegionsize_gigabytesinttagslistVolume
optional
Hide ParametersShow Parameters
idstr
optional

The unique identifier for the block storage volume.

created_atstr
optional

A time value given in ISO8601 combined date and time format that represents when the block storage volume was created.

descriptionstr
optional

An optional free-form text field to describe a block storage volume.

droplet_idslist
optional
Optional[List[int]]

An array containing the IDs of the Droplets the volume is attached to. Note that at this time, a volume can only be attached to a single Droplet.

filesystem_labelstr
optional

The label currently applied to the filesystem.

filesystem_typestr
optional

The type of filesystem currently in-use on the volume.

namestr
optional

A human-readable name for the block storage volume. Must be lowercase and be composed only of numbers, letters and "-", up to a limit of 64 characters. The name must begin with a letter.

regionRegion
optional

The region that the block storage volume is located in. When setting a region, the value should be the slug identifier for the region. When you query a block storage volume, the entire region object will be returned.

size_gigabytesint
optional

The size of the block storage volume in GiB (1024^3). This field does not apply when creating a volume from a snapshot.

tagslist
optional
Optional[List[str]]

A flat array of tag names as strings applied to the resource.

Requires tag:read scope.

from do_gradientai import GradientAI

client = GradientAI()
volume = client.gpu_droplets.volumes.create(
    name="ext4-example",
    region="nyc1",
    size_gigabytes=10,
    description="Block store for examples",
    filesystem_label="ext4_volume_01",
    filesystem_type="ext4",
)
print(volume.volume)
200 Example
{
  "volume": {
    "description": "Block store for examples",
    "filesystem_label": "example",
    "filesystem_type": "ext4",
    "name": "example",
    "size_gigabytes": 10,
    "tags": [
      "base-image",
      "prod"
    ]
  }
}