Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

  • A memory component start as an empty component with its state being either READABLE_WRITABLE (first component) or INACTIVE (other components).
  • READABLE_WRITABLE component becomes READABLE_UNWRITABLE prior to flushing it to allow for current writers inside the components to exit before flushing.
    • This operation is done through the primary index operation tracker and it affects all indexes/partitions of the dataset.
    • Hence, an empty component can become READABLE_UNWRITABLE and schedule flush will get called.
  • If schedule flush is called on an empty component, its state is switched back from READABLE_UNWRITABLE to READABLE_WRITABLE.
  • On scheduling a flush, the memory component state is transitioned to READABLE_UNWRITABLE_FLUSHING. The previous state can either be
    READABLE_UNWRITABLE or (READABLE_WRITABLE: not clear when).
  • When a flush is scheduled, the activation flag is set for the next component. If there is only a single component, then the flag is set for the current component.