Vladimir Pligin created IGNITE-25101:
----------------------------------------
Summary: add a separate error code for access to a rolled back
transaction
Key: IGNITE-25101
URL: https://issues.apache.org/jira/browse/IGNITE-25101
Project: Ignite
Issue Type: Improvement
Reporter: Vladimir Pligin
{{Currently there is only one error code for access to a finished transaction.
Looks impossible to distinguish if it was rolled back.}}
{code:java}
public static final int TX_ALREADY_FINISHED_ERR =
TX_ERR_GROUP.registerErrorCode((short) 13);{code}
For example the exception (it's a RO transaction called from SQL layer):
{code:java}
Caused by:
org.apache.ignite.internal.sql.engine.exec.RemoteFragmentExecutionException:
IGN-TX-13 TraceId:95e939eb-e9a0-42dc-8aee-6fcbdc52ea8e Transaction is already
finished () [txId=01961a63-27cf-0000-0642-127000000001, readOnly=true]. at
org.apache.ignite.internal.sql.engine.exec.ExecutionServiceImpl.onMessage(ExecutionServiceImpl.java:673)
at
org.apache.ignite.internal.sql.engine.exec.ExecutionServiceImpl.lambda$start$4(ExecutionServiceImpl.java:331)
at
org.apache.ignite.internal.sql.engine.message.MessageServiceImpl.onMessageInternal(MessageServiceImpl.java:158)
at
org.apache.ignite.internal.sql.engine.message.MessageServiceImpl.lambda$onMessage$2(MessageServiceImpl.java:124)
at
org.apache.ignite.internal.sql.engine.exec.QueryTaskExecutorImpl.lambda$execute$0(QueryTaskExecutorImpl.java:78)
... 3 more{code}
There is a method {{}}
{code:java}
isRolledBackWithTimeoutExceeded(){code}
{{{}{}}}in {{{*}_InternalTransaction_{*}, but it's unclear how to use it.}}
{{We have to add a way of getting information if a transaction was rolled back
(and/or timed out).}}
--
This message was sent by Atlassian Jira
(v8.20.10#820010)