Error handling task settings
You can set the error handling behavior of your replication task using the following settings. For information about how to use a task configuration file to set task settings, see Task settings example.
-
DataErrorPolicy
– Determines the action AWS DMS takes when there is an error related to data processing at the record level. Some examples of data processing errors include conversion errors, errors in transformation, and bad data. The default isLOG_ERROR
.-
IGNORE_RECORD
– The task continues and the data for that record is ignored. The error counter for theDataErrorEscalationCount
property is incremented. Thus, if you set a limit on errors for a table, this error counts toward that limit. -
LOG_ERROR
– The task continues and the error is written to the task log. -
SUSPEND_TABLE
– The task continues but data from the table with the error record is moved into an error state and the data isn't replicated. -
STOP_TASK
– The task stops and manual intervention is required.
-
-
DataTruncationErrorPolicy
– Determines the action AWS DMS takes when data is truncated. The default isLOG_ERROR
.-
IGNORE_RECORD
– The task continues and the data for that record is ignored. The error counter for theDataErrorEscalationCount
property is incremented. Thus, if you set a limit on errors for a table, this error counts toward that limit. -
LOG_ERROR
– The task continues and the error is written to the task log. -
SUSPEND_TABLE
– The task continues but data from the table with the error record is moved into an error state and the data isn't replicated. -
STOP_TASK
– The task stops and manual intervention is required.
-
-
DataErrorEscalationPolicy
– Determines the action AWS DMS takes when the maximum number of errors (set in theDataErrorEscalationCount
parameter) is reached. The default isSUSPEND_TABLE
.-
SUSPEND_TABLE
– The task continues but data from the table with the error record is moved into an error state and the data isn't replicated. -
STOP_TASK
– The task stops and manual intervention is required.
-
-
DataErrorEscalationCount
– Sets the maximum number of errors that can occur to the data for a specific record. When this number is reached, the data for the table that contains the error record is handled according to the policy set in theDataErrorEscalationPolicy
. The default is 0. -
EventErrorPolicy
– Determines the action AWS DMS takes when an error occurs while sending a task-related event. Its possible values are-
IGNORE
– The task continues and any data associated with that event is ignored. -
STOP_TASK
– The task stops and manual intervention is required.
-
-
TableErrorPolicy
– Determines the action AWS DMS takes when an error occurs when processing data or metadata for a specific table. This error only applies to general table data and isn't an error that relates to a specific record. The default isSUSPEND_TABLE
.-
SUSPEND_TABLE
– The task continues but data from the table with the error record is moved into an error state and the data isn't replicated. -
STOP_TASK
– The task stops and manual intervention is required.
-
-
TableErrorEscalationPolicy
– Determines the action AWS DMS takes when the maximum number of errors (set using theTableErrorEscalationCount
parameter). The default and only user setting isSTOP_TASK
, where the task is stopped and manual intervention is required. -
TableErrorEscalationCount
– The maximum number of errors that can occur to the general data or metadata for a specific table. When this number is reached, the data for the table is handled according to the policy set in theTableErrorEscalationPolicy
. The default is 0. -
RecoverableErrorCount
– The maximum number of attempts made to restart a task when an environmental error occurs. After the system attempts to restart the task the designated number of times, the task is stopped and manual intervention is required. The default value is -1, which instructs AWS DMS to attempt to restart the task indefinitely. When you set this value to -1, the number of retries that DMS attempts varies based on the returned error type as follows:Running state, recoverable error: If a recoverable error such as a lost connection or a target apply fail occurs, DMS retries the task nine times.
Starting state, recoverable error: DMS retries the task six times.
Running state, fatal error handled by DMS: DMS retries the task six times.
Running state, fatal error not handled by DMS: DMS does not retry the task.
Set this value to 0 to never attempt to restart a task.
We recommend that you set
RecoverableErrorCount
andRecoverableErrorInterval
to values such that there are sufficient retries at sufficient intervals for your DMS task to recover properly. If a fatal error occurs, DMS stops making restart attempts in most scenarios. -
RecoverableErrorInterval
– The number of seconds that AWS DMS waits between attempts to restart a task. The default is 5. -
RecoverableErrorThrottling
– When enabled, the interval between attempts to restart a task is increased in a series based on the value ofRecoverableErrorInterval
. For example, ifRecoverableErrorInterval
is set to 5 seconds, then the next retry will happen after 10 seconds, then 20, then 40 seconds and so on. The default istrue
. -
RecoverableErrorThrottlingMax
– The maximum number of seconds that AWS DMS waits between attempts to restart a task ifRecoverableErrorThrottling
is enabled. The default is 1800. -
RecoverableErrorStopRetryAfterThrottlingMax
– When set totrue
, stops restarting the task after the maximum number of seconds that AWS DMS waits between recovery attempts is reached, perRecoverableErrorThrottlingMax
. -
ApplyErrorDeletePolicy
– Determines what action AWS DMS takes when there is a conflict with a DELETE operation. The default isIGNORE_RECORD
. Possible values are the following:-
IGNORE_RECORD
– The task continues and the data for that record is ignored. The error counter for theApplyErrorEscalationCount
property is incremented. Thus, if you set a limit on errors for a table, this error counts toward that limit. -
LOG_ERROR
– The task continues and the error is written to the task log. -
SUSPEND_TABLE
– The task continues but data from the table with the error record is moved into an error state and the data isn't replicated. -
STOP_TASK
– The task stops and manual intervention is required.
-
-
ApplyErrorInsertPolicy
– Determines what action AWS DMS takes when there is a conflict with an INSERT operation. The default isLOG_ERROR
. Possible values are the following:-
IGNORE_RECORD
– The task continues and the data for that record is ignored. The error counter for theApplyErrorEscalationCount
property is incremented. Thus, if you set a limit on errors for a table, this error counts toward that limit. -
LOG_ERROR
– The task continues and the error is written to the task log. -
SUSPEND_TABLE
– The task continues but data from the table with the error record is moved into an error state and the data isn't replicated. -
STOP_TASK
– The task stops and manual intervention is required. -
INSERT_RECORD
– If there is an existing target record with the same primary key as the inserted source record, the target record is updated.
-
-
ApplyErrorUpdatePolicy
– Determines what action AWS DMS takes when there is a missing data conflict with an UPDATE operation. The default isLOG_ERROR
. Possible values are the following:-
IGNORE_RECORD
– The task continues and the data for that record is ignored. The error counter for theApplyErrorEscalationCount
property is incremented. Thus, if you set a limit on errors for a table, this error counts toward that limit. -
LOG_ERROR
– The task continues and the error is written to the task log. -
SUSPEND_TABLE
– The task continues but data from the table with the error record is moved into an error state and the data isn't replicated. -
STOP_TASK
– The task stops and manual intervention is required. -
UPDATE_RECORD
– If the target record is missing, the missing target record is inserted into the target table. AWS DMS completely disables LOB column support for the task. Selecting this option requires full supplemental logging to be enabled for all the source table columns when Oracle is the source database.
-
-
ApplyErrorEscalationPolicy
– Determines what action AWS DMS takes when the maximum number of errors (set using theApplyErrorEscalationCount
parameter) is reached. The default is LOG_ERROR:-
LOG_ERROR
– The task continues and the error is written to the task log. -
SUSPEND_TABLE
– The task continues but data from the table with the error record is moved into an error state and the data isn't replicated. -
STOP_TASK
– The task stops and manual intervention is required.
-
-
ApplyErrorEscalationCount
– This option sets the maximum number of APPLY conflicts that can occur for a specific table during a change process operation. When this number is reached, the table data is handled according to the policy set in theApplyErrorEscalationPolicy
parameter. The default is 0. -
ApplyErrorFailOnTruncationDdl
– Set this option totrue
to cause the task to fail when a truncation is performed on any of the tracked tables during CDC. The default isfalse
.This approach doesn't work with PostgreSQL version 11.x or lower, or any other source endpoint that doesn't replicate DDL table truncation.
-
FailOnNoTablesCaptured
– Set this option totrue
to cause a task to fail when the table mappings defined for a task find no tables when the task starts. The default isfalse
. -
FailOnTransactionConsistencyBreached
– This option applies to tasks using Oracle as a source with CDC. The default is false. Set it totrue
to cause a task to fail when a transaction is open for more time than the specified timeout and can be dropped.When a CDC task starts with Oracle, AWS DMS waits for a limited time for the oldest open transaction to close before starting CDC. If the oldest open transaction doesn't close until the timeout is reached, then in most cases AWS DMS starts CDC, ignoring that transaction. If this option is set to
true
, the task fails. -
FullLoadIgnoreConflicts
– Set this option totrue
to have AWS DMS ignore "zero rows affected" and "duplicates" errors when applying cached events. If set tofalse
, AWS DMS reports all errors instead of ignoring them. The default istrue
.
Note that table load errors in Redshift as a target are reported
in STL_LOAD_ERRORS
. For more information, see
STL_LOAD_ERRORS
in the Amazon Redshift Database Developer Guide.