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

Transaction coordinator could be left in unknown state after ZK session timeout

    XMLWordPrintableJSON

Details

    • Bug
    • Status: Resolved
    • Major
    • Resolution: Fixed
    • 2.2.0, 2.3.0, 2.2.1, 2.2.2, 2.4.0, 2.3.1
    • 2.2.3, 2.3.2, 2.4.1
    • core
    • None

    Description

      We observed a case where the transaction coordinator could not load transaction state from __transaction-state topic partition. Clients would continue seeing COORDINATOR_LOAD_IN_PROGRESS exceptions until the broker hosting the coordinator is restarted.

      This is the sequence of events that leads to the issue:

      1. The broker is the leader of one (or more) transaction state topic partitions.
      2. The broker loses its ZK session due to a network issue.
      3. Broker reestablishes session with ZK, though there are still transient network issues.
      4. Broker is made follower of the transaction state topic partition it was leading earlier.
      5. During the become-follower transition, the broker loses its ZK session again.
      6. The become-follower transition for this broker fails in-between, leaving us in a partial leader / partial follower state for the transaction topic. This meant that we could not unload the transaction metadata. However, the broker successfully caches the leader epoch of associated with the LeaderAndIsrRequest.
      7. Later, when the ZK session is finally established successfully, the broker ignores the become-follower transition as the leader epoch was same as the one it had cached. This prevented the transaction metadata from being unloaded.
      8. Because this partition was a partial follower, we had setup replica fetchers. The partition continued to fetch from the leader until it was made part of the ISR.
      9. Once it was part of the ISR, preferred leader election kicked in and elected this broker as the leader.
      10. When processing the become-leader transition, the transaction state load operation failed as we already had transaction metadata loaded at a previous epoch.
      11. This meant that this partition was left in the "loading" state and we thus returned COORDINATOR_LOAD_IN_PROGRESS errors.

      Restarting the broker that hosts the transaction state coordinator is the only way to recover from this situation.

      Attachments

        Issue Links

          Activity

            People

              dhruvilshah Dhruvil Shah
              dhruvilshah Dhruvil Shah
              Votes:
              0 Vote for this issue
              Watchers:
              3 Start watching this issue

              Dates

                Created:
                Updated:
                Resolved: