Uploaded image for project: 'Kafka'
  1. Kafka
  2. KAFKA-9062

Handle stalled writes to RocksDB

    XMLWordPrintableJSON

Details

    Description

      RocksDB may stall writes at times when background compactions or flushes are having trouble keeping up. This means we can effectively end up blocking indefinitely during a StateStore#put call within Streams, and may get kicked from the group if the throttling does not ease up within the max poll interval.

      Example: when restoring large amounts of state from scratch, we use the strategy recommended by RocksDB of turning off automatic compactions and dumping everything into L0. We do batch somewhat, but do not sort these small batches before loading into the db, so we end up with a large number of unsorted L0 files.

      When restoration is complete and we toggle the db back to normal (not bulk loading) settings, a background compaction is triggered to merge all these into the next level. This background compaction can take a long time to merge unsorted keys, especially when the amount of data is quite large.

      Any new writes while the number of L0 files exceeds the max will be stalled until the compaction can finish, and processing after restoring from scratch can block beyond the polling interval

      Attachments

        Activity

          People

            Unassigned Unassigned
            ableegoldman A. Sophie Blee-Goldman
            Votes:
            1 Vote for this issue
            Watchers:
            11 Start watching this issue

            Dates

              Created:
              Updated:
              Resolved: