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

H4HIP: Enhanced logging library for Helm CLI #372

Open
wants to merge 4 commits into
base: main
Choose a base branch
from

Conversation

banjoh
Copy link
Contributor

@banjoh banjoh commented Nov 27, 2024

No description provided.

Signed-off-by: Evans Mungai <[email protected]>
Copy link
Contributor

@mattfarina mattfarina left a 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.
Copy link
Contributor

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
Comment on lines 18 to 19
- 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.
Copy link
Contributor

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`:**
Copy link
Contributor

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.
Copy link
Contributor

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`).
Copy link
Contributor

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.

- 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.
Copy link
Contributor

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.

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.

2 participants