Ensure TiKV transactions do not panic when a transaction is dropped
This commit is contained in:
parent
10bc3b2ddd
commit
0d05446976
1 changed files with 28 additions and 16 deletions
|
@ -4,6 +4,8 @@ use crate::err::Error;
|
||||||
use crate::kvs::Key;
|
use crate::kvs::Key;
|
||||||
use crate::kvs::Val;
|
use crate::kvs::Val;
|
||||||
use std::ops::Range;
|
use std::ops::Range;
|
||||||
|
use tikv::CheckLevel;
|
||||||
|
use tikv::TransactionOptions;
|
||||||
|
|
||||||
pub struct Datastore {
|
pub struct Datastore {
|
||||||
db: tikv::TransactionClient,
|
db: tikv::TransactionClient,
|
||||||
|
@ -31,22 +33,32 @@ impl Datastore {
|
||||||
// Start a new transaction
|
// Start a new transaction
|
||||||
pub async fn transaction(&self, write: bool, lock: bool) -> Result<Transaction, Error> {
|
pub async fn transaction(&self, write: bool, lock: bool) -> Result<Transaction, Error> {
|
||||||
match lock {
|
match lock {
|
||||||
true => match self.db.begin_optimistic().await {
|
true => {
|
||||||
|
// Set the behaviour when dropping an unfinished transaction
|
||||||
|
let opt = TransactionOptions::new_optimistic().drop_check(CheckLevel::Warn);
|
||||||
|
// Create a new optimistic transaction
|
||||||
|
match self.db.begin_with_options(opt).await {
|
||||||
Ok(tx) => Ok(Transaction {
|
Ok(tx) => Ok(Transaction {
|
||||||
ok: false,
|
ok: false,
|
||||||
rw: write,
|
rw: write,
|
||||||
tx,
|
tx,
|
||||||
}),
|
}),
|
||||||
Err(e) => Err(Error::Tx(e.to_string())),
|
Err(e) => Err(Error::Tx(e.to_string())),
|
||||||
},
|
}
|
||||||
false => match self.db.begin_pessimistic().await {
|
}
|
||||||
|
false => {
|
||||||
|
// Set the behaviour when dropping an unfinished transaction
|
||||||
|
let opt = TransactionOptions::new_pessimistic().drop_check(CheckLevel::Warn);
|
||||||
|
// Create a new pessimistic transaction
|
||||||
|
match self.db.begin_with_options(opt).await {
|
||||||
Ok(tx) => Ok(Transaction {
|
Ok(tx) => Ok(Transaction {
|
||||||
ok: false,
|
ok: false,
|
||||||
rw: write,
|
rw: write,
|
||||||
tx,
|
tx,
|
||||||
}),
|
}),
|
||||||
Err(e) => Err(Error::Tx(e.to_string())),
|
Err(e) => Err(Error::Tx(e.to_string())),
|
||||||
},
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue