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

com.databricks.sdk.service.compute.AwsAttributes Maven / Gradle / Ivy

There is a newer version: 0.38.0
Show newest version
// Code generated from OpenAPI specs by Databricks SDK Generator. DO NOT EDIT.

package com.databricks.sdk.service.compute;

import com.databricks.sdk.support.Generated;
import com.databricks.sdk.support.ToStringer;
import com.fasterxml.jackson.annotation.JsonProperty;
import java.util.Objects;

@Generated
public class AwsAttributes {
  /**
   * Availability type used for all subsequent nodes past the `first_on_demand` ones.
   *
   * 

Note: If `first_on_demand` is zero, this availability type will be used for the entire * cluster. */ @JsonProperty("availability") private AwsAvailability availability; /** * The number of volumes launched for each instance. Users can choose up to 10 volumes. This * feature is only enabled for supported node types. Legacy node types cannot specify custom EBS * volumes. For node types with no instance store, at least one EBS volume needs to be specified; * otherwise, cluster creation will fail. * *

These EBS volumes will be mounted at `/ebs0`, `/ebs1`, and etc. Instance store volumes will * be mounted at `/local_disk0`, `/local_disk1`, and etc. * *

If EBS volumes are attached, Databricks will configure Spark to use only the EBS volumes for * scratch storage because heterogenously sized scratch devices can lead to inefficient disk * utilization. If no EBS volumes are attached, Databricks will configure Spark to use instance * store volumes. * *

Please note that if EBS volumes are specified, then the Spark configuration * `spark.local.dir` will be overridden. */ @JsonProperty("ebs_volume_count") private Long ebsVolumeCount; /** */ @JsonProperty("ebs_volume_iops") private Long ebsVolumeIops; /** * The size of each EBS volume (in GiB) launched for each instance. For general purpose SSD, this * value must be within the range 100 - 4096. For throughput optimized HDD, this value must be * within the range 500 - 4096. */ @JsonProperty("ebs_volume_size") private Long ebsVolumeSize; /** */ @JsonProperty("ebs_volume_throughput") private Long ebsVolumeThroughput; /** The type of EBS volumes that will be launched with this cluster. */ @JsonProperty("ebs_volume_type") private EbsVolumeType ebsVolumeType; /** * The first `first_on_demand` nodes of the cluster will be placed on on-demand instances. If this * value is greater than 0, the cluster driver node in particular will be placed on an on-demand * instance. If this value is greater than or equal to the current cluster size, all nodes will be * placed on on-demand instances. If this value is less than the current cluster size, * `first_on_demand` nodes will be placed on on-demand instances and the remainder will be placed * on `availability` instances. Note that this value does not affect cluster size and cannot * currently be mutated over the lifetime of a cluster. */ @JsonProperty("first_on_demand") private Long firstOnDemand; /** * Nodes for this cluster will only be placed on AWS instances with this instance profile. If * ommitted, nodes will be placed on instances without an IAM instance profile. The instance * profile must have previously been added to the Databricks environment by an account * administrator. * *

This feature may only be available to certain customer plans. * *

If this field is ommitted, we will pull in the default from the conf if it exists. */ @JsonProperty("instance_profile_arn") private String instanceProfileArn; /** * The bid price for AWS spot instances, as a percentage of the corresponding instance type's * on-demand price. For example, if this field is set to 50, and the cluster needs a new * `r3.xlarge` spot instance, then the bid price is half of the price of on-demand `r3.xlarge` * instances. Similarly, if this field is set to 200, the bid price is twice the price of * on-demand `r3.xlarge` instances. If not specified, the default value is 100. When spot * instances are requested for this cluster, only spot instances whose bid price percentage * matches this field will be considered. Note that, for safety, we enforce this field to be no * more than 10000. * *

The default value and documentation here should be kept consistent with * CommonConf.defaultSpotBidPricePercent and CommonConf.maxSpotBidPricePercent. */ @JsonProperty("spot_bid_price_percent") private Long spotBidPricePercent; /** * Identifier for the availability zone/datacenter in which the cluster resides. This string will * be of a form like "us-west-2a". The provided availability zone must be in the same region as * the Databricks deployment. For example, "us-west-2a" is not a valid zone id if the Databricks * deployment resides in the "us-east-1" region. This is an optional field at cluster creation, * and if not specified, a default zone will be used. If the zone specified is "auto", will try to * place cluster in a zone with high availability, and will retry placement in a different AZ if * there is not enough capacity. The list of available zones as well as the default value can be * found by using the `List Zones` method. */ @JsonProperty("zone_id") private String zoneId; public AwsAttributes setAvailability(AwsAvailability availability) { this.availability = availability; return this; } public AwsAvailability getAvailability() { return availability; } public AwsAttributes setEbsVolumeCount(Long ebsVolumeCount) { this.ebsVolumeCount = ebsVolumeCount; return this; } public Long getEbsVolumeCount() { return ebsVolumeCount; } public AwsAttributes setEbsVolumeIops(Long ebsVolumeIops) { this.ebsVolumeIops = ebsVolumeIops; return this; } public Long getEbsVolumeIops() { return ebsVolumeIops; } public AwsAttributes setEbsVolumeSize(Long ebsVolumeSize) { this.ebsVolumeSize = ebsVolumeSize; return this; } public Long getEbsVolumeSize() { return ebsVolumeSize; } public AwsAttributes setEbsVolumeThroughput(Long ebsVolumeThroughput) { this.ebsVolumeThroughput = ebsVolumeThroughput; return this; } public Long getEbsVolumeThroughput() { return ebsVolumeThroughput; } public AwsAttributes setEbsVolumeType(EbsVolumeType ebsVolumeType) { this.ebsVolumeType = ebsVolumeType; return this; } public EbsVolumeType getEbsVolumeType() { return ebsVolumeType; } public AwsAttributes setFirstOnDemand(Long firstOnDemand) { this.firstOnDemand = firstOnDemand; return this; } public Long getFirstOnDemand() { return firstOnDemand; } public AwsAttributes setInstanceProfileArn(String instanceProfileArn) { this.instanceProfileArn = instanceProfileArn; return this; } public String getInstanceProfileArn() { return instanceProfileArn; } public AwsAttributes setSpotBidPricePercent(Long spotBidPricePercent) { this.spotBidPricePercent = spotBidPricePercent; return this; } public Long getSpotBidPricePercent() { return spotBidPricePercent; } public AwsAttributes setZoneId(String zoneId) { this.zoneId = zoneId; return this; } public String getZoneId() { return zoneId; } @Override public boolean equals(Object o) { if (this == o) return true; if (o == null || getClass() != o.getClass()) return false; AwsAttributes that = (AwsAttributes) o; return Objects.equals(availability, that.availability) && Objects.equals(ebsVolumeCount, that.ebsVolumeCount) && Objects.equals(ebsVolumeIops, that.ebsVolumeIops) && Objects.equals(ebsVolumeSize, that.ebsVolumeSize) && Objects.equals(ebsVolumeThroughput, that.ebsVolumeThroughput) && Objects.equals(ebsVolumeType, that.ebsVolumeType) && Objects.equals(firstOnDemand, that.firstOnDemand) && Objects.equals(instanceProfileArn, that.instanceProfileArn) && Objects.equals(spotBidPricePercent, that.spotBidPricePercent) && Objects.equals(zoneId, that.zoneId); } @Override public int hashCode() { return Objects.hash( availability, ebsVolumeCount, ebsVolumeIops, ebsVolumeSize, ebsVolumeThroughput, ebsVolumeType, firstOnDemand, instanceProfileArn, spotBidPricePercent, zoneId); } @Override public String toString() { return new ToStringer(AwsAttributes.class) .add("availability", availability) .add("ebsVolumeCount", ebsVolumeCount) .add("ebsVolumeIops", ebsVolumeIops) .add("ebsVolumeSize", ebsVolumeSize) .add("ebsVolumeThroughput", ebsVolumeThroughput) .add("ebsVolumeType", ebsVolumeType) .add("firstOnDemand", firstOnDemand) .add("instanceProfileArn", instanceProfileArn) .add("spotBidPricePercent", spotBidPricePercent) .add("zoneId", zoneId) .toString(); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy