Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Dataflow Streaming] Reduce contention on work submission #33687

Open
wants to merge 3 commits into
base: master
Choose a base branch
from

Conversation

arunpandianp
Copy link
Contributor

@arunpandianp arunpandianp commented Jan 21, 2025

The monitor guarding BoundedQueueExecutor's counters was locked by both the work submitting threads and the harness threads (300 of them). The contention can slow down the work submission loop. This change reduces the contention by collapsing counter updates from the harness threads and letting one thread to lock the monitor and update the counters.

Example wallz profile showing the stacks locking the monitor
Screenshot 2025-01-22 at 6 27 12 PM

#33578

@arunpandianp
Copy link
Contributor Author

R: @scwhittle

Copy link
Contributor

Stopping reviewer notifications for this pull request: review requested by someone other than the bot, ceding control. If you'd like to restart, comment assign set of reviewers

@arunpandianp
Copy link
Contributor Author

Run Java PreCommit

// counters. We do this to reduce contention on monitor which is locked by
// GetWork thread
decrementQueue.add(workBytes);
synchronized (decrementQueueDrainLock) {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

wondering if this will end up creating more threads in the pool if we have a bunch of threads blocking on this but the count is decremented by another thread and new work is admitted.

maybe we could improve to reduce the # of threads waiting on synchronized block using an atomic? Seems like something like the following would make it so there is at most one thread waiting for the synchronized block

addToQueue
bool coalesce = !atomic_coalescer.getandset(true);
if (!coalesce) return;
{
sync single
atomic_coalescer.set(false);
poll queue, return if empty
monitor {

}
}

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants