com.databricks.sdk.service.compute.ClustersService Maven / Gradle / Ivy
// Code generated from OpenAPI specs by Databricks SDK Generator. DO NOT EDIT.
package com.databricks.sdk.service.compute;
import com.databricks.sdk.support.Generated;
/**
* The Clusters API allows you to create, start, edit, list, terminate, and delete clusters.
*
* Databricks maps cluster node instance types to compute units known as DBUs. See the instance
* type pricing page for a list of the supported instance types and their corresponding DBUs.
*
*
A Databricks cluster is a set of computation resources and configurations on which you run
* data engineering, data science, and data analytics workloads, such as production ETL pipelines,
* streaming analytics, ad-hoc analytics, and machine learning.
*
*
You run these workloads as a set of commands in a notebook or as an automated job. Databricks
* makes a distinction between all-purpose clusters and job clusters. You use all-purpose clusters
* to analyze data collaboratively using interactive notebooks. You use job clusters to run fast and
* robust automated jobs.
*
*
You can create an all-purpose cluster using the UI, CLI, or REST API. You can manually
* terminate and restart an all-purpose cluster. Multiple users can share such clusters to do
* collaborative interactive analysis.
*
*
IMPORTANT: Databricks retains cluster configuration information for up to 200 all-purpose
* clusters terminated in the last 30 days and up to 30 job clusters recently terminated by the job
* scheduler. To keep an all-purpose cluster configuration even after it has been terminated for
* more than 30 days, an administrator can pin a cluster to the cluster list.
*
*
This is the high-level interface, that contains generated methods.
*
*
Evolving: this interface is under development. Method signatures may change.
*/
@Generated
public interface ClustersService {
/**
* Change cluster owner.
*
*
Change the owner of the cluster. You must be an admin and the cluster must be terminated to
* perform this operation. The service principal application ID can be supplied as an argument to
* `owner_username`.
*/
void changeOwner(ChangeClusterOwner changeClusterOwner);
/**
* Create new cluster.
*
*
Creates a new Spark cluster. This method will acquire new instances from the cloud provider
* if necessary. Note: Databricks may not be able to acquire some of the requested nodes, due to
* cloud provider limitations (account limits, spot price, etc.) or transient network issues.
*
*
If Databricks acquires at least 85% of the requested on-demand nodes, cluster creation will
* succeed. Otherwise the cluster will terminate with an informative error message.
*/
CreateClusterResponse create(CreateCluster createCluster);
/**
* Terminate cluster.
*
*
Terminates the Spark cluster with the specified ID. The cluster is removed asynchronously.
* Once the termination has completed, the cluster will be in a `TERMINATED` state. If the cluster
* is already in a `TERMINATING` or `TERMINATED` state, nothing will happen.
*/
void delete(DeleteCluster deleteCluster);
/**
* Update cluster configuration.
*
*
Updates the configuration of a cluster to match the provided attributes and size. A cluster
* can be updated if it is in a `RUNNING` or `TERMINATED` state.
*
*
If a cluster is updated while in a `RUNNING` state, it will be restarted so that the new
* attributes can take effect.
*
*
If a cluster is updated while in a `TERMINATED` state, it will remain `TERMINATED`. The next
* time it is started using the `clusters/start` API, the new attributes will take effect. Any
* attempt to update a cluster in any other state will be rejected with an `INVALID_STATE` error
* code.
*
*
Clusters created by the Databricks Jobs service cannot be edited.
*/
void edit(EditCluster editCluster);
/**
* List cluster activity events.
*
*
Retrieves a list of events about the activity of a cluster. This API is paginated. If there
* are more events to read, the response includes all the nparameters necessary to request the
* next page of events.
*/
GetEventsResponse events(GetEvents getEvents);
/**
* Get cluster info.
*
*
Retrieves the information for a cluster given its identifier. Clusters can be described
* while they are running, or up to 60 days after they are terminated.
*/
ClusterDetails get(GetClusterRequest getClusterRequest);
/**
* Get cluster permission levels.
*
*
Gets the permission levels that a user can have on an object.
*/
GetClusterPermissionLevelsResponse getPermissionLevels(
GetClusterPermissionLevelsRequest getClusterPermissionLevelsRequest);
/**
* Get cluster permissions.
*
*
Gets the permissions of a cluster. Clusters can inherit permissions from their root object.
*/
ClusterPermissions getPermissions(GetClusterPermissionsRequest getClusterPermissionsRequest);
/**
* List all clusters.
*
*
Return information about all pinned clusters, active clusters, up to 200 of the most
* recently terminated all-purpose clusters in the past 30 days, and up to 30 of the most recently
* terminated job clusters in the past 30 days.
*
*
For example, if there is 1 pinned cluster, 4 active clusters, 45 terminated all-purpose
* clusters in the past 30 days, and 50 terminated job clusters in the past 30 days, then this API
* returns the 1 pinned cluster, 4 active clusters, all 45 terminated all-purpose clusters, and
* the 30 most recently terminated job clusters.
*/
ListClustersResponse list(ListClustersRequest listClustersRequest);
/**
* List node types.
*
*
Returns a list of supported Spark node types. These node types can be used to launch a
* cluster.
*/
ListNodeTypesResponse listNodeTypes();
/**
* List availability zones.
*
*
Returns a list of availability zones where clusters can be created in (For example,
* us-west-2a). These zones can be used to launch a cluster.
*/
ListAvailableZonesResponse listZones();
/**
* Permanently delete cluster.
*
*
Permanently deletes a Spark cluster. This cluster is terminated and resources are
* asynchronously removed.
*
*
In addition, users will no longer see permanently deleted clusters in the cluster list, and
* API users can no longer perform any action on permanently deleted clusters.
*/
void permanentDelete(PermanentDeleteCluster permanentDeleteCluster);
/**
* Pin cluster.
*
*
Pinning a cluster ensures that the cluster will always be returned by the ListClusters API.
* Pinning a cluster that is already pinned will have no effect. This API can only be called by
* workspace admins.
*/
void pin(PinCluster pinCluster);
/**
* Resize cluster.
*
*
Resizes a cluster to have a desired number of workers. This will fail unless the cluster is
* in a `RUNNING` state.
*/
void resize(ResizeCluster resizeCluster);
/**
* Restart cluster.
*
*
Restarts a Spark cluster with the supplied ID. If the cluster is not currently in a
* `RUNNING` state, nothing will happen.
*/
void restart(RestartCluster restartCluster);
/**
* Set cluster permissions.
*
*
Sets permissions on a cluster. Clusters can inherit permissions from their root object.
*/
ClusterPermissions setPermissions(ClusterPermissionsRequest clusterPermissionsRequest);
/**
* List available Spark versions.
*
*
Returns the list of available Spark versions. These versions can be used to launch a
* cluster.
*/
GetSparkVersionsResponse sparkVersions();
/**
* Start terminated cluster.
*
*
Starts a terminated Spark cluster with the supplied ID. This works similar to
* `createCluster` except:
*
*
* The previous cluster id and attributes are preserved. * The cluster starts with the last
* specified cluster size. * If the previous cluster was an autoscaling cluster, the current
* cluster starts with the minimum number of nodes. * If the cluster is not currently in a
* `TERMINATED` state, nothing will happen. * Clusters launched to run a job cannot be started.
*/
void start(StartCluster startCluster);
/**
* Unpin cluster.
*
*
Unpinning a cluster will allow the cluster to eventually be removed from the ListClusters
* API. Unpinning a cluster that is not pinned will have no effect. This API can only be called by
* workspace admins.
*/
void unpin(UnpinCluster unpinCluster);
/**
* Update cluster permissions.
*
*
Updates the permissions on a cluster. Clusters can inherit permissions from their root
* object.
*/
ClusterPermissions updatePermissions(ClusterPermissionsRequest clusterPermissionsRequest);
}