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

Add logging of query IDs via QueryLogIterator class #2451

Open
wants to merge 44 commits into
base: integration
Choose a base branch
from

Conversation

SethSmucker
Copy link
Collaborator

Create QueryLogIterator class that logs a query's ID to the TServer logs

  • Add QueryLogIterator to DefaultQueryPlanner
  • Add tserver.logging.active to QueryParameters, used to turn logging on and off
  • Add tests for QueryLogIterator and TServerLogging

Resolves #2305

Updated the PR to merge code from NSA/log-iterator to NSA/origin instead of from SethSmucker/log-iterator.

SethSmucker and others added 17 commits June 5, 2024 14:08
Added the query option tserver.logging.active to enable
logging of query IDs to the TServer logs. Created the
class QueryLogIterator to handle this. Logs the
start and end of each method called.

Fixes #2305
* Fix CountQueryTest issues

* Remove unecessary changes

* Code formatting
Add TserverLogging test to verify that queryLogIterator is created and
added to the iterator stack when desired. Additionally, move
tserver.logging.active property to QueryParameters, and ensure that if
specified, the query parameter will override the configuration settings.
Additionally, make it possible to set the tserver active logging flag
from a ShardQueryLogic configuration setting in the
QueryLogicFactory.xml file.
Added the query option tserver.logging.active to enable
logging of query IDs to the TServer logs. Created the
class QueryLogIterator to handle this. Logs the
start and end of each method called.

Fixes #2305
@SethSmucker SethSmucker marked this pull request as ready for review July 1, 2024 20:49
@SethSmucker SethSmucker requested review from apmoriarty, jwomeara and ivakegg and removed request for apmoriarty and jwomeara July 5, 2024 15:22
ivakegg
ivakegg previously approved these changes Sep 6, 2024
@ivakegg ivakegg added the MXTC label Oct 31, 2024
Copy link
Collaborator

@billoley billoley left a comment

Choose a reason for hiding this comment

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

How to update thread name and restore old name
Also how to add and remove a value to the MapedDiagnosticContext (MDC)

String oldName = Thread.currentThread().getName();
Thread.currentThread().setName(oldName + " -> " + queryId);
MDC.put("queryId", queryId);
try {
    // call corresponding method of the source
} finally {
    Thread.currentThread().setName(oldName);
    MDC.remove("queryId");
}

Keep the start/stop logging in seek and next, but it's overkill in the others
Add the code to change/restore thread name and add/remove MDC in all methods that are overridden from the base class and which call that method on source

@SethSmucker SethSmucker reopened this Jan 23, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

Successfully merging this pull request may close these issues.

QueryIterators/ScanIterators should log query id first
4 participants