-
Notifications
You must be signed in to change notification settings - Fork 182
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
H4HIP: Enhanced logging library for Helm CLI #372
base: main
Are you sure you want to change the base?
Conversation
Signed-off-by: Evans Mungai <[email protected]>
Signed-off-by: Evans Mungai <[email protected]>
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.
I like the path this is going one. But, there are some changes I would like to see.
First, how should we handle structured logging? Right now Helm variable details into many logging strings. Should these be handled as structured logs so that they are easier to query in log searching tools?
Second, handling the logging in the SDK vs the client (and not mixing concerns).
hips/hip-9999.md
Outdated
|
||
## Abstract | ||
|
||
This proposal introduces an improved logging library for Helm CLI to enhance logging capabilities for troubleshooting, development, and debugging. By using newer logging features such as log formatting, different log levels and verbosity levels, developers and CLI users gain flexibility when deciding how much logging information they want to consume, and in what format. |
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.
It might be useful to call out the SDK users and how they can integrate with Helm in a standard way.
hips/hip-9999.md
Outdated
- Troubleshooting Helm CLI commands due to inability to increase the details that can get logged. More logs come in handy when submitting bug reports for example. | ||
- Instrumenting code with clear and consistent logging conventions for contributors, as well as consumers of CLI logs. |
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.
Also, SDK users integrating with Helm have to use Helm's custom logging mechanism. This is an integration problem for users (e.g., Flux)
- Lightweight and straightforward to integrate. | ||
- Is part of the standard library | ||
|
||
2. **`klog`:** |
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.
In addition to klog there is logr, an interface that klog suffices. Can you add that in.
hips/hip-9999.md
Outdated
- Well-aligned with Kubernetes development standards. | ||
- Allows getting instrumented Kubernetes client library. | ||
|
||
While both libraries meet the basic requirements, `klog` offers richer features for developers familiar with Kubernetes' logging patterns, making it the preferred choice for this proposal. |
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.
There are two parts to Helm. There is the SDK and then the client that uses the SDK.
The SDK shouldn't use an implementation of logging. It should accept a logger from any application that uses it and follows the right interface. So, the SDK should use either slog
or logr
. It may have a default one but that needs to be easy to override.
Note, SDK users may not be developers familiar with Kubernetes. There will be people familiar with and those not familiar with it.
Then there is the Helm client (a.k.a CLI). This should pick an implementation. It could be slog, klog, zap, or something else. Note, klog appears to support the slog interface (see this example).
We need to make decisions on both of these. If we go the klog route for the Helm Client we should document the log levels to use and what they mean. There is no common clarity on what levels to use for what. This is one of the weakness of this model. What level should you set for what purposes?
hips/hip-9999.md
Outdated
Two libraries were evaluated: | ||
|
||
1. **`slog`:** | ||
- Provides log levels (`info`, `debug`, `error`, `warning`). |
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.
Note, it's fairly easy to add levels if an app wants to use more. The Go docs provide an example.
Signed-off-by: Evans Mungai <[email protected]>
Signed-off-by: Evans Mungai <[email protected]>
- Helm SDK should not be instrumented with error logs. Instead, errors ought to be returned. Any logging of such errors should be left to clients to choose whether to log or not. | ||
- When invoking plugins and post-renderers, `HELM_LOG_LEVEL` environment variable would be set, allowing them to output the appropriate amount of logs to stderr. | ||
- There will be structured logging with two options. Raw text for humans to view, and JSON formatting that machines can consume. | ||
- Ability for SDK users to override the default logger implementation. The SDK will expect at logger that implements `logr.Logger` interface. |
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.
This means an application that uses the Helm SDK will need to implement the logr.Logger
interface with their logger of choice. For example, an application that uses zap will need to create a conversion mechanism to work with the Helm SDK.
The logr.Logger
interface is not commonly used and I'm aware of numerous applications that use the Helm SDK today but their loggers don't have a conversion mechanism or a native ability to work with logr.Logger
.
This is what draws me to the slog
interface. Just about every logging package either natively works with slog
or has an existing add-on to work with it.
What is the benefit for the SDK to use logr
and to whom?
Note, the CLI can use logr as an implementation even if the SDK uses slog.
No description provided.