containerized-data-importer/vendor/k8s.io/klog/v2
Alex Kalenyuk b2bd873d77
update k8s & related libraries to 1.31 (#3625)
* Bump k8s/OpenShift/ctrl-runtime & make deps-update

Signed-off-by: Alex Kalenyuk <akalenyu@redhat.com>

* operator: fix prometheus API bool->*bool change

Signed-off-by: Alex Kalenyuk <akalenyu@redhat.com>

* certrotation: pass signer ns/name according to API change

Signed-off-by: Alex Kalenyuk <akalenyu@redhat.com>

* certrotation: adapt by passing clock through API

Signed-off-by: Alex Kalenyuk <akalenyu@redhat.com>

* certrotation: create empty secret with type tls

Brace yourself for a rollercoaster:
https://github.com/openshift/library-go/blob/release-4.18/pkg/operator/resource/resourceapply/core.go#L452
this path is no longer used since recent library-go.

We should be okay since the versions upgrading to this CDI
have a secret that was converted to the TLS type

Signed-off-by: Alex Kalenyuk <akalenyu@redhat.com>

* certrotation: adapt to unit tests failing on secret create

context https://github.com/openshift/library-go/pull/1772

Signed-off-by: Alex Kalenyuk <akalenyu@redhat.com>

* Revert "handle "already exists" when certrotation creates secret"

This reverts commit 9acaa19d37.

Signed-off-by: Alex Kalenyuk <akalenyu@redhat.com>

---------

Signed-off-by: Alex Kalenyuk <akalenyu@redhat.com>
2025-02-24 20:24:44 +01:00
..
internal update to k8s 1.30 libs and controller-runtime 0.18.4 (#3336) 2024-07-14 20:12:50 +02:00
.gitignore update k8s deps to 18.6 and controller runtime to 0.6.2 (#1330) 2020-08-07 14:09:52 +02:00
.golangci.yaml update to k8s 1.30 libs and controller-runtime 0.18.4 (#3336) 2024-07-14 20:12:50 +02:00
BUILD.bazel update to k8s 1.30 libs and controller-runtime 0.18.4 (#3336) 2024-07-14 20:12:50 +02:00
code-of-conduct.md update k8s deps to 18.6 and controller runtime to 0.6.2 (#1330) 2020-08-07 14:09:52 +02:00
contextual_slog.go update to k8s 1.30 libs and controller-runtime 0.18.4 (#3336) 2024-07-14 20:12:50 +02:00
contextual.go update k8s libs to 1.26. (#2687) 2023-04-18 19:30:40 +01:00
CONTRIBUTING.md update k8s deps to 18.6 and controller runtime to 0.6.2 (#1330) 2020-08-07 14:09:52 +02:00
exit.go update k8s libs to 1.26. (#2687) 2023-04-18 19:30:40 +01:00
format.go Update golang to 1.20.7 (#2884) 2023-09-03 18:23:35 +02:00
imports.go update k8s libs to 1.26. (#2687) 2023-04-18 19:30:40 +01:00
k8s_references_slog.go update to k8s 1.30 libs and controller-runtime 0.18.4 (#3336) 2024-07-14 20:12:50 +02:00
k8s_references.go Update golang to 1.20.7 (#2884) 2023-09-03 18:23:35 +02:00
klog_file_others.go update k8s libs to 1.26. (#2687) 2023-04-18 19:30:40 +01:00
klog_file_windows.go update k8s libs to 1.26. (#2687) 2023-04-18 19:30:40 +01:00
klog_file.go update to k8s 1.30 libs and controller-runtime 0.18.4 (#3336) 2024-07-14 20:12:50 +02:00
klog.go update k8s & related libraries to 1.31 (#3625) 2025-02-24 20:24:44 +01:00
klogr_slog.go update to k8s 1.30 libs and controller-runtime 0.18.4 (#3336) 2024-07-14 20:12:50 +02:00
klogr.go update to k8s 1.30 libs and controller-runtime 0.18.4 (#3336) 2024-07-14 20:12:50 +02:00
LICENSE update k8s deps to 18.6 and controller runtime to 0.6.2 (#1330) 2020-08-07 14:09:52 +02:00
OWNERS update to k8s 1.30 libs and controller-runtime 0.18.4 (#3336) 2024-07-14 20:12:50 +02:00
README.md update k8s libs to 1.26. (#2687) 2023-04-18 19:30:40 +01:00
RELEASE.md update k8s deps to 18.6 and controller runtime to 0.6.2 (#1330) 2020-08-07 14:09:52 +02:00
safeptr.go update to k8s 1.30 libs and controller-runtime 0.18.4 (#3336) 2024-07-14 20:12:50 +02:00
SECURITY_CONTACTS update k8s deps to 18.6 and controller runtime to 0.6.2 (#1330) 2020-08-07 14:09:52 +02:00
SECURITY.md update deps and bazel (#1815) 2021-06-08 01:31:59 +02:00

klog

klog is a permanent fork of https://github.com/golang/glog.

Why was klog created?

The decision to create klog was one that wasn't made lightly, but it was necessary due to some drawbacks that are present in glog. Ultimately, the fork was created due to glog not being under active development; this can be seen in the glog README:

The code in this repo [...] is not itself under development

This makes us unable to solve many use cases without a fork. The factors that contributed to needing feature development are listed below:

  • glog presents a lot "gotchas" and introduces challenges in containerized environments, all of which aren't well documented.
  • glog doesn't provide an easy way to test logs, which detracts from the stability of software using it
  • A long term goal is to implement a logging interface that allows us to add context, change output format, etc.

Historical context is available here:

Release versioning

Semantic versioning is used in this repository. It contains several Go modules with different levels of stability:

  • k8s.io/klog/v2 - stable API, vX.Y.Z tags
  • examples - no stable API, no tags, no intention to ever stabilize

Exempt from the API stability guarantee are items (packages, functions, etc.) which are marked explicitly as EXPERIMENTAL in their docs comment. Those may still change in incompatible ways or get removed entirely. This can only be used for code that is used in tests to avoid situations where non-test code from two different Kubernetes dependencies depends on incompatible releases of klog because an experimental API was changed.


How to use klog

  • Replace imports for "github.com/golang/glog" with "k8s.io/klog/v2"
  • Use klog.InitFlags(nil) explicitly for initializing global flags as we no longer use init() method to register the flags
  • You can now use log_file instead of log_dir for logging to a single file (See examples/log_file/usage_log_file.go)
  • If you want to redirect everything logged using klog somewhere else (say syslog!), you can use klog.SetOutput() method and supply a io.Writer. (See examples/set_output/usage_set_output.go)
  • For more logging conventions (See Logging Conventions)
  • See our documentation on pkg.go.dev/k8s.io.

NOTE: please use the newer go versions that support semantic import versioning in modules, ideally go 1.11.4 or greater.

Coexisting with klog/v2

See this example to see how to coexist with both klog/v1 and klog/v2.

Coexisting with glog

This package can be used side by side with glog. This example shows how to initialize and synchronize flags from the global flag.CommandLine FlagSet. In addition, the example makes use of stderr as combined output by setting alsologtostderr (or logtostderr) to true.

Community, discussion, contribution, and support

Learn how to engage with the Kubernetes community on the community page.

You can reach the maintainers of this project at:

Code of conduct

Participation in the Kubernetes community is governed by the Kubernetes Code of Conduct.


glog

Leveled execution logs for Go.

This is an efficient pure Go implementation of leveled logs in the manner of the open source C++ package https://github.com/google/glog

By binding methods to booleans it is possible to use the log package without paying the expense of evaluating the arguments to the log. Through the -vmodule flag, the package also provides fine-grained control over logging at the file level.

The comment from glog.go introduces the ideas:

Package glog implements logging analogous to the Google-internal
C++ INFO/ERROR/V setup.  It provides functions Info, Warning,
Error, Fatal, plus formatting variants such as Infof. It
also provides V-style logging controlled by the -v and
-vmodule=file=2 flags.

Basic examples:

	glog.Info("Prepare to repel boarders")

	glog.Fatalf("Initialization failed: %s", err)

See the documentation of the V function for an explanation
of these examples:

	if glog.V(2) {
		glog.Info("Starting transaction...")
	}

	glog.V(2).Infoln("Processed", nItems, "elements")

The repository contains an open source version of the log package used inside Google. The master copy of the source lives inside Google, not here. The code in this repo is for export only and is not itself under development. Feature requests will be ignored.

Send bug reports to golang-nuts@googlegroups.com.