• Luis Soares's avatar
    BUG#49259: Slave I/O thread could not register on master · 845d7e1e
    Luis Soares authored
    The slave thread changed the format of the information it used to
    connect to the master after patch for BUG 13963.  This resulted
    in old master getting confused, thence rejecting the slave
    connection attempt.
    
    In particular, patch for BUG 13963 removed the rpl_recovery_rank
    variable which was, at that time, packed together with the rest
    of the information which the slave would use to register itself
    on the master. Based on this data, the master would then assert
    that the number of bytes received in the connection command was
    consistent to what it was expecting. 
    
    Therefore, given that a slave, patched with the aforementioned
    patch, would not pack the four bytes related to the
    rpl_recovery_rank variable, the old master would reject the
    connection attempt. It would assume that the data was
    inconsistent (fewer bytes than it was expecting) and return 
    an error.
    
    We fix this by faking an rpl_recovery_rank variable when
    registering the slave on the master. In practice this reverts a
    small part of patch for BUG 13963, the one related to the slave
    connecting to the master.
    845d7e1e
repl_failsafe.cc 18.3 KB