mirror of
https://github.com/FirebirdSQL/firebird.git
synced 2025-01-23 18:03:04 +01:00
Improvement CORE-3656 : Support for sweep information in Trace API.
Fixed case when sweep cleaned up relation with all records deleted but corresponding event was missed in trace log.
This commit is contained in:
parent
218a462784
commit
8dc7b564ca
@ -1845,7 +1845,7 @@ void TRA_sweep(thread_db* tdbb)
|
||||
|
||||
CCH_RELEASE(tdbb, &window);
|
||||
|
||||
traceSweep.report(process_state_finished);
|
||||
traceSweep.finish();
|
||||
}
|
||||
|
||||
TRA_commit(tdbb, transaction, false);
|
||||
@ -3671,7 +3671,54 @@ TraceSweepEvent::~TraceSweepEvent()
|
||||
}
|
||||
|
||||
|
||||
void TraceSweepEvent::report(ntrace_process_state_t state, jrd_rel* relation)
|
||||
void TraceSweepEvent::beginSweepRelation(jrd_rel* relation)
|
||||
{
|
||||
if (!m_need_trace)
|
||||
return;
|
||||
|
||||
if (relation && relation->rel_name.isEmpty())
|
||||
{
|
||||
// don't accumulate per-relation stats for metadata query below
|
||||
MET_lookup_relation_id(m_tdbb, relation->rel_id, false);
|
||||
}
|
||||
|
||||
m_relation_clock = fb_utils::query_performance_counter();
|
||||
m_request.req_stats.reset();
|
||||
}
|
||||
|
||||
|
||||
void TraceSweepEvent::endSweepRelation(jrd_rel* relation)
|
||||
{
|
||||
if (!m_need_trace)
|
||||
return;
|
||||
|
||||
// don't report empty relation
|
||||
if (m_request.req_stats.getValue(RuntimeStatistics::RECORD_SEQ_READS) == 0 &&
|
||||
m_request.req_stats.getValue(RuntimeStatistics::RECORD_BACKOUTS) == 0 &&
|
||||
m_request.req_stats.getValue(RuntimeStatistics::RECORD_PURGES) == 0 &&
|
||||
m_request.req_stats.getValue(RuntimeStatistics::RECORD_EXPUNGES) == 0)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
// we need to compare stats against zero base
|
||||
m_request.req_base_stats.reset();
|
||||
|
||||
Database* dbb = m_tdbb->getDatabase();
|
||||
TraceRuntimeStats stats(dbb, &m_request.req_base_stats, &m_request.req_stats,
|
||||
fb_utils::query_performance_counter() - m_relation_clock,
|
||||
0);
|
||||
|
||||
m_sweep_info.setPerf(stats.getPerf());
|
||||
|
||||
Attachment* att = m_tdbb->getAttachment();
|
||||
TraceConnectionImpl conn(att);
|
||||
TraceManager* trace_mgr = att->att_trace_manager;
|
||||
trace_mgr->event_sweep(&conn, &m_sweep_info, process_state_progress);
|
||||
}
|
||||
|
||||
|
||||
void TraceSweepEvent::report(ntrace_process_state_t state)
|
||||
{
|
||||
Attachment* att = m_tdbb->getAttachment();
|
||||
|
||||
@ -3695,26 +3742,13 @@ void TraceSweepEvent::report(ntrace_process_state_t state, jrd_rel* relation)
|
||||
|
||||
TraceConnectionImpl conn(att);
|
||||
|
||||
if (relation && relation->rel_name.isEmpty())
|
||||
{
|
||||
// don't accumulate per-relation stats for metadata query below
|
||||
m_tdbb->setRequest(NULL);
|
||||
MET_lookup_relation_id(m_tdbb, relation->rel_id, false);
|
||||
m_tdbb->setRequest(&m_request);
|
||||
}
|
||||
|
||||
// we need to compare stats against zero base
|
||||
m_request.req_base_stats.reset();
|
||||
|
||||
TraceRuntimeStats stats(dbb, &m_request.req_base_stats,
|
||||
state == process_state_progress ? &m_request.req_stats : &att->att_stats,
|
||||
fb_utils::query_performance_counter() - (state == process_state_progress ?
|
||||
m_relation_clock : m_start_clock),
|
||||
TraceRuntimeStats stats(dbb, &m_request.req_base_stats, &att->att_stats,
|
||||
fb_utils::query_performance_counter() - m_start_clock,
|
||||
0);
|
||||
|
||||
m_request.req_stats.reset();
|
||||
m_relation_clock = fb_utils::query_performance_counter();
|
||||
|
||||
m_sweep_info.setPerf(stats.getPerf());
|
||||
trace_mgr->event_sweep(&conn, &m_sweep_info, state);
|
||||
|
||||
|
@ -480,9 +480,17 @@ public:
|
||||
m_sweep_info.update(header);
|
||||
}
|
||||
|
||||
void report(ntrace_process_state_t state, jrd_rel* relation = 0);
|
||||
void beginSweepRelation(jrd_rel* relation);
|
||||
void endSweepRelation(jrd_rel* relation);
|
||||
|
||||
void finish()
|
||||
{
|
||||
report(process_state_finished);
|
||||
}
|
||||
|
||||
private:
|
||||
void report(ntrace_process_state_t state);
|
||||
|
||||
bool m_need_trace;
|
||||
thread_db* m_tdbb;
|
||||
TraceSweepImpl m_sweep_info;
|
||||
@ -491,6 +499,7 @@ private:
|
||||
jrd_req m_request;
|
||||
};
|
||||
|
||||
|
||||
} // namespace Jrd
|
||||
|
||||
#endif // JRD_TRACE_JRD_HELPERS_H
|
||||
|
@ -2926,7 +2926,6 @@ bool VIO_sweep(thread_db* tdbb, jrd_tra* transaction, TraceSweepEvent* traceSwee
|
||||
|
||||
for (size_t i = 1; (vector = dbb->dbb_relations) && i < vector->count(); i++)
|
||||
{
|
||||
bool haveRecs = false;
|
||||
if ((relation = (*vector)[i]) && !(relation->rel_flags & (REL_deleted | REL_deleting)) &&
|
||||
relation->getPages(tdbb)->rel_pages)
|
||||
{
|
||||
@ -2934,6 +2933,9 @@ bool VIO_sweep(thread_db* tdbb, jrd_tra* transaction, TraceSweepEvent* traceSwee
|
||||
rpb.rpb_number.setValue(BOF_NUMBER);
|
||||
rpb.rpb_org_scans = relation->rel_scan_count++;
|
||||
++relation->rel_sweep_count;
|
||||
|
||||
traceSweep->beginSweepRelation(relation);
|
||||
|
||||
#ifdef GARBAGE_THREAD
|
||||
if (relation->rel_garbage) {
|
||||
relation->rel_garbage->clear();
|
||||
@ -2955,12 +2957,9 @@ bool VIO_sweep(thread_db* tdbb, jrd_tra* transaction, TraceSweepEvent* traceSwee
|
||||
#ifdef SUPERSERVER
|
||||
transaction->tra_oldest_active = dbb->dbb_oldest_snapshot;
|
||||
#endif
|
||||
haveRecs = true;
|
||||
}
|
||||
|
||||
if (haveRecs) {
|
||||
traceSweep->report(process_state_progress, relation);
|
||||
}
|
||||
traceSweep->endSweepRelation(relation);
|
||||
|
||||
--relation->rel_sweep_count;
|
||||
--relation->rel_scan_count;
|
||||
|
Loading…
Reference in New Issue
Block a user