mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-12-15 02:41:59 +00:00
Add locks on exception throwing.
This commit is contained in:
parent
bdd9243f68
commit
333bba4e6b
@ -459,7 +459,6 @@ void QueryStatus::ExecutorHolder::remove()
|
||||
CancellationCode QueryStatus::cancelQuery(CancelReason reason, std::exception_ptr exception)
|
||||
{
|
||||
{
|
||||
// Lock the mutex to protect the critical section
|
||||
std::lock_guard<std::mutex> lock(cancel_mutex);
|
||||
|
||||
if (is_killed)
|
||||
@ -501,10 +500,13 @@ CancellationCode QueryStatus::cancelQuery(CancelReason reason, std::exception_pt
|
||||
|
||||
void QueryStatus::throwProperExceptionIfNeeded(const UInt64 & max_execution_time, const UInt64 & elapsed_ns) const
|
||||
{
|
||||
if (is_killed.load())
|
||||
{
|
||||
std::lock_guard<std::mutex> lock(cancel_mutex);
|
||||
if (is_killed)
|
||||
{
|
||||
throwProperException(max_execution_time, elapsed_ns);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void QueryStatus::throwProperException(const UInt64 & max_execution_time, const UInt64 & elapsed_ns) const
|
||||
@ -515,7 +517,7 @@ void QueryStatus::throwProperException(const UInt64 & max_execution_time, const
|
||||
|
||||
if (cancel_reason == CancelReason::TIMEOUT)
|
||||
throw Exception(ErrorCodes::TIMEOUT_EXCEEDED, "Timeout exceeded: {} maximum: {} ms", additional_error_part, max_execution_time / 1000.0);
|
||||
throw Exception(ErrorCodes::QUERY_WAS_CANCELLED, "Query was cancelled");
|
||||
throwQueryWasCancelled();
|
||||
}
|
||||
|
||||
void QueryStatus::addPipelineExecutor(PipelineExecutor * e)
|
||||
|
@ -116,7 +116,7 @@ protected:
|
||||
bool is_cancelling { false };
|
||||
/// KILL was send to the query
|
||||
std::atomic<bool> is_killed { false };
|
||||
std::atomic<CancelReason> cancel_reason { CancelReason::UNDEFINED };
|
||||
CancelReason cancel_reason { CancelReason::UNDEFINED };
|
||||
|
||||
std::exception_ptr cancellation_exception;
|
||||
mutable std::mutex cancellation_exception_mutex;
|
||||
|
Loading…
Reference in New Issue
Block a user