Why is ParallelBatchWriterMode used when Applying Oplogs

XMLWordPrintableJSON

    • Type: Question
    • Resolution: Done
    • Priority: Critical - P2
    • None
    • Affects Version/s: None
    • Component/s: Replication
    • None
    • None
    • 0
    • None
    • None
    • None
    • None
    • None
    • None
    • None

      In function OpTime SyncTail::multiApply, ParallelBatchWriterMode is used.
      If primary is writing heavily, the latency of reading slaves will be very unstable. In our production environment, it may be 400 to 1000ms,
      I know that ParallelBatchWriterMode is a global resource lock, which will block every read operation on every collections.
      My question is that: why is it necessary to stop reads on collections other than oplog.rs?
      Why can not a lock on local db satisfy the concurrency model?

              Assignee:
              Andy Schwerin
              Reporter:
              deyukong
              Votes:
              0 Vote for this issue
              Watchers:
              7 Start watching this issue

                Created:
                Updated:
                Resolved: