mirror of
https://github.com/XRPLF/clio.git
synced 2025-12-01 17:15:52 +00:00
Fix crashing bug related to account_tx writes
This commit is contained in:
@@ -24,12 +24,13 @@ processAsyncWriteResponse(T& requestParams, CassFuture* fut, F func)
|
||||
auto rc = cass_future_error_code(fut);
|
||||
if (rc != CASS_OK)
|
||||
{
|
||||
BOOST_LOG_TRIVIAL(error)
|
||||
<< "ERROR!!! Cassandra insert error: " << rc << ", "
|
||||
<< cass_error_desc(rc) << ", retrying ";
|
||||
// exponential backoff with a max wait of 2^10 ms (about 1 second)
|
||||
auto wait = std::chrono::milliseconds(
|
||||
lround(std::pow(2, std::min(10u, requestParams.currentRetries))));
|
||||
BOOST_LOG_TRIVIAL(error)
|
||||
<< "ERROR!!! Cassandra ETL insert error: " << rc << ", "
|
||||
<< cass_error_desc(rc) << ", retrying in " << wait.count()
|
||||
<< " milliseconds";
|
||||
++requestParams.currentRetries;
|
||||
std::shared_ptr<boost::asio::steady_timer> timer =
|
||||
std::make_shared<boost::asio::steady_timer>(
|
||||
@@ -42,6 +43,8 @@ processAsyncWriteResponse(T& requestParams, CassFuture* fut, F func)
|
||||
}
|
||||
else
|
||||
{
|
||||
BOOST_LOG_TRIVIAL(trace)
|
||||
<< __func__ << " Succesfully inserted a record";
|
||||
backend.finishAsyncWrite();
|
||||
int remaining = --requestParams.refs;
|
||||
if (remaining == 0)
|
||||
@@ -668,12 +671,13 @@ writeBookCallback(CassFuture* fut, void* cbData)
|
||||
auto rc = cass_future_error_code(fut);
|
||||
if (rc != CASS_OK)
|
||||
{
|
||||
BOOST_LOG_TRIVIAL(error)
|
||||
<< "ERROR!!! Cassandra insert key error: " << rc << ", "
|
||||
<< cass_error_desc(rc) << ", retrying ";
|
||||
// exponential backoff with a max wait of 2^10 ms (about 1 second)
|
||||
auto wait = std::chrono::milliseconds(
|
||||
lround(std::pow(2, std::min(10u, requestParams.currentRetries))));
|
||||
BOOST_LOG_TRIVIAL(error)
|
||||
<< "ERROR!!! Cassandra insert book error: " << rc << ", "
|
||||
<< cass_error_desc(rc) << ", retrying in " << wait.count()
|
||||
<< " milliseconds";
|
||||
++requestParams.currentRetries;
|
||||
std::shared_ptr<boost::asio::steady_timer> timer =
|
||||
std::make_shared<boost::asio::steady_timer>(
|
||||
@@ -686,7 +690,7 @@ writeBookCallback(CassFuture* fut, void* cbData)
|
||||
}
|
||||
else
|
||||
{
|
||||
BOOST_LOG_TRIVIAL(trace) << __func__ << "Finished a write request";
|
||||
BOOST_LOG_TRIVIAL(trace) << __func__ << " Successfully inserted a book";
|
||||
{
|
||||
std::lock_guard lck(requestParams.mtx);
|
||||
--requestParams.numRemaining;
|
||||
@@ -742,12 +746,13 @@ writeKeyCallback(CassFuture* fut, void* cbData)
|
||||
auto rc = cass_future_error_code(fut);
|
||||
if (rc != CASS_OK)
|
||||
{
|
||||
BOOST_LOG_TRIVIAL(error)
|
||||
<< "ERROR!!! Cassandra insert key error: " << rc << ", "
|
||||
<< cass_error_desc(rc) << ", retrying ";
|
||||
// exponential backoff with a max wait of 2^10 ms (about 1 second)
|
||||
auto wait = std::chrono::milliseconds(
|
||||
lround(std::pow(2, std::min(10u, requestParams.currentRetries))));
|
||||
BOOST_LOG_TRIVIAL(error)
|
||||
<< "ERROR!!! Cassandra insert key error: " << rc << ", "
|
||||
<< cass_error_desc(rc) << ", retrying in " << wait.count()
|
||||
<< " milliseconds";
|
||||
// exponential backoff with a max wait of 2^10 ms (about 1 second)
|
||||
++requestParams.currentRetries;
|
||||
std::shared_ptr<boost::asio::steady_timer> timer =
|
||||
std::make_shared<boost::asio::steady_timer>(
|
||||
@@ -760,7 +765,7 @@ writeKeyCallback(CassFuture* fut, void* cbData)
|
||||
}
|
||||
else
|
||||
{
|
||||
BOOST_LOG_TRIVIAL(trace) << __func__ << "Finished a write request";
|
||||
BOOST_LOG_TRIVIAL(trace) << __func__ << " Successfully inserted a key";
|
||||
{
|
||||
std::lock_guard lck(requestParams.mtx);
|
||||
--requestParams.numRemaining;
|
||||
|
||||
@@ -1185,18 +1185,29 @@ public:
|
||||
{
|
||||
}
|
||||
};
|
||||
|
||||
struct WriteAccountTxCallbackData
|
||||
{
|
||||
CassandraBackend const* backend;
|
||||
AccountTransactionsData data;
|
||||
ripple::AccountID account;
|
||||
uint32_t ledgerSequence;
|
||||
uint32_t transactionIndex;
|
||||
ripple::uint256 txHash;
|
||||
|
||||
uint32_t currentRetries = 0;
|
||||
std::atomic<int> refs;
|
||||
std::atomic<int> refs = 1;
|
||||
|
||||
WriteAccountTxCallbackData(
|
||||
CassandraBackend const* f,
|
||||
AccountTransactionsData&& in)
|
||||
: backend(f), data(std::move(in)), refs(data.accounts.size())
|
||||
ripple::AccountID&& account,
|
||||
uint32_t lgrSeq,
|
||||
uint32_t txIdx,
|
||||
ripple::uint256&& hash)
|
||||
: backend(f)
|
||||
, account(std::move(account))
|
||||
, ledgerSequence(lgrSeq)
|
||||
, transactionIndex(txIdx)
|
||||
, txHash(std::move(hash))
|
||||
{
|
||||
}
|
||||
};
|
||||
@@ -1291,26 +1302,30 @@ public:
|
||||
{
|
||||
for (auto& record : data)
|
||||
{
|
||||
WriteAccountTxCallbackData* cbData =
|
||||
new WriteAccountTxCallbackData(this, std::move(record));
|
||||
writeAccountTx(*cbData, false);
|
||||
for (auto& account : record.accounts)
|
||||
{
|
||||
WriteAccountTxCallbackData* cbData =
|
||||
new WriteAccountTxCallbackData(
|
||||
this,
|
||||
std::move(account),
|
||||
record.ledgerSequence,
|
||||
record.transactionIndex,
|
||||
std::move(record.txHash));
|
||||
writeAccountTx(*cbData, false);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void
|
||||
writeAccountTx(WriteAccountTxCallbackData& data, bool isRetry) const
|
||||
{
|
||||
for (auto const& account : data.data.accounts)
|
||||
{
|
||||
CassandraStatement statement(insertAccountTx_);
|
||||
statement.bindBytes(account);
|
||||
statement.bindIntTuple(
|
||||
data.data.ledgerSequence, data.data.transactionIndex);
|
||||
statement.bindBytes(data.data.txHash);
|
||||
CassandraStatement statement(insertAccountTx_);
|
||||
statement.bindBytes(data.account);
|
||||
statement.bindIntTuple(data.ledgerSequence, data.transactionIndex);
|
||||
statement.bindBytes(data.txHash);
|
||||
|
||||
executeAsyncWrite(
|
||||
statement, flatMapWriteAccountTxCallback, data, isRetry);
|
||||
}
|
||||
executeAsyncWrite(
|
||||
statement, flatMapWriteAccountTxCallback, data, isRetry);
|
||||
}
|
||||
|
||||
struct WriteTransactionCallbackData
|
||||
|
||||
Reference in New Issue
Block a user