Skip to content
Snippets Groups Projects
  • Heikki Linnakangas's avatar
    3881aedb
    Fix recycling of WAL segments after changing recovery target timeline. · 3881aedb
    Heikki Linnakangas authored
    After the recovery target timeline is changed, we would still recycle and
    preallocate WAL segments on the old target timeline. Those WAL segments
    created for the old timeline are a waste of space, although otherwise
    harmless.
    
    The problem is that when installing a recycled WAL segment as a future one,
    ThisTimeLineID is used to construct the filename. ThisTimeLineID is
    initialized in the checkpointer process to the recovery target timeline at
    startup, but it was not updated when the startup process chooses a new
    target timeline (recovery_target_timeline='latest'). To fix, always update
    ThisTimeLineID before recycling WAL segments at a restartpoint.
    
    This still leaves a small window where we might install WAL segments under
    wrong timeline ID, if the target timeline is changed just as we're about to
    start recycling. Also, when we're not on the target timeline yet, but still
    replaying some older timeline, we'll install WAL segments to the newer
    timeline anyway and they will still go wasted. We'll just live with the
    waste in that situation.
    
    Commit to 9.2 and 9.1. Older versions didn't change recovery target timeline
    after startup, and for master, I'll commit a slightly different variant of
    this.
    3881aedb
    History
    Fix recycling of WAL segments after changing recovery target timeline.
    Heikki Linnakangas authored
    After the recovery target timeline is changed, we would still recycle and
    preallocate WAL segments on the old target timeline. Those WAL segments
    created for the old timeline are a waste of space, although otherwise
    harmless.
    
    The problem is that when installing a recycled WAL segment as a future one,
    ThisTimeLineID is used to construct the filename. ThisTimeLineID is
    initialized in the checkpointer process to the recovery target timeline at
    startup, but it was not updated when the startup process chooses a new
    target timeline (recovery_target_timeline='latest'). To fix, always update
    ThisTimeLineID before recycling WAL segments at a restartpoint.
    
    This still leaves a small window where we might install WAL segments under
    wrong timeline ID, if the target timeline is changed just as we're about to
    start recycling. Also, when we're not on the target timeline yet, but still
    replaying some older timeline, we'll install WAL segments to the newer
    timeline anyway and they will still go wasted. We'll just live with the
    waste in that situation.
    
    Commit to 9.2 and 9.1. Older versions didn't change recovery target timeline
    after startup, and for master, I'll commit a slightly different variant of
    this.