ID | IEP-34 |
Author | |
Sponsor | |
Created |
|
Status | COMPLETED |
Currently transactions are not supported by thin client protocol.
There are changes needed for protocol, server side, and client side to support transactions.
Add new operations to the thin client protocol:
Name | Code | Description |
---|---|---|
OP_TX_START | 4000 | Start a new transaction |
OP_TX_END | 4001 | End the transaction |
Request | |
---|---|
byte | Concurrency control: 0 - OPTIMISTIC 1 - PESSIMISTIC |
byte | Isolation level: 0 - READ_COMMITTED 1 - REPEATABLE_READ 2 - SERIALIZABLE |
long | Timeout |
string | label |
Response | |
---|---|
int | Unique per client connection transaction id. This id should be returned as parameter with OP_TX_END message and all messages of cache operations within the transaction. |
Request | |
---|---|
int | Transaction id. |
bool | Commit flag. |
Empty response.
We need to add a new field to requests header of all cache data manipulation operations (opcodes 1000-1020, 2000, 2002, 2004) to bind these operations with the transaction.
Proposed changes to cache operations request header format:
Type | Description | |
---|---|---|
int | Length of payload | |
short | Operation code | |
long | Request id | |
int | Cache id | |
byte | flags (new "under transaction" flag with bitmask 0x02 introduced, to indicate that operation performed under transaction) | modified |
int | Transaction id (present only if "under transaction" flag is set, i.e. if flags & 0x02 != 0) | added |
On the server side, we need to have the ability to decouple transactions from threads. We can do this by using transaction suspend/resume methods. Suspend/resume methods are only implemented for optimistic transactions now, so we need to implement this mechanism for pessimistic transactions first.
Using this approach there is no need to start any new thread to serve the transaction. All transaction control operations and all cache operations within transactions will be served by existing "client-connector" threads.
When the client sends OP_TX_START request, a new transaction is starting in a suspended state.
When the client performs a cache operation within a transaction, thread served this request resumes the transaction, processes cache operation and suspends the transaction again.
When the client sends OP_TX_END request, thread served this request resumes the transaction and commit or rollback it.
The client must bind transaction and all cache operations which was made within this explicitly started transaction. We can implement transaction per thread approach on the thin client side as implemented now for the thick client. In this case, each transaction on the thin client side will be bound to a thread started this transaction. And each cache operation performed by this thread will be bound to the same transaction until the transaction is completed.
Also, the client implementation must review the logic of failover, since we can't silently change servers in case of connection error in the middle of the transaction.
If client allowed to use several concurrent transactions per connection it must support async request sending to server, otherwise, deadlock is possible (for example, when the first transaction lock the key, then the second transaction try to lock the same key, blocks and lock the connection).
Proposed new interfaces for java thin client:
public interface ClientTransactions { public ClientTransaction txStart(); // Start tx with client default values of concurrency, isolation and timeout properties. public ClientTransaction txStart(TransactionConcurrency concurrency, TransactionIsolation isolation); // Start tx with default timeout. public ClientTransaction txStart(TransactionConcurrency concurrency, TransactionIsolation isolation, long timeout); public ClientTransactions withLabel(String lb); }
public interface ClientTransaction extends AutoCloseable { public void commit(); public void rollback(); public void close(); }
To configure client default concurrency, isolation and timeout values for connection it is proposed to create new configuration class:
public class ClientTransactionConfiguration { public static final TransactionConcurrency DFLT_TX_CONCURRENCY = TransactionConcurrency.PESSIMISTIC; public static final TransactionIsolation DFLT_TX_ISOLATION = TransactionIsolation.REPEATABLE_READ; public static final long DFLT_TRANSACTION_TIMEOUT = 0; public TransactionConcurrency getDefaultTxConcurrency(); public ClientTransactionConfiguration setDefaultTxConcurrency(TransactionConcurrency dfltConcurrency) public TransactionIsolation getDefaultTxIsolation(); public ClientTransactionConfiguration setDefaultTxIsolation(TransactionIsolation dfltIsolation); public long getDefaultTxTimeout(); public ClientTransactionConfiguration setDefaultTxTimeout(long dfltTxTimeout); }
This transaction configuration can be used when the client connection is created (as a property of ClientConfiguration class).
//
http://apache-ignite-developers.2346864.n4.nabble.com/Thin-client-transactions-support-td27761.html
// Links to various reference documents, if applicable.