com.databricks.sdk.service.serving.ServedEntityInput Maven / Gradle / Ivy
// Code generated from OpenAPI specs by Databricks SDK Generator. DO NOT EDIT.
package com.databricks.sdk.service.serving;
import com.databricks.sdk.support.Generated;
import com.databricks.sdk.support.ToStringer;
import com.fasterxml.jackson.annotation.JsonProperty;
import java.util.Map;
import java.util.Objects;
@Generated
public class ServedEntityInput {
/**
* The name of the entity to be served. The entity may be a model in the Databricks Model
* Registry, a model in the Unity Catalog (UC), or a function of type FEATURE_SPEC in the UC. If
* it is a UC object, the full name of the object should be given in the form of
* __catalog_name__.__schema_name__.__model_name__.
*/
@JsonProperty("entity_name")
private String entityName;
/**
* The version of the model in Databricks Model Registry to be served or empty if the entity is a
* FEATURE_SPEC.
*/
@JsonProperty("entity_version")
private String entityVersion;
/**
* An object containing a set of optional, user-specified environment variable key-value pairs
* used for serving this entity. Note: this is an experimental feature and subject to change.
* Example entity environment variables that refer to Databricks secrets: `{"OPENAI_API_KEY":
* "{{secrets/my_scope/my_key}}", "DATABRICKS_TOKEN": "{{secrets/my_scope2/my_key2}}"}`
*/
@JsonProperty("environment_vars")
private Map environmentVars;
/**
* The external model to be served. NOTE: Only one of external_model and (entity_name,
* entity_version, workload_size, workload_type, and scale_to_zero_enabled) can be specified with
* the latter set being used for custom model serving for a Databricks registered model. When an
* external_model is present, the served entities list can only have one served_entity object. For
* an existing endpoint with external_model, it can not be updated to an endpoint without
* external_model. If the endpoint is created without external_model, users cannot update it to
* add external_model later.
*/
@JsonProperty("external_model")
private ExternalModel externalModel;
/** ARN of the instance profile that the served entity uses to access AWS resources. */
@JsonProperty("instance_profile_arn")
private String instanceProfileArn;
/**
* The name of a served entity. It must be unique across an endpoint. A served entity name can
* consist of alphanumeric characters, dashes, and underscores. If not specified for an external
* model, this field defaults to external_model.name, with '.' and ':' replaced with '-', and if
* not specified for other entities, it defaults to -.
*/
@JsonProperty("name")
private String name;
/** Whether the compute resources for the served entity should scale down to zero. */
@JsonProperty("scale_to_zero_enabled")
private Boolean scaleToZeroEnabled;
/**
* The workload size of the served entity. The workload size corresponds to a range of provisioned
* concurrency that the compute autoscales between. A single unit of provisioned concurrency can
* process one request at a time. Valid workload sizes are "Small" (4 - 4 provisioned
* concurrency), "Medium" (8 - 16 provisioned concurrency), and "Large" (16 - 64 provisioned
* concurrency). If scale-to-zero is enabled, the lower bound of the provisioned concurrency for
* each workload size is 0.
*/
@JsonProperty("workload_size")
private String workloadSize;
/**
* The workload type of the served entity. The workload type selects which type of compute to use
* in the endpoint. The default value for this parameter is "CPU". For deep learning workloads,
* GPU acceleration is available by selecting workload types like GPU_SMALL and others. See the
* available [GPU types].
*
* [GPU types]:
* https://docs.databricks.com/machine-learning/model-serving/create-manage-serving-endpoints.html#gpu-workload-types
*/
@JsonProperty("workload_type")
private String workloadType;
public ServedEntityInput setEntityName(String entityName) {
this.entityName = entityName;
return this;
}
public String getEntityName() {
return entityName;
}
public ServedEntityInput setEntityVersion(String entityVersion) {
this.entityVersion = entityVersion;
return this;
}
public String getEntityVersion() {
return entityVersion;
}
public ServedEntityInput setEnvironmentVars(Map environmentVars) {
this.environmentVars = environmentVars;
return this;
}
public Map getEnvironmentVars() {
return environmentVars;
}
public ServedEntityInput setExternalModel(ExternalModel externalModel) {
this.externalModel = externalModel;
return this;
}
public ExternalModel getExternalModel() {
return externalModel;
}
public ServedEntityInput setInstanceProfileArn(String instanceProfileArn) {
this.instanceProfileArn = instanceProfileArn;
return this;
}
public String getInstanceProfileArn() {
return instanceProfileArn;
}
public ServedEntityInput setName(String name) {
this.name = name;
return this;
}
public String getName() {
return name;
}
public ServedEntityInput setScaleToZeroEnabled(Boolean scaleToZeroEnabled) {
this.scaleToZeroEnabled = scaleToZeroEnabled;
return this;
}
public Boolean getScaleToZeroEnabled() {
return scaleToZeroEnabled;
}
public ServedEntityInput setWorkloadSize(String workloadSize) {
this.workloadSize = workloadSize;
return this;
}
public String getWorkloadSize() {
return workloadSize;
}
public ServedEntityInput setWorkloadType(String workloadType) {
this.workloadType = workloadType;
return this;
}
public String getWorkloadType() {
return workloadType;
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
ServedEntityInput that = (ServedEntityInput) o;
return Objects.equals(entityName, that.entityName)
&& Objects.equals(entityVersion, that.entityVersion)
&& Objects.equals(environmentVars, that.environmentVars)
&& Objects.equals(externalModel, that.externalModel)
&& Objects.equals(instanceProfileArn, that.instanceProfileArn)
&& Objects.equals(name, that.name)
&& Objects.equals(scaleToZeroEnabled, that.scaleToZeroEnabled)
&& Objects.equals(workloadSize, that.workloadSize)
&& Objects.equals(workloadType, that.workloadType);
}
@Override
public int hashCode() {
return Objects.hash(
entityName,
entityVersion,
environmentVars,
externalModel,
instanceProfileArn,
name,
scaleToZeroEnabled,
workloadSize,
workloadType);
}
@Override
public String toString() {
return new ToStringer(ServedEntityInput.class)
.add("entityName", entityName)
.add("entityVersion", entityVersion)
.add("environmentVars", environmentVars)
.add("externalModel", externalModel)
.add("instanceProfileArn", instanceProfileArn)
.add("name", name)
.add("scaleToZeroEnabled", scaleToZeroEnabled)
.add("workloadSize", workloadSize)
.add("workloadType", workloadType)
.toString();
}
}