The marker exception thrown when a timeout is exceeded.
This error can be thrown under 2 circumstances:
A wait timeout has exceeded, which means that the client timed out waiting for the next
message from the server. In this case, #isRetryable() will be true.
An idle timeout has exceeded, which means that the stream is using manual flow control and
the caller has not called StreamController#request(int) (in case of callback api)
or next on ServerStream#iterator() (in case of blocking api).
[[["Easy to understand","easyToUnderstand","thumb-up"],["Solved my problem","solvedMyProblem","thumb-up"],["Other","otherUp","thumb-up"]],[["Hard to understand","hardToUnderstand","thumb-down"],["Incorrect information or sample code","incorrectInformationOrSampleCode","thumb-down"],["Missing the information/samples I need","missingTheInformationSamplesINeed","thumb-down"],["Other","otherDown","thumb-down"]],["Last updated 2025-08-28 UTC."],[[["\u003cp\u003eThe latest version available for \u003ccode\u003eWatchdogTimeoutException\u003c/code\u003e is 2.63.1, as seen in the provided list of version numbers.\u003c/p\u003e\n"],["\u003cp\u003e\u003ccode\u003eWatchdogTimeoutException\u003c/code\u003e is a marker exception, inheriting from \u003ccode\u003eApiException\u003c/code\u003e, that is thrown when a timeout has been exceeded.\u003c/p\u003e\n"],["\u003cp\u003eThis exception can occur when either a wait timeout or an idle timeout is exceeded, the wait timeout being retryable.\u003c/p\u003e\n"],["\u003cp\u003eThe \u003ccode\u003eLOCAL_ABORTED_STATUS_CODE\u003c/code\u003e is a static field provided, and is of the type \u003ccode\u003eStatusCode\u003c/code\u003e.\u003c/p\u003e\n"],["\u003cp\u003e\u003ccode\u003eWatchdogTimeoutException\u003c/code\u003e inherits a variety of methods and fields from \u003ccode\u003eApiException\u003c/code\u003e, \u003ccode\u003eObject\u003c/code\u003e, and \u003ccode\u003eThrowable\u003c/code\u003e, for managing error states, stack trace information, and status codes.\u003c/p\u003e\n"]]],[],null,["# Exception WatchdogTimeoutException (2.69.0)\n\nVersion latestkeyboard_arrow_down\n\n- [2.69.0 (latest)](/java/docs/reference/gax/latest/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.68.2](/java/docs/reference/gax/2.68.2/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.67.0](/java/docs/reference/gax/2.67.0/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.66.0](/java/docs/reference/gax/2.66.0/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.65.0](/java/docs/reference/gax/2.65.0/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.63.1](/java/docs/reference/gax/2.63.1/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.62.0](/java/docs/reference/gax/2.62.0/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.61.0](/java/docs/reference/gax/2.61.0/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.60.0](/java/docs/reference/gax/2.60.0/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.59.1](/java/docs/reference/gax/2.59.1/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.58.0](/java/docs/reference/gax/2.58.0/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.57.0](/java/docs/reference/gax/2.57.0/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.55.0](/java/docs/reference/gax/2.55.0/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.54.1](/java/docs/reference/gax/2.54.1/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.53.0](/java/docs/reference/gax/2.53.0/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.52.0](/java/docs/reference/gax/2.52.0/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.51.0](/java/docs/reference/gax/2.51.0/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.50.0](/java/docs/reference/gax/2.50.0/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.49.0](/java/docs/reference/gax/2.49.0/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.48.1](/java/docs/reference/gax/2.48.1/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.47.0](/java/docs/reference/gax/2.47.0/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.46.1](/java/docs/reference/gax/2.46.1/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.45.0](/java/docs/reference/gax/2.45.0/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.43.0](/java/docs/reference/gax/2.43.0/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.42.0](/java/docs/reference/gax/2.42.0/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.41.0](/java/docs/reference/gax/2.41.0/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.39.0](/java/docs/reference/gax/2.39.0/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.38.0](/java/docs/reference/gax/2.38.0/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.37.0](/java/docs/reference/gax/2.37.0/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.36.0](/java/docs/reference/gax/2.36.0/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.35.0](/java/docs/reference/gax/2.35.0/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.34.1](/java/docs/reference/gax/2.34.1/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.33.0](/java/docs/reference/gax/2.33.0/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.32.1](/java/docs/reference/gax/2.32.1/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.31.1](/java/docs/reference/gax/2.31.1/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.30.1](/java/docs/reference/gax/2.30.1/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.24.0](/java/docs/reference/gax/2.24.0/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.23.3](/java/docs/reference/gax/2.23.3/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.22.0](/java/docs/reference/gax/2.22.0/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.21.0](/java/docs/reference/gax/2.21.0/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.20.1](/java/docs/reference/gax/2.20.1/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.19.6](/java/docs/reference/gax/2.19.6/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.18.7](/java/docs/reference/gax/2.18.7/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.17.0](/java/docs/reference/gax/2.17.0/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.16.0](/java/docs/reference/gax/2.16.0/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.15.0](/java/docs/reference/gax/2.15.0/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.14.0](/java/docs/reference/gax/2.14.0/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.13.0](/java/docs/reference/gax/2.13.0/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.12.2](/java/docs/reference/gax/2.12.2/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.11.0](/java/docs/reference/gax/2.11.0/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.10.0](/java/docs/reference/gax/2.10.0/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.9.0](/java/docs/reference/gax/2.9.0/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.8.1](/java/docs/reference/gax/2.8.1/com.google.api.gax.rpc.WatchdogTimeoutException)\n- [2.7.1](/java/docs/reference/gax/2.7.1/com.google.api.gax.rpc.WatchdogTimeoutException) \n\n public class WatchdogTimeoutException extends ApiException\n\nThe marker exception thrown when a timeout is exceeded.\n\nThis error can be thrown under 2 circumstances:\n\n- A wait timeout has exceeded, which means that the client timed out waiting for the next message from the server. In this case, #isRetryable() will be true.\n- An idle timeout has exceeded, which means that the stream is using manual flow control and the caller has not called [StreamController#request(int)](/java/docs/reference/gax/latest/com.google.api.gax.rpc.StreamController#com_google_api_gax_rpc_StreamController_request_int_) (in case of callback api) or next on [ServerStream#iterator()](/java/docs/reference/gax/latest/com.google.api.gax.rpc.ServerStream#com_google_api_gax_rpc_ServerStream_iterator__) (in case of blocking api). \n\nInherited Members\n-----------------\n\n[ApiException.getDomain()](/java/docs/reference/gax/latest/com.google.api.gax.rpc.ApiException#com_google_api_gax_rpc_ApiException_getDomain__) \n[ApiException.getErrorDetails()](/java/docs/reference/gax/latest/com.google.api.gax.rpc.ApiException#com_google_api_gax_rpc_ApiException_getErrorDetails__) \n[ApiException.getMetadata()](/java/docs/reference/gax/latest/com.google.api.gax.rpc.ApiException#com_google_api_gax_rpc_ApiException_getMetadata__) \n[ApiException.getReason()](/java/docs/reference/gax/latest/com.google.api.gax.rpc.ApiException#com_google_api_gax_rpc_ApiException_getReason__) \n[ApiException.getStatusCode()](/java/docs/reference/gax/latest/com.google.api.gax.rpc.ApiException#com_google_api_gax_rpc_ApiException_getStatusCode__) \n[ApiException.isRetryable()](/java/docs/reference/gax/latest/com.google.api.gax.rpc.ApiException#com_google_api_gax_rpc_ApiException_isRetryable__) \n[Object.clone()](https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html#clone--) \n[Object.equals(Object)](https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html#equals-java.lang.Object-) \n[Object.finalize()](https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html#finalize--) \n[Object.getClass()](https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html#getClass--) \n[Object.hashCode()](https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html#hashCode--) \n[Object.notify()](https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html#notify--) \n[Object.notifyAll()](https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html#notifyAll--) \n[Object.wait()](https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html#wait--) \n[Object.wait(long)](https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html#wait-long-) \n[Object.wait(long,int)](https://docs.oracle.com/javase/8/docs/api/java/lang/Object.html#wait-long-int-) \n[Throwable.addSuppressed(Throwable)](https://docs.oracle.com/javase/8/docs/api/java/lang/Throwable.html#addSuppressed-java.lang.Throwable-) \n[Throwable.fillInStackTrace()](https://docs.oracle.com/javase/8/docs/api/java/lang/Throwable.html#fillInStackTrace--) \n[Throwable.getCause()](https://docs.oracle.com/javase/8/docs/api/java/lang/Throwable.html#getCause--) \n[Throwable.getLocalizedMessage()](https://docs.oracle.com/javase/8/docs/api/java/lang/Throwable.html#getLocalizedMessage--) \n[Throwable.getMessage()](https://docs.oracle.com/javase/8/docs/api/java/lang/Throwable.html#getMessage--) \n[Throwable.getStackTrace()](https://docs.oracle.com/javase/8/docs/api/java/lang/Throwable.html#getStackTrace--) \n[Throwable.getSuppressed()](https://docs.oracle.com/javase/8/docs/api/java/lang/Throwable.html#getSuppressed--) \n[Throwable.initCause(Throwable)](https://docs.oracle.com/javase/8/docs/api/java/lang/Throwable.html#initCause-java.lang.Throwable-) \n[Throwable.printStackTrace()](https://docs.oracle.com/javase/8/docs/api/java/lang/Throwable.html#printStackTrace--) \n[Throwable.printStackTrace(PrintStream)](https://docs.oracle.com/javase/8/docs/api/java/lang/Throwable.html#printStackTrace-java.io.PrintStream-) \n[Throwable.printStackTrace(PrintWriter)](https://docs.oracle.com/javase/8/docs/api/java/lang/Throwable.html#printStackTrace-java.io.PrintWriter-) \n[Throwable.setStackTrace(StackTraceElement\\[\\])](https://docs.oracle.com/javase/8/docs/api/java/lang/Throwable.html#setStackTrace-java.lang.StackTraceElement[]-) \n[Throwable.toString()](https://docs.oracle.com/javase/8/docs/api/java/lang/Throwable.html#toString--)\n\nStatic Fields\n-------------\n\n### LOCAL_ABORTED_STATUS_CODE\n\n public static final StatusCode LOCAL_ABORTED_STATUS_CODE"]]