-
-
Notifications
You must be signed in to change notification settings - Fork 200
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
log levels and structured logging #831
Comments
I think your suggestion of adding the flag to the cli is a great first step! |
@iwpnd thanks for this write-up! I think logging in tegola has been severely lacking and this is something I strongly support improving. I don't really have any issues with your suggestions. I think it's a strong plan, I support the approach and the introduction of the Regarding implementation, I think we should take this package by package. Maybe we start with the core logging package upgrade followed by implementing this in the |
As discussed in go-spatial#831 I added the option to use structured logs with uber/zap while falling back to the currently implemented default if --logger is not specifically used. Log levels conform to the current implementation with the exception of log level TRACE that is not supported by zap. I use Debug as a fall back here.
As discussed in #831 I added the option to use structured logs with uber/zap while falling back to the currently implemented default if --logger is not specifically used. Log levels conform to the current implementation with the exception of log level TRACE that is not supported by zap. I use Debug as a fall back here.
TLDR:
Let's organize logging in Tegola, revisit log levels and classification and push for json structured logs.
Hi there 👋,
As discussed on Slack I'd love to discuss the issue of logging in Tegola right now. I want to be transparent here and say that I'm pushing for a discussion, because it's a feature that will benefit the company I'm working for. However, I'm trying to make a case why this benefits the Tegola user in general.
I want to briefly cover three issues I see with logging in Tegola right now.
In the following I will try to form problem statements for each of the topics and propose action points that I want to put up for discussion.
1. Chatty logs
Problem statement:
Under some circumstances tegola can be very very chatty. While not ideal, I don't think this is too much of an issue for smaller applications. Bigger applications with a lot of users however, in my experience, push logs to providers like datadog/cloudwatch etc to aggregate and analyze them. Noisy applications tend to become a cost factor all of a sudden.
One example is this log line:
That occurs when the user configures max and min zoom for a layer.
Is this an information you'd expect to be logged on INFO level?
Action points:
(source)
2. inability for the user to set log levels
Problem statement:
Allowing the user to set the desired log level allows to address different user groups and usage scenarios. While development DEBUG level is the preferred choice, INFO or WARN is what makes it to production to reduce information noise and/or alert fatige.
@gdey created a central log package with everything that is needed to to set loglevels for the application. The current init sets defaults it to INFO with no way for the user to change it on start-up or in the config.
Action points:
quick win let's expose
log.go:SetLogLevel
in the CLI as--log-level very-verbose|verbose|quiet|silent
and make this part of v0.15.0.very-verbose
= TRACEverbose
= DEBUGdefault
= INFOquiet
= WARNsilent
= ERROR3. structured json logs
Problem statement:
Text logs have a small footprint and are faster than json logs. The biggest benefit of loggin in JSON however is, that its structured data that can be analyzed and filtered better than text logs. Plus, it's standardized and almost every language or os can parse/work with it.
I suggest we do not build that from scratch but tap into the rich eco-system of packages that already provide us with the basic functionalities. I also suggest that a json logger hooks into @gdey s existing log package, so log levels can be re-used. Defaulting to the current standard logger gives backwards compatibility.
Proposed package: uber/zap
Zap is very mature, well maintained and highly performant while at the same time highly customizable.
Zap comes with sane development and production default settings, but allows to pass your own configuration.
By default timestamps are logged unix timestamps
ts
Passing a config like this:
results in:
That gives alot of power to the user, while also providing basic logs for the user that doesn't really care.
Possible action points:
--logs json|text
with text as defaultisJSON
WDYT? :)
The text was updated successfully, but these errors were encountered: