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

Fix lock order when dropping index #7600

Open
wants to merge 2 commits into
base: main
Choose a base branch
from

Conversation

mkindahl
Copy link
Contributor

If an index is dropped, it is necessary to lock the heap table (of the index) before the index since all normal operations do it in this order. When dropping an index, we did not take all the necessary locks in the right order before calling performMultipleDeletions, which can cause deadlocks when dropping an index on a hypertable at the same time as running a utility statement that takes heavy locks, e.g., VACUUM or ANALYZE.

@mkindahl mkindahl force-pushed the fix-index-deadlock branch 2 times, most recently from 1f7a183 to 951b92a Compare January 17, 2025 10:04
Copy link

codecov bot commented Jan 17, 2025

Codecov Report

Attention: Patch coverage is 14.28571% with 12 lines in your changes missing coverage. Please review.

Project coverage is 82.28%. Comparing base (59f50f2) to head (4504ac8).
Report is 702 commits behind head on main.

Files with missing lines Patch % Lines
src/chunk_index.c 14.28% 11 Missing and 1 partial ⚠️
Additional details and impacted files
@@            Coverage Diff             @@
##             main    #7600      +/-   ##
==========================================
+ Coverage   80.06%   82.28%   +2.22%     
==========================================
  Files         190      238      +48     
  Lines       37181    44099    +6918     
  Branches     9450    11089    +1639     
==========================================
+ Hits        29770    36289    +6519     
- Misses       2997     3426     +429     
+ Partials     4414     4384      -30     

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

@mkindahl mkindahl marked this pull request as ready for review January 17, 2025 10:58
src/chunk_index.c Outdated Show resolved Hide resolved
mkindahl and others added 2 commits January 21, 2025 09:24
If an index is dropped, it is necessary to lock the heap table (of
the index) before the index since all normal operations do it in this
order. When dropping an index, we did not take all the necessary locks
in the right order before calling `performMultipleDeletions`, which can
cause deadlocks when dropping an index on a hypertable at the same time
as running a utility statement that takes heavy locks, e.g., VACUUM or
ANALYZE.
Co-authored-by: Erik Nordström <[email protected]>
Signed-off-by: Mats Kindahl <[email protected]>
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