All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.google.api.services.batch.v1.model.Disk Maven / Gradle / Ivy

/*
 * 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.
 */
/*
 * This code was generated by https://github.com/googleapis/google-api-java-client-services/
 * Modify at your own risk.
 */

package com.google.api.services.batch.v1.model;

/**
 * A new persistent disk or a local ssd. A VM can only have one local SSD setting but multiple local
 * SSD partitions. See https://cloud.google.com/compute/docs/disks#pdspecs and
 * https://cloud.google.com/compute/docs/disks#localssds.
 *
 * 

This is the Java data model class that specifies how to parse/serialize into the JSON that is * transmitted over HTTP when working with the Batch API. For a detailed explanation see: * https://developers.google.com/api-client-library/java/google-http-java-client/json *

* * @author Google, Inc. */ @SuppressWarnings("javadoc") public final class Disk extends com.google.api.client.json.GenericJson { /** * Local SSDs are available through both "SCSI" and "NVMe" interfaces. If not indicated, "NVMe" * will be the default one for local ssds. This field is ignored for persistent disks as the * interface is chosen automatically. See https://cloud.google.com/compute/docs/disks/persistent- * disks#choose_an_interface. * The value may be {@code null}. */ @com.google.api.client.util.Key private java.lang.String diskInterface; /** * URL for a VM image to use as the data source for this disk. For example, the following are all * valid URLs: * Specify the image by its family name: * projects/{project}/global/images/family/{image_family} * Specify the image version: * projects/{project}/global/images/{image_version} You can also use Batch customized image in * short names. The following image values are supported for a boot disk: * `batch-debian`: use * Batch Debian images. * `batch-centos`: use Batch CentOS images. * `batch-cos`: use Batch * Container-Optimized images. * `batch-hpc-centos`: use Batch HPC CentOS images. * `batch-hpc- * rocky`: use Batch HPC Rocky Linux images. * The value may be {@code null}. */ @com.google.api.client.util.Key private java.lang.String image; /** * Disk size in GB. **Non-Boot Disk**: If the `type` specifies a persistent disk, this field is * ignored if `data_source` is set as `image` or `snapshot`. If the `type` specifies a local SSD, * this field should be a multiple of 375 GB, otherwise, the final size will be the next greater * multiple of 375 GB. **Boot Disk**: Batch will calculate the boot disk size based on source * image and task requirements if you do not speicify the size. If both this field and the * `boot_disk_mib` field in task spec's `compute_resource` are defined, Batch will only honor this * field. Also, this field should be no smaller than the source disk's size when the `data_source` * is set as `snapshot` or `image`. For example, if you set an image as the `data_source` field * and the image's default disk size 30 GB, you can only use this field to make the disk larger or * equal to 30 GB. * The value may be {@code null}. */ @com.google.api.client.util.Key @com.google.api.client.json.JsonString private java.lang.Long sizeGb; /** * Name of a snapshot used as the data source. Snapshot is not supported as boot disk now. * The value may be {@code null}. */ @com.google.api.client.util.Key private java.lang.String snapshot; /** * Disk type as shown in `gcloud compute disk-types list`. For example, local SSD uses type * "local-ssd". Persistent disks and boot disks use "pd-balanced", "pd-extreme", "pd-ssd" or "pd- * standard". * The value may be {@code null}. */ @com.google.api.client.util.Key private java.lang.String type; /** * Local SSDs are available through both "SCSI" and "NVMe" interfaces. If not indicated, "NVMe" * will be the default one for local ssds. This field is ignored for persistent disks as the * interface is chosen automatically. See https://cloud.google.com/compute/docs/disks/persistent- * disks#choose_an_interface. * @return value or {@code null} for none */ public java.lang.String getDiskInterface() { return diskInterface; } /** * Local SSDs are available through both "SCSI" and "NVMe" interfaces. If not indicated, "NVMe" * will be the default one for local ssds. This field is ignored for persistent disks as the * interface is chosen automatically. See https://cloud.google.com/compute/docs/disks/persistent- * disks#choose_an_interface. * @param diskInterface diskInterface or {@code null} for none */ public Disk setDiskInterface(java.lang.String diskInterface) { this.diskInterface = diskInterface; return this; } /** * URL for a VM image to use as the data source for this disk. For example, the following are all * valid URLs: * Specify the image by its family name: * projects/{project}/global/images/family/{image_family} * Specify the image version: * projects/{project}/global/images/{image_version} You can also use Batch customized image in * short names. The following image values are supported for a boot disk: * `batch-debian`: use * Batch Debian images. * `batch-centos`: use Batch CentOS images. * `batch-cos`: use Batch * Container-Optimized images. * `batch-hpc-centos`: use Batch HPC CentOS images. * `batch-hpc- * rocky`: use Batch HPC Rocky Linux images. * @return value or {@code null} for none */ public java.lang.String getImage() { return image; } /** * URL for a VM image to use as the data source for this disk. For example, the following are all * valid URLs: * Specify the image by its family name: * projects/{project}/global/images/family/{image_family} * Specify the image version: * projects/{project}/global/images/{image_version} You can also use Batch customized image in * short names. The following image values are supported for a boot disk: * `batch-debian`: use * Batch Debian images. * `batch-centos`: use Batch CentOS images. * `batch-cos`: use Batch * Container-Optimized images. * `batch-hpc-centos`: use Batch HPC CentOS images. * `batch-hpc- * rocky`: use Batch HPC Rocky Linux images. * @param image image or {@code null} for none */ public Disk setImage(java.lang.String image) { this.image = image; return this; } /** * Disk size in GB. **Non-Boot Disk**: If the `type` specifies a persistent disk, this field is * ignored if `data_source` is set as `image` or `snapshot`. If the `type` specifies a local SSD, * this field should be a multiple of 375 GB, otherwise, the final size will be the next greater * multiple of 375 GB. **Boot Disk**: Batch will calculate the boot disk size based on source * image and task requirements if you do not speicify the size. If both this field and the * `boot_disk_mib` field in task spec's `compute_resource` are defined, Batch will only honor this * field. Also, this field should be no smaller than the source disk's size when the `data_source` * is set as `snapshot` or `image`. For example, if you set an image as the `data_source` field * and the image's default disk size 30 GB, you can only use this field to make the disk larger or * equal to 30 GB. * @return value or {@code null} for none */ public java.lang.Long getSizeGb() { return sizeGb; } /** * Disk size in GB. **Non-Boot Disk**: If the `type` specifies a persistent disk, this field is * ignored if `data_source` is set as `image` or `snapshot`. If the `type` specifies a local SSD, * this field should be a multiple of 375 GB, otherwise, the final size will be the next greater * multiple of 375 GB. **Boot Disk**: Batch will calculate the boot disk size based on source * image and task requirements if you do not speicify the size. If both this field and the * `boot_disk_mib` field in task spec's `compute_resource` are defined, Batch will only honor this * field. Also, this field should be no smaller than the source disk's size when the `data_source` * is set as `snapshot` or `image`. For example, if you set an image as the `data_source` field * and the image's default disk size 30 GB, you can only use this field to make the disk larger or * equal to 30 GB. * @param sizeGb sizeGb or {@code null} for none */ public Disk setSizeGb(java.lang.Long sizeGb) { this.sizeGb = sizeGb; return this; } /** * Name of a snapshot used as the data source. Snapshot is not supported as boot disk now. * @return value or {@code null} for none */ public java.lang.String getSnapshot() { return snapshot; } /** * Name of a snapshot used as the data source. Snapshot is not supported as boot disk now. * @param snapshot snapshot or {@code null} for none */ public Disk setSnapshot(java.lang.String snapshot) { this.snapshot = snapshot; return this; } /** * Disk type as shown in `gcloud compute disk-types list`. For example, local SSD uses type * "local-ssd". Persistent disks and boot disks use "pd-balanced", "pd-extreme", "pd-ssd" or "pd- * standard". * @return value or {@code null} for none */ public java.lang.String getType() { return type; } /** * Disk type as shown in `gcloud compute disk-types list`. For example, local SSD uses type * "local-ssd". Persistent disks and boot disks use "pd-balanced", "pd-extreme", "pd-ssd" or "pd- * standard". * @param type type or {@code null} for none */ public Disk setType(java.lang.String type) { this.type = type; return this; } @Override public Disk set(String fieldName, Object value) { return (Disk) super.set(fieldName, value); } @Override public Disk clone() { return (Disk) super.clone(); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy