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

com.databricks.sdk.service.jobs.JobsAPI 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.jobs;

import com.databricks.sdk.core.ApiClient;
import com.databricks.sdk.support.Generated;
import com.databricks.sdk.support.Paginator;
import com.databricks.sdk.support.Wait;
import java.time.Duration;
import java.util.Arrays;
import java.util.concurrent.TimeoutException;
import java.util.function.Consumer;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
 * The Jobs API allows you to create, edit, and delete jobs.
 *
 * 

You can use a Databricks job to run a data processing or data analysis task in a Databricks * cluster with scalable resources. Your job can consist of a single task or can be a large, * multi-task workflow with complex dependencies. Databricks manages the task orchestration, cluster * management, monitoring, and error reporting for all of your jobs. You can run your jobs * immediately or periodically through an easy-to-use scheduling system. You can implement job tasks * using notebooks, JARS, Delta Live Tables pipelines, or Python, Scala, Spark submit, and Java * applications. * *

You should never hard code secrets or store them in plain text. Use the [Secrets CLI] to * manage secrets in the [Databricks CLI]. Use the [Secrets utility] to reference secrets in * notebooks and jobs. * *

[Databricks CLI]: https://docs.databricks.com/dev-tools/cli/index.html [Secrets CLI]: * https://docs.databricks.com/dev-tools/cli/secrets-cli.html [Secrets utility]: * https://docs.databricks.com/dev-tools/databricks-utils.html#dbutils-secrets */ @Generated public class JobsAPI { private static final Logger LOG = LoggerFactory.getLogger(JobsAPI.class); private final JobsService impl; /** Regular-use constructor */ public JobsAPI(ApiClient apiClient) { impl = new JobsImpl(apiClient); } /** Constructor for mocks */ public JobsAPI(JobsService mock) { impl = mock; } public Run waitGetRunJobTerminatedOrSkipped(Long runId) throws TimeoutException { return waitGetRunJobTerminatedOrSkipped(runId, Duration.ofMinutes(20), null); } public Run waitGetRunJobTerminatedOrSkipped(Long runId, Duration timeout, Consumer callback) throws TimeoutException { long deadline = System.currentTimeMillis() + timeout.toMillis(); java.util.List targetStates = Arrays.asList(RunLifeCycleState.TERMINATED, RunLifeCycleState.SKIPPED); java.util.List failureStates = Arrays.asList(RunLifeCycleState.INTERNAL_ERROR); String statusMessage = "polling..."; int attempt = 1; while (System.currentTimeMillis() < deadline) { Run poll = getRun(new GetRunRequest().setRunId(runId)); RunLifeCycleState status = poll.getState().getLifeCycleState(); statusMessage = String.format("current status: %s", status); if (poll.getState() != null) { statusMessage = poll.getState().getStateMessage(); } if (targetStates.contains(status)) { return poll; } if (callback != null) { callback.accept(poll); } if (failureStates.contains(status)) { String msg = String.format( "failed to reach TERMINATED or SKIPPED, got %s: %s", status, statusMessage); throw new IllegalStateException(msg); } String prefix = String.format("runId=%s", runId); int sleep = attempt; if (sleep > 10) { // sleep 10s max per attempt sleep = 10; } LOG.info("{}: ({}) {} (sleeping ~{}s)", prefix, status, statusMessage, sleep); try { Thread.sleep((long) (sleep * 1000L + Math.random() * 1000)); } catch (InterruptedException e) { Thread.currentThread().interrupt(); } attempt++; } throw new TimeoutException(String.format("timed out after %s: %s", timeout, statusMessage)); } /** * Cancel all runs of a job. * *

Cancels all active runs of a job. The runs are canceled asynchronously, so it doesn't * prevent new runs from being started. */ public void cancelAllRuns(CancelAllRuns request) { impl.cancelAllRuns(request); } public Wait cancelRun(long runId) { return cancelRun(new CancelRun().setRunId(runId)); } /** * Cancel a run. * *

Cancels a job run or a task run. The run is canceled asynchronously, so it may still be * running when this request completes. */ public Wait cancelRun(CancelRun request) { impl.cancelRun(request); return new Wait<>( (timeout, callback) -> waitGetRunJobTerminatedOrSkipped(request.getRunId(), timeout, callback)); } /** * Create a new job. * *

Create a new job. */ public CreateResponse create(CreateJob request) { return impl.create(request); } public void delete(long jobId) { delete(new DeleteJob().setJobId(jobId)); } /** * Delete a job. * *

Deletes a job. */ public void delete(DeleteJob request) { impl.delete(request); } public void deleteRun(long runId) { deleteRun(new DeleteRun().setRunId(runId)); } /** * Delete a job run. * *

Deletes a non-active run. Returns an error if the run is active. */ public void deleteRun(DeleteRun request) { impl.deleteRun(request); } public ExportRunOutput exportRun(long runId) { return exportRun(new ExportRunRequest().setRunId(runId)); } /** * Export and retrieve a job run. * *

Export and retrieve the job run task. */ public ExportRunOutput exportRun(ExportRunRequest request) { return impl.exportRun(request); } public Job get(long jobId) { return get(new GetJobRequest().setJobId(jobId)); } /** * Get a single job. * *

Retrieves the details for a single job. */ public Job get(GetJobRequest request) { return impl.get(request); } public GetJobPermissionLevelsResponse getPermissionLevels(String jobId) { return getPermissionLevels(new GetJobPermissionLevelsRequest().setJobId(jobId)); } /** * Get job permission levels. * *

Gets the permission levels that a user can have on an object. */ public GetJobPermissionLevelsResponse getPermissionLevels(GetJobPermissionLevelsRequest request) { return impl.getPermissionLevels(request); } public JobPermissions getPermissions(String jobId) { return getPermissions(new GetJobPermissionsRequest().setJobId(jobId)); } /** * Get job permissions. * *

Gets the permissions of a job. Jobs can inherit permissions from their root object. */ public JobPermissions getPermissions(GetJobPermissionsRequest request) { return impl.getPermissions(request); } public Run getRun(long runId) { return getRun(new GetRunRequest().setRunId(runId)); } /** * Get a single job run. * *

Retrieve the metadata of a run. */ public Run getRun(GetRunRequest request) { return impl.getRun(request); } public RunOutput getRunOutput(long runId) { return getRunOutput(new GetRunOutputRequest().setRunId(runId)); } /** * Get the output for a single run. * *

Retrieve the output and metadata of a single task run. When a notebook task returns a value * through the `dbutils.notebook.exit()` call, you can use this endpoint to retrieve that value. * Databricks restricts this API to returning the first 5 MB of the output. To return a larger * result, you can store job results in a cloud storage service. * *

This endpoint validates that the __run_id__ parameter is valid and returns an HTTP status * code 400 if the __run_id__ parameter is invalid. Runs are automatically removed after 60 days. * If you to want to reference them beyond 60 days, you must save old run results before they * expire. */ public RunOutput getRunOutput(GetRunOutputRequest request) { return impl.getRunOutput(request); } /** * List jobs. * *

Retrieves a list of jobs. */ public Iterable list(ListJobsRequest request) { return new Paginator<>( request, impl::list, ListJobsResponse::getJobs, response -> { String token = response.getNextPageToken(); if (token == null) { return null; } return request.setPageToken(token); }); } /** * List job runs. * *

List runs in descending order by start time. */ public Iterable listRuns(ListRunsRequest request) { return new Paginator<>( request, impl::listRuns, ListRunsResponse::getRuns, response -> { String token = response.getNextPageToken(); if (token == null) { return null; } return request.setPageToken(token); }); } public Wait repairRun(long runId) { return repairRun(new RepairRun().setRunId(runId)); } /** * Repair a job run. * *

Re-run one or more tasks. Tasks are re-run as part of the original job run. They use the * current job and task settings, and can be viewed in the history for the original job run. */ public Wait repairRun(RepairRun request) { RepairRunResponse response = impl.repairRun(request); return new Wait<>( (timeout, callback) -> waitGetRunJobTerminatedOrSkipped(request.getRunId(), timeout, callback), response); } public void reset(long jobId, JobSettings newSettings) { reset(new ResetJob().setJobId(jobId).setNewSettings(newSettings)); } /** * Update all job settings (reset). * *

Overwrite all settings for the given job. Use the [_Update_ endpoint](:method:jobs/update) * to update job settings partially. */ public void reset(ResetJob request) { impl.reset(request); } public Wait runNow(long jobId) { return runNow(new RunNow().setJobId(jobId)); } /** * Trigger a new job run. * *

Run a job and return the `run_id` of the triggered run. */ public Wait runNow(RunNow request) { RunNowResponse response = impl.runNow(request); return new Wait<>( (timeout, callback) -> waitGetRunJobTerminatedOrSkipped(response.getRunId(), timeout, callback), response); } public JobPermissions setPermissions(String jobId) { return setPermissions(new JobPermissionsRequest().setJobId(jobId)); } /** * Set job permissions. * *

Sets permissions on a job. Jobs can inherit permissions from their root object. */ public JobPermissions setPermissions(JobPermissionsRequest request) { return impl.setPermissions(request); } /** * Create and trigger a one-time run. * *

Submit a one-time run. This endpoint allows you to submit a workload directly without * creating a job. Runs submitted using this endpoint don’t display in the UI. Use the * `jobs/runs/get` API to check the run state after the job is submitted. */ public Wait submit(SubmitRun request) { SubmitRunResponse response = impl.submit(request); return new Wait<>( (timeout, callback) -> waitGetRunJobTerminatedOrSkipped(response.getRunId(), timeout, callback), response); } public void update(long jobId) { update(new UpdateJob().setJobId(jobId)); } /** * Update job settings partially. * *

Add, update, or remove specific settings of an existing job. Use the [_Reset_ * endpoint](:method:jobs/reset) to overwrite all job settings. */ public void update(UpdateJob request) { impl.update(request); } public JobPermissions updatePermissions(String jobId) { return updatePermissions(new JobPermissionsRequest().setJobId(jobId)); } /** * Update job permissions. * *

Updates the permissions on a job. Jobs can inherit permissions from their root object. */ public JobPermissions updatePermissions(JobPermissionsRequest request) { return impl.updatePermissions(request); } public JobsService impl() { return impl; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy