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

com.edmunds.rest.databricks.service.ClusterService Maven / Gradle / Ivy

/*
 * Copyright 2018 Edmunds.com, Inc.
 *
 *    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.
 */

package com.edmunds.rest.databricks.service;

import com.edmunds.rest.databricks.DTO.UpsertClusterDTO;
import com.edmunds.rest.databricks.DTO.clusters.AutoScaleDTO;
import com.edmunds.rest.databricks.DTO.clusters.ClusterEventDTO;
import com.edmunds.rest.databricks.DTO.clusters.ClusterEventTypeDTO;
import com.edmunds.rest.databricks.DTO.clusters.ClusterInfoDTO;
import com.edmunds.rest.databricks.DTO.clusters.NodeTypeDTO;
import com.edmunds.rest.databricks.DTO.clusters.SparkVersionDTO;
import com.edmunds.rest.databricks.DTO.jobs.NewClusterDTO;
import com.edmunds.rest.databricks.DatabricksRestException;
import com.edmunds.rest.databricks.request.CreateClusterRequest;
import com.edmunds.rest.databricks.request.EditClusterRequest;
import java.io.IOException;
import java.util.List;
import java.util.Optional;

/**
 * A Wrapper around the cluster part of the databricks rest api.
 *
 * @see https://docs.databricks.com/api/latest/clusters.html
 */
public interface ClusterService {

  /**
   * Creates a databricks cluster.
   * @deprecated in version 2.3.2, please use {@link ClusterService#create(NewClusterDTO)}
   * @see https://docs.databricks.com/api/latest/clusters.html#create
   * @param createClusterRequest the cluster request object
   * @return the clusterId
   * @throws IOException other connection errors
   * @throws DatabricksRestException any errors with the request
   */
  @Deprecated
  String create(CreateClusterRequest createClusterRequest) throws IOException, DatabricksRestException;

  /**
   * Creates a databricks cluster.
   * @see https://docs.databricks.com/api/latest/clusters.html#create
   * @param clusterDTO cluster DTO
   * @return the clusterId
   * @throws IOException other connection errors
   * @throws DatabricksRestException any errors with the request
   */
  String create(NewClusterDTO clusterDTO) throws IOException, DatabricksRestException;

  /**
   * Edits the configurations of a databricks cluster.
   * @deprecated in version 2.3.2, please use {@link ClusterService#edit(UpsertClusterDTO)}
   * @see https://docs.databricks.com/api/latest/clusters.html#edit
   * @param editClusterRequest the edit cluster request object
   * @throws IOException any other errors
   * @throws DatabricksRestException any errors with the request
   */
  @Deprecated
  void edit(EditClusterRequest editClusterRequest) throws IOException, DatabricksRestException;

  /**
   * Edits the configurations of a databricks cluster.
   * @see https://docs.databricks.com/api/latest/clusters.html#edit
   * @param clusterDTO cluster DTO
   * @throws IOException any other errors
   * @throws DatabricksRestException any errors with the request
   */
  void edit(UpsertClusterDTO clusterDTO) throws IOException, DatabricksRestException;

  /**
   * Starts a databricks cluster.
   * @see https://docs.databricks.com/api/latest/clusters.html#start
   * @param clusterId the clusterId of the cluster you want to start.
   * @throws IOException any other errors
   * @throws DatabricksRestException any errors with the request
   */
  void start(String clusterId) throws IOException, DatabricksRestException;

  /**
   * Returns true if the cluster is running.
   * @param clusterId the clusterId to check.
   * @return true if the cluster is running.
   * @throws IOException any other errors
   * @throws DatabricksRestException any errors with the request
   */
  boolean isClusterRunning(String clusterId) throws IOException, DatabricksRestException;

  /**
   * Restarts a given databricks cluster.
   * @see https://docs.databricks.com/api/latest/clusters.html#restart
   * @param clusterId the clusterid of the cluster you want to restart.
   * @throws IOException any other errors
   * @throws DatabricksRestException any errors with the request
   */
  void restart(String clusterId) throws IOException, DatabricksRestException;

  /**
   * Resizes a cluster. Will give it a fixed number of workers.
   * @see https://docs.databricks.com/api/latest/clusters.html#resize
   * @param numWorkers the number of workers you want to resize to
   * @param clusterId the clusterId you want to operate on
   * @throws IOException any other errors
   * @throws DatabricksRestException any errors with request
   */
  void resize(int numWorkers, String clusterId) throws IOException, DatabricksRestException;

  /**
   * Resizes a cluster. Will add/edit autoscale functionality.
   * @see https://docs.databricks.com/api/latest/clusters.html#resize
   * @param autoscale the autoscale specs.
   * @param clusterId the clusterId you want to work on
   * @throws IOException any other errors
   * @throws DatabricksRestException any errors with request
   */
  void resize(AutoScaleDTO autoscale, String clusterId) throws IOException, DatabricksRestException;

