โ04-15-2025 09:13 PM
Hi everyone,
I'm exploring ways to streamline my workflow in Databricks and could really use some expert advice. In my current setup, I have a job (named job_silver) with multiple tasks (e.g., task 1, task 2, task 3). When one of these tasks failsโsay task 2โI want the ability to restart just that specific task without rerunning the entire job.
I did some research and came across the โRepair and Rerunโ feature (Databricks Blog). While that's a great tool for saving time and money in data and ML workflows, my use case requires more flexibility. Specifically, I'm looking for an API-based solution that I can integrate into my code, allowing dynamic control over which task to restart based on custom logic.
Some points Iโm particularly interested in:
Is there an existing API (or a combination of APIs) that allows for restarting individual tasks within a job?
Could this be done via the REST API, and if so, what endpoints or methods should I look at?
Are there any workarounds or best practices for implementing this functionality if a dedicated API is not available?
How might this approach scale in environments with a large number of jobs and complex dependency graphs?
Iโd love to hear about your experiences and any code snippets or documentation pointers that could help me get started. Thanks in advance for your insights!
โ04-15-2025 09:27 PM
use retry job or task option it is available bottom right side of the job or task plane
โ04-15-2025 09:39 PM
Hi @Aviral-Bhardwaj ,
Thanks for your suggestion. But I really need is a code/API-driven approach rather than having to click around in the UI to manage a specific task in a job retry.
โ04-15-2025 09:41 PM
โ04-15-2025 09:53 PM
Thank you so much for sharing that information. After reviewing the /api/2.2/jobs/reset API documentation, it looks like this endpoint is designed for updating the entire job configuration for future runs and doesnโt support restarting only the failed tasks of an active job run.
I appreciate your help, and if you have any other suggestions or ideas on achieving that level of granularity, I'd be happy to hear them.
โ04-16-2025 01:17 AM - edited โ04-16-2025 01:20 AM
Please check if the below code using rest api is able to cater to your needs.
โ04-16-2025 07:40 AM
โ04-16-2025 07:44 PM
Sure, we will try again based on the solution you provided and will feedback to you whether it works or not. Thank you very much.
โ04-16-2025 08:45 PM
Hi @RiyazAliM , after applying your code to the pipeline it seems that it can't work because of the following error:
400 --- {"error_code":"INVALID_PARAMETER_VALUE","message":"One of job_cluster_key, new_cluster, or existing_cluster_id must be specified. Serverless compute for workflows is not enabled in the workspace.","details":[{"@type":"type.googleapis.com/google.rpc.RequestInfo","request_id":"74ef6feb-9cff-4d3d-8cb6-3f45f3525768","serving_data":""}]}
Could you plese help us investigate this error?
โ04-16-2025 10:43 PM
Hey @minhhung0507 - quick question - what is the cluster type you're using to run your workflow?
I'm using a shared, interactive cluster, so I'm passing the parameter
{'existing_cluster_id' : task['existing_cluster_id']}in the payload. This parameter will change if you're using a job_cluster, I'd have to check what it's gonna be for serveless though.
Hope it helps.
Cheers!
โ04-17-2025 02:25 AM
Hi @RiyazAliM ,
Thanks for showing how to pass the existing_cluster_id in the payload. One thing Iโm worried about from a production standpoint is what happens if the ID we supply doesnโt correspond to an active clusterโwill Databricks automatically spin up a new cluster under the hood, or will the run fail immediately?
Autoโprovisioning clusters without explicit control could lead to unwanted resource sprawl and cost overruns. Could you please clarify the behavior of the Submit Run API when existing_cluster_id canโt be resolved, and recommend best practices to ensure we only target known, managed clusters?
โ04-21-2025 01:07 AM
The trigger won't be successful if the cluster-id is not provided. I tried to replicate it and found that it throws an error as below:
{"error_code":"INVALID_PARAMETER_VALUE","message":"Missing required fields: settings.job_clusters.job_cluster_key, settings.job_clusters.new_cluster","details":[{"@type":"type.googleapis.com/google.rpc.RequestInfo","request_id":"b9631652-3101-4b69-95a6-45be477c85a5","serving_data":""}]}
โ04-17-2025 04:09 AM
@RiyazAliM FYI
@RiyazAliM FYI:
400 --- {"error_code":"INVALID_PARAMETER_VALUE","message":"The cluster 0417-102632-cuhsyfm0 is not an all-purpose cluster. existing_cluster_id only supports all-purpose cluster IDs.","details":[{"@type":"type.googleapis.com/google.rpc.RequestInfo","request_id":"3379c0ea-0fc0-405a-808c-7f06759aad83","serving_data":""}]}
โ04-21-2025 01:10 AM
The error depicts that you've passed job_cluster id with the key as existing_cluster_id which is used for interactive clusters. Please pass job_cluster_details if you're using the key `
โ04-21-2025 01:50 AM
Hi @RiyazAliM ,
I have two quick questions Iโd appreciate your help with:
Why do we need to use an interactive (allโpurpose) cluster when submitting a job, rather than a job cluster?
I canโt find any reference to a parameter called job_cluster_details in the official docsโcould you point me to where itโs documented or share a link?
Thanks in advance for any pointers!
 
					
				
				
			
		
 
					
				
				
			
		
Passionate about hosting events and connecting people? Help us grow a vibrant local communityโsign up today to get started!
Sign Up Now