• D
    Fix a race condition while processing tasks by background threads. · 38671c4d
    Dhruba Borthakur 提交于
    Summary:
    Suppose you submit 100 background tasks one after another. The first
    enqueu task finds that the queue is empty and wakes up one worker thread.
    Now suppose that all remaining 99 work items are enqueued, they do not
    wake up any worker threads because the queue is already non-empty.
    This causes a situation when there are 99 tasks in the task queue but
    only one worker thread is processing a task while the remaining
    worker threads are waiting.
    The fix is to always wakeup one worker thread while enqueuing a task.
    
    I also added a check to count the number of elements in the queue
    to help in debugging.
    
    Test Plan: make clean check.
    
    Reviewers: chip
    
    Reviewed By: chip
    
    CC: leveldb
    
    Differential Revision: https://reviews.facebook.net/D7203
    38671c4d
env_posix.cc 23.3 KB