  /**
   * Terminates a cluster.
   * @see https://docs.databricks.com/api/latest/clusters.html#delete-terminate
   * @param clusterId the cluster you want to terminate
   * @throws IOException any other errors
   * @throws DatabricksRestException errors with request
   */
  void delete(String clusterId) throws IOException, DatabricksRestException;

  /**
   * Permanently terminates a cluster.
   * @see https://docs.databricks.com/api/latest/clusters.html#permanent-delete
   * @param clusterId the cluster you want to permanently terminate
   * @throws IOException any other errors
   * @throws DatabricksRestException errors with request
   */
  void permanentDelete(String clusterId) throws IOException, DatabricksRestException;

  /**
   * Gets information about a given cluster.
   * @see https://docs.databricks.com/api/latest/clusters.html#get
   * @param clusterId the cluster you want to get info about
   * @return the information DTO object
   * @throws IOException any other errors.
   * @throws DatabricksRestException any errors with the request
   */
  ClusterInfoDTO getInfo(String clusterId) throws IOException, DatabricksRestException;

  /**
   * Lists all of the clusters on a given databricks instance.
   * @see https://docs.databricks.com/api/latest/clusters.html#list
   * @return an array of cluster information objects
   * @throws IOException any other errors
   * @throws DatabricksRestException any errors with the request
   */
  ClusterInfoDTO[] list() throws IOException, DatabricksRestException;

  /**
   * Lists events of a specific cluster on a given databricks instance.
   * Allows you to filter which events you want to see too.
   * @see https://docs.databricks.com/api/latest/clusters.html#events
   * @return an array of cluster events objects
   * @throws IOException any other errors
   * @throws DatabricksRestException any errors with the request
   */
  List listEvents(String clusterId, ClusterEventTypeDTO[] eventsToFilter,
      int offset, int limit) throws IOException,
      DatabricksRestException;

  /**
   * Given a cluster settings DTO object it will:
   * - create the cluster if it doesn't exist
   * - edit the cluster if it does exist.
   * Uses a combination of
   * If cluster doesn't exist:
   * @see https://docs.databricks.com/api/latest/clusters.html#create
   * If cluster exists:
   * @see https://docs.databricks.com/api/latest/clusters.html#edit
   * @param clusterDTO cluster DTO
   */
  void upsertCluster(NewClusterDTO clusterDTO) throws IOException, DatabricksRestException;

  /**
   * Look for clusters with a given name.
   * @see https://docs.databricks.com/api/latest/clusters.html#findByName
   * @param clusterName name to look for
   * @return a list of cluster information objects
   * @throws IOException any other errors
   * @throws DatabricksRestException any errors with the request
   */
  List findByName(String clusterName) throws IOException, DatabricksRestException;

  /**
   * Same as findByName, but it will throw an exception if more then one cluster has the name.
   *
   * @param clusterName name to look for
   * @return a cluster if only one was found
   * @throws IOException any other errors
   * @throws DatabricksRestException any errors with the request,
   *            including if more then 1 cluster was found with the name.
   * @see https://docs.databricks.com/api/latest/clusters.html#findByName
   */
  Optional findUniqueByName(String clusterName)
      throws IOException, DatabricksRestException;

  /**
   * Pin a cluster with a given id. Needs administrator rights.
   * @see https://docs.databricks.com/api/latest/clusters.html#pin
   * @param clusterId the clusterId you want to pin
   * @throws IOException any other errors
   * @throws DatabricksRestException any errors with the request
   */
  void pin(String clusterId) throws IOException, DatabricksRestException;

  /**
   * Unpin a cluster with a given id. Needs administrator rights.
   * @see https://docs.databricks.com/api/latest/clusters.html#unpin
   * @param clusterId the clusterId you want to unpin
   * @throws IOException any other errors
   * @throws DatabricksRestException any errors with the request
   */
  void unpin(String clusterId) throws IOException, DatabricksRestException;

  /**
   * Return a list of supported Spark node types.
   * @see https://docs.databricks.com/api/latest/clusters.html#list-node-types
   * @return an array of node types
   * @throws IOException any other errors
   * @throws DatabricksRestException any errors with the request
   */
  List listNodeTypes() throws IOException, DatabricksRestException;

  /**
   * Return a list of availability zones where clusters can be created in. This method only works on AWS.
   * @see https://docs.databricks.com/api/latest/clusters.html#list-zones
   * @return the a list of availability zones
   * @throws IOException any other errors
   * @throws DatabricksRestException any errors with the request
   */
  List listZones() throws IOException, DatabricksRestException;

  /**
   * Return the list of available runtime versions.
   * @see https://docs.databricks.com/api/latest/clusters.html#spark-versions
   * @return the a list of runtime versions
   * @throws IOException any other errors
   * @throws DatabricksRestException any errors with the request
   */
  List listSparkVersions() throws IOException, DatabricksRestException;


}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy