mirror of
https://git.postgresql.org/git/postgresql.git
synced 2024-12-09 08:10:09 +08:00
Have GetCurrentTransactionStopTimestamp() set xactStopTimestamp if unset
Previously GetCurrentTransactionStopTimestamp() computed a new timestamp whenever xactStopTimestamp was unset and xactStopTimestamp was only set when a commit or abort record was written. An upcoming patch will add additional calls to GetCurrentTransactionStopTimestamp() from pgstats. To avoid computing timestamps multiple times, set xactStopTimestamp in GetCurrentTransactionStopTimestamp() if not already set. Author: Dave Page <dpage@pgadmin.org> Reviewed-by: Andres Freund <andres@anarazel.de> Reviewed-by: Vik Fearing <vik@postgresfriends.org> Discussion: https://postgr.es/m/20220906155325.an3xesq5o3fq36gt%40awork3.anarazel.de
This commit is contained in:
parent
db1b931a4e
commit
309b2cf243
@ -263,7 +263,10 @@ static bool currentCommandIdUsed;
|
|||||||
/*
|
/*
|
||||||
* xactStartTimestamp is the value of transaction_timestamp().
|
* xactStartTimestamp is the value of transaction_timestamp().
|
||||||
* stmtStartTimestamp is the value of statement_timestamp().
|
* stmtStartTimestamp is the value of statement_timestamp().
|
||||||
* xactStopTimestamp is the time at which we log a commit or abort WAL record.
|
* xactStopTimestamp is the time at which we log a commit / abort WAL record,
|
||||||
|
* or if that was skipped, the time of the first subsequent
|
||||||
|
* GetCurrentTransactionStopTimestamp() call.
|
||||||
|
*
|
||||||
* These do not change as we enter and exit subtransactions, so we don't
|
* These do not change as we enter and exit subtransactions, so we don't
|
||||||
* keep them inside the TransactionState stack.
|
* keep them inside the TransactionState stack.
|
||||||
*/
|
*/
|
||||||
@ -865,15 +868,24 @@ GetCurrentStatementStartTimestamp(void)
|
|||||||
/*
|
/*
|
||||||
* GetCurrentTransactionStopTimestamp
|
* GetCurrentTransactionStopTimestamp
|
||||||
*
|
*
|
||||||
* We return current time if the transaction stop time hasn't been set
|
* If the transaction stop time hasn't already been set, which can happen if
|
||||||
* (which can happen if we decide we don't need to log an XLOG record).
|
* we decided we don't need to log an XLOG record, set xactStopTimestamp.
|
||||||
*/
|
*/
|
||||||
TimestampTz
|
TimestampTz
|
||||||
GetCurrentTransactionStopTimestamp(void)
|
GetCurrentTransactionStopTimestamp(void)
|
||||||
{
|
{
|
||||||
if (xactStopTimestamp != 0)
|
TransactionState s PG_USED_FOR_ASSERTS_ONLY = CurrentTransactionState;
|
||||||
|
|
||||||
|
/* should only be called after commit / abort processing */
|
||||||
|
Assert(s->state == TRANS_DEFAULT ||
|
||||||
|
s->state == TRANS_COMMIT ||
|
||||||
|
s->state == TRANS_ABORT ||
|
||||||
|
s->state == TRANS_PREPARE);
|
||||||
|
|
||||||
|
if (xactStopTimestamp == 0)
|
||||||
|
xactStopTimestamp = GetCurrentTimestamp();
|
||||||
|
|
||||||
return xactStopTimestamp;
|
return xactStopTimestamp;
|
||||||
return GetCurrentTimestamp();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -891,15 +903,6 @@ SetCurrentStatementStartTimestamp(void)
|
|||||||
Assert(stmtStartTimestamp != 0);
|
Assert(stmtStartTimestamp != 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* SetCurrentTransactionStopTimestamp
|
|
||||||
*/
|
|
||||||
static inline void
|
|
||||||
SetCurrentTransactionStopTimestamp(void)
|
|
||||||
{
|
|
||||||
xactStopTimestamp = GetCurrentTimestamp();
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* GetCurrentTransactionNestLevel
|
* GetCurrentTransactionNestLevel
|
||||||
*
|
*
|
||||||
@ -1396,9 +1399,7 @@ RecordTransactionCommit(void)
|
|||||||
START_CRIT_SECTION();
|
START_CRIT_SECTION();
|
||||||
MyProc->delayChkptFlags |= DELAY_CHKPT_START;
|
MyProc->delayChkptFlags |= DELAY_CHKPT_START;
|
||||||
|
|
||||||
SetCurrentTransactionStopTimestamp();
|
XactLogCommitRecord(GetCurrentTransactionStopTimestamp(),
|
||||||
|
|
||||||
XactLogCommitRecord(xactStopTimestamp,
|
|
||||||
nchildren, children, nrels, rels,
|
nchildren, children, nrels, rels,
|
||||||
ndroppedstats, droppedstats,
|
ndroppedstats, droppedstats,
|
||||||
nmsgs, invalMessages,
|
nmsgs, invalMessages,
|
||||||
@ -1422,7 +1423,7 @@ RecordTransactionCommit(void)
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
if (!replorigin || replorigin_session_origin_timestamp == 0)
|
if (!replorigin || replorigin_session_origin_timestamp == 0)
|
||||||
replorigin_session_origin_timestamp = xactStopTimestamp;
|
replorigin_session_origin_timestamp = GetCurrentTransactionStopTimestamp();
|
||||||
|
|
||||||
TransactionTreeSetCommitTsData(xid, nchildren, children,
|
TransactionTreeSetCommitTsData(xid, nchildren, children,
|
||||||
replorigin_session_origin_timestamp,
|
replorigin_session_origin_timestamp,
|
||||||
@ -1754,8 +1755,7 @@ RecordTransactionAbort(bool isSubXact)
|
|||||||
xact_time = GetCurrentTimestamp();
|
xact_time = GetCurrentTimestamp();
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
SetCurrentTransactionStopTimestamp();
|
xact_time = GetCurrentTransactionStopTimestamp();
|
||||||
xact_time = xactStopTimestamp;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
XactLogAbortRecord(xact_time,
|
XactLogAbortRecord(xact_time,
|
||||||
|
Loading…
Reference in New Issue
Block a user