• Michael Paquier's avatar
    Refresh apply delay on reload of recovery_min_apply_delay at recovery · f83d80ea
    Michael Paquier authored
    This commit ensures that the wait interval in the replay delay loop
    waiting for an amount of time defined by recovery_min_apply_delay is
    correctly handled on reload, recalculating the delay if this GUC value
    is updated, based on the timestamp of the commit record being replayed.
    
    The previous behavior would be problematic for example with replay
    still waiting even if the delay got reduced or just cancelled.  If the
    apply delay was increased to a larger value, the wait would have just
    respected the old value set, finishing earlier.
    
    Author: Soumyadeep Chakraborty, Ashwin Agrawal
    Reviewed-by: Kyotaro Horiguchi, Michael Paquier
    Discussion: https://postgr.es/m/CAE-ML+93zfr-HLN8OuxF0BjpWJ17O5dv1eMvSE5jsj9jpnAXZA@mail.gmail.com
    Backpatch-through: 9.6
    f83d80ea
xlog.c 402 KB