• Satya B's avatar
    Fix for BUG#41330 -Myisam table open count set to zero before index blocks · 87e417ac
    Satya B authored
                       are written.
          
    When we have a myisam table with DELAY_KEY_WRITE option, index updates
    are not applied until the flush tables command is issued or until the
    server is shutdown. If server gets killed before the index updates are 
    written to disk, the index file is corrupted as expected but the table 
    is not marked as crashed. So when we start server with myisam-recover,
    table is not repaired leaving the table unusable.
          
    The problem is when we try to write the index updates to index file,
    we decrement the open_count even before the flushing the keys to index
    file.
          
    Fixed by moving the decrement operation after flushing the keys to the
    index file. So we always have non zero open count if the flush table
    operation is killed and when the server is started with mysiam-recover
    option, it marks the table as crashed and repairs it.
          
    Note: No testcase for added as we need to kill the server and start the 
          server with different set of options and other non trivial
          operations involved.
    
    myisam/mi_close.c:
      Decrement open count after flushing the key blocks to the
      key file. If the server(with DELAY_KEY_WRITE option) is
      killed before flush_key_blocks operation, we will have non
      zero open count and the table can be repaired when server is
      started with --myisam-recover option.
    87e417ac
mi_close.c 3.48 KB