On 2021-Aug-23, Bossart, Nathan wrote:
> Sorry, I'm still not following this one. If we skipped creating
> .ready segments due to a crash, we rely on RemoveOldXlogFiles() to
> create them as needed in the end-of-recovery checkpoint. If a record
> fits perfectly in the end of a segment, we'll still register it as a
> boundary for the next segment (hence why we use XLByteToSeg() instead
> of XLByteToPrevSeg()). If database activity stops completely, there
> shouldn't be anything to mark ready.
The only way .ready files are created is that XLogNotifyWrite() is
called. For regular WAL files during regular operation, that only
happens in XLogNotifyWriteSeg(). That, in turn, only happens in
NotifySegmentsReadyForArchive(). But if the system runs and never
writes WAL records that cross WAL boundaries, that function will see
that both earliestSegBoundary and latestSegBoundary are MaxXLogSegno,
and return without doing anything. So no segments will be notified.
--
Álvaro Herrera 39°49'30"S 73°17'W — https://www.EnterpriseDB.com/