-
Notifications
You must be signed in to change notification settings - Fork 427
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 #370
Add logging #370
Conversation
Thanks for the patch! I need to think about this for a little bit. |
I think this should rather be using https://github.com/tokio-rs/tracing where the user can choose how something is logged. Additionally, traces can be used for much more than just logging, for example users could send them to Zipkin or some trace viewer and visually check how the application is performing. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks again for the PR! After reading up I think using https://github.com/tokio-rs/tracing/tree/master/tracing is the better choice and will also be easier to reason about once we go async (soon™).
I will need to look at tracing more, but unless I am mistaken, tracing is for application level logging/tracing. Juniper is a library. So, users could use the tracing crate in their application which uses the Juniper library... This PR uses a logging facade via the log crate for that purpose—so users can decide which logging front end to use (e.g. tracing or env-logger etc). Regardless, the log crate is pretty much the standard/official (it is maintained by the Rust lang team and has 13+ million downloads) way to implement logging in libraries. Also, tokio uses the log crate... |
Thanks for the PR @mwilliammyers , but I'm closing this for now. We will want to use the tracing crate, especially with async support, but even without it. |
@theduke I am happy to open a new PR using There is also use tracing_log::LogTracer;
use log;
LogTracer::init()?;
// will be available for Subscribers as a tracing Event
log::trace!("an example trace log"); I would really prefer to not force users to use a specific logging adapter and let them choose the crate. |
You can fine-grain tracing! The idea is, that there are different implementations on subscribers which can indicate interest in a specific trace or event. These subscribers could - for example - only listen to events emitted by Tokio and Juniper, or just Tokio, or just events from a specific thread, or ... What the subscriber does with the events is also not set in stone. There's existing logging subscribers or timing subscribers, but only your imagination can set the limits here. I, for example, are tinkering with a subscriber that exports events in the OpenZipkin format, so traces can be visualized. One could also think about exporting to Honeycomb. |
Open to all ideas. Let's discuss in #423. |
As it stands right now, this is an MVP of logging, with just the bare minimum I thought useful (at least at for my work).
Some questions need to be answered:
warn
/error
or simplydebug
and reservewarn
anderror
for recoverable errors and unrecoverable errors?execute
function. Maybe we should go 1+ levels deeper, and for example, log in theexecute_validated_query
function so that users can be more granular and enable/disablejuniper::executor
etc.ClearTextPassword
scalar type in my code and making theDisplay
/Debug
impl be something like[password]
. Perhaps we add something to that effect to the book?I didn't and probably won't (yet) do much logging of the actual parser because #138...
I am happy to keep adding commits (and squashing?) to this PR and/or do this in chunks and open smaller PRs as I add more logging.
Closes #48.