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

[optimizer] debugging: capture id and plan in a span when lowering MIR #30920

Closed
wants to merge 2 commits into from

Conversation

mgree
Copy link
Contributor

@mgree mgree commented Dec 30, 2024

We've seen some one-shot selects with joins that are missing arrangements; adding a span here should let us see more about the issue.

Motivation

  • This PR fixes a previously unreported bug.

Logs are triggering a soft_assert_or_log in lowering.rs, but it's not clear what the high-level query is that's causing the issue.

Tips for reviewer

Checklist

  • This PR has adequate test coverage / QA involvement has been duly considered. (trigger-ci for additional test/nightly runs)
  • This PR has an associated up-to-date design doc, is a design doc (template), or is sufficiently small to not require a design.
  • If this PR evolves an existing $T ⇔ Proto$T mapping (possibly in a backwards-incompatible way), then it is tagged with a T-proto label.
  • If this PR will require changes to cloud orchestration or tests, there is a companion cloud PR to account for those changes that is tagged with the release-blocker label (example).
  • If this PR includes major user-facing behavior changes, I have pinged the relevant PM to schedule a changelog post.

@mgree mgree requested a review from a team as a code owner December 30, 2024 16:03
Copy link
Contributor

@ggevay ggevay left a comment

Choose a reason for hiding this comment

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

I tried the PR locally as mentioned here, and it seems to be working.

Might slow down things a slightly bit, but I'd say this is worth it for getting to the bottom of this issue. I had another go today at trying to find the offending queries in the query history, but no luck, so this PR is my last hope currently.

@ggevay
Copy link
Contributor

ggevay commented Jan 9, 2025

In the meantime we found the problem without this extra logging. We can decide whether we still want to merge this. The log turned out to include the query (not in Sentry, but when accessed through Grafana), so maybe the MIR added in this PR is not really needed. We didn't pay attention to performance when we were writing the stringification of plans, because EXPLAIN is not performance sensitive, so I'd be a slightly bit worried with putting a stringification at every query execution.

@mgree
Copy link
Contributor Author

mgree commented Jan 9, 2025

Let's skip it, then---it's a non-trivial overhead on every lowering.

@mgree mgree closed this Jan 9, 2025
@mgree mgree deleted the debug-missing-arrangement branch January 9, 2025 15:23
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants