databendlabs / databend

๐——๐—ฎ๐˜๐—ฎ, ๐—”๐—ป๐—ฎ๐—น๐˜†๐˜๐—ถ๐—ฐ๐˜€ & ๐—”๐—œ. Modern alternative to Snowflake. Cost-effective and simple for massive-scale analytics. https://databend.com
https://docs.databend.com
Other
7.85k stars 750 forks source link

fix: lock mgr may failed to release lock in time #16611

Closed dantengsky closed 1 month ago

dantengsky commented 1 month ago

I hereby agree to the terms of the CLA available at: https://docs.databend.com/dev/policies/cla/

Summary

Replaces tokio::sync::Notify with WatchNotify which is safe to nofity_one before Notified future has been polled, otherwise, we risk not being able to release the lock in time.

Tests

Type of change


This change isโ€‚Reviewable

what-the-diff[bot] commented 1 month ago

PR Summary

github-actions[bot] commented 1 month ago

Docker Image for PR

note: this image tag is only available for internal use, please check the internal doc for more details.

github-actions[bot] commented 1 month ago

ClickBench Report