Releases: kubernetes-sigs/controller-runtime
v0.16.3
What's Changed
- 🐛Update dependency go-restful to 3.11.0 by @k8s-infra-cherrypick-robot in #2516
- 🐛 Correctly identify if patch call was made on status by @k8s-infra-cherrypick-robot in #2515
- 🐛 Handle unstructured status update with fake client by @troy0820 in #2523
- ✨ Cache: Allow defining options that apply to all namespaces that themselves have no explicit config by @k8s-infra-cherrypick-robot in #2539
- 🐛 bump golang.org/x/net to v0.17.0 by @joelanford in #2541
- 🌱 Bump k8s to 1.28.3 by @varshaprasad96 in #2552
Full Changelog: v0.16.2...v0.16.3
v0.16.2
What's Changed
- 🐛 Add corev1, coordinationv1 scheme for leader election when LeaderElection manager option is true by @troy0820 in #2466
- 🐛 Use http client from leaderElectionConfig by @k8s-infra-cherrypick-robot in #2468
- 🐛 Default namespace only for namespaced object by @k8s-infra-cherrypick-robot in #2482
- 🐛 Do not update anything but status when using subresource client by @k8s-infra-cherrypick-robot in #2483
- 🐛 Fix status subresource getting updated on Update when it is empty by @k8s-infra-cherrypick-robot in #2485
- 🐛 Fix returning object after status update by @k8s-infra-cherrypick-robot in #2490
- 🐛 Return NoResourceMatchError when appropriate for backwards compatibility. by @k8s-infra-cherrypick-robot in #2492
Full Changelog: v0.16.1...v0.16.2
v0.16.1
What's Changed
- 🐛 Refactor tests to drop hard otel dependency by @howardjohn in #2465
- 🌱 Bump k8s.io/apiserver from 0.28.0 to 0.28.1 by @k8s-infra-cherrypick-robot in #2459
Full Changelog: v0.16.0...v0.16.1
v0.16.0
Highlights
- Granular cache configuration (#2421)
- New cache option to fail on missing informer on cache reads (#2406)
- Secure metrics serving (#2407)
- Upgrade to Kubernetes 1.28 libraries (#2393, #2405, #2449)
Changes since v0.15
⚠️ Breaking Changes
- Bump k8s.io/* dependencies to v1.28.0 by @sbueringer (#2393, #2405, #2449)
- Allow configuring more granular cache filtering by @alvaroaleman (#2421)
- Introduce Metrics Options & secure metrics serving by @sbueringer (#2407)
- Return an error if the continue list option is set for the cache reader by @shuheiktgw (#2439)
- Remove deprecated manager, webhook and cluster options by @sbueringer (#2422)
- Remove deprecated MultiNamespacedCacheBuilder, NewFakeClientWithScheme, controllerutil.Object, envtest.Environment.KubeAPIServerFlags & zap.Options.DestWritter by @sbueringer (#2423)
- controller builder: return error when multiple reconcilers are set by @sbueringer (#2415)
- fake client: use correct RBAC apiGroup name when deciding if to allow unconditional updates by @jaideepr97 (#2412)
- Minor improvements to godoc & code style in cache pkg by @sbueringer (#2416)
✨ New Features
- Cache: add ReaderFailOnMissingInformer option by @stevekuznetsov (#2406)
- Cache: allow non-blocking retrieval of informers by @maxsmythe (#2371)
🐛 Bug Fixes
- Add missing return statement in admission.Decoder.DecodeRaw by @lleshchi (#2433)
- fakeClient.Status().Update(...) cannot recognize resource version conflicts by @iiiceoo (#2365)
- Fix Defaulting of the User Agent by @alvaroaleman (#2435)
- Fix logs in the unstructured client by @Poor12 (#2343)
- Fix unspecified KindsFor version by @tenstad (#2346)
- Fix TerminalError(nil).Error() panic by @sheidkamp (#2438)
- hasLabels and matchingLabels step on each other by @shanshanying (#2363)
- SetLogger should work with nil sinks by @vincepri (#2367)
🌱 Others
- Use NewRateLimitingQueueWithConfig instead of deprecated NewNamedRateLimitingQueue by @sbueringer (#2411)
- Add a prefix to the stack trace printed after SetLogger timeout by @vincepri (#2357)
- Minor improvements to godoc, code style in builder pkg by @sbueringer (#2414)
- Add integration test to avoid manager.Start deadlocks by @sbueringer (#2418)
- Automatically regenerate scratch env go mod file by @sbueringer (#2413)
- Introduce a new runnable group for basic servers of the manager by @zqzten (#2337)
- Add logs around Reconcile call, change webhook logs to log level 5 by @sbueringer (#2419)
- Add action to update modules on dependabot PRs by @sbueringer (#2447, #2448)
- Optimize Add/RemoveFinalizer by @0xff-dev (#2348)
- Log warning if error and non-zero Result are returned by @sbueringer (#2451)
📖 Documentation and proposals
- Add a design for cache options configuration by @alvaroaleman (#2261)
- Add documentation to clarify the ContentType behavior by @FillZpp (#2410)
- Clarify that the reconcile.Result is ignored on non-nil error by @alvaroaleman (#2444)
- Fix typo "compatiblity" to "compatibility" by @ArshiAAkhavan (#2396)
- Update fake client doc.go to avoid the deprecated method by @sunglim (#2392)
📈 Dependencies
- Bump k8s.io/klog/v2 from 2.90.1 to 2.100.1 by @dependabot (#2294)
- Bump github.com/onsi/ginkgo/v2 from 2.9.5 to 2.11.0 by @dependabot (#2368, #2376, #2384)
- Bump github.com/onsi/gomega from 1.27.7 to 1.27.8 by @dependabot (#2375, #2420)
- Bump github.com/prometheus/client_golang from 1.15.1 to 1.16.0 by @dependabot (#2383)
- Bump golang.org/x/sys from 0.8.0 to 0.11.0 by @dependabot (#2377, #2401, #2441)
- Bump gomodules.xyz/jsonpatch/v2 from 2.3.0 to 2.4.0 by @dependabot (#2446)
- Bump go.uber.org/zap from 1.24.0 to 1.25.0 by @dependabot (#2440)
- Bump golangci-lint to v1.53 by @vincepri (#2398)
- Bump controller-tools to v0.13 by @sbueringer (#2450)
Thanks to all our contributors! 😊
Full Changelog: v0.15.0...v0.16.0
v0.15.2
What's Changed
- 🐛 Fix TerminalError(nil).Error() panic by @sheidkamp in #2443
- 🐛 Add missing return statement in the webhook admissions func by @k8s-infra-cherrypick-robot in #2452
Full Changelog: v0.15.1...v0.15.2
v0.15.1
What's Changed
- [release-0.15] ✨Fix logs in unstructured client by @k8s-infra-cherrypick-robot in #2344
- [release-0.15] 🐛 fix unspecified KindsFor version by @k8s-infra-cherrypick-robot in #2347
- [release-0.15] 🐛 fakeClient.Status().Update(...) cannot recognize resource version conflicts by @k8s-infra-cherrypick-robot in #2372
- [release-0.15] 🐛 hasLabels and matchingLabels step on each other by @k8s-infra-cherrypick-robot in #2373
- [release-0.15] 🐛 Fix Defaulting of the User Agent by @alvaroaleman in #2436
Full Changelog: v0.15.0...v0.15.1
v0.15.0
Controller Runtime v0.15
A note from the maintainers
The following release is probably the largest in the history of the project. Controller Runtime is a foundational piece for almost all controllers and operators and we're aware that breaking changes are never an ask for our users, especially while running production services.
We take breaking changes very seriously and carefully reviewed each one of these changes to improve the codebase, user experience, and future maintainability of the project.
The v0.15 release is a stepping stone towards maturity.
As always, please reach out in Slack in #controller-runtime.
Changes since v0.14.5
⚠️ Breaking Changes
- Make
*http.Client
configurable and use/share the same client by default (#2122)- When using the default Manager configuration, no immediate changes are needed.
client/apiutil.NewDynamicRESTMapper
signature has changed and now requires an*http.Client
as parameter.cluster.Cluster
interface requiresGetHTTPClient()
method which must return an already configured, non-nil,*http.Client
for the Cluster. When usingcluster.New
to create Clusters, the client is created internally if not specified as anOptions
field.cluster.Options.MapperProvider
field now requires a*rest.Config
and*http.Client
.
- Deprecate Component Configuration
config/v1alpha1
types (#2149, #2200)- The Component Configuration package has been unmaintained for over a year and is no longer actively developed. There are (currently) no plans to revive the package, or provide an alternative.
- Users should migrate to a custom implementation that sets
Manager.Options
directly. - 👉 Feedback requested: removal of the deprecated types and code is tracked in #895.
- Remove dependency injection functions (#2134, #2120)
- The package
pkg/inject
has been removed, this package contained long deprecated injection functions (likeInjectScheme
,InjectLogger
,InjectConfig
,InjectClient
,InjectCache
, etc.). - The runtime injection functionality has been deprecated since Controller Runtime 0.10; all of the above fields can be passed from the
Manager
to structs or interfaces that need them.
- The package
- Improve
builder
package capabilities and general UX (#2135)builder.Builder.Watches
signature has changed, it now takes aclient.Object
instead of asource.Source
as first argument.- For
source.Source
, useWatchesRawSource
.
- For
builder.Builder.WatchesMetadata
has been added to simplify watchingPartialObjectMetadata
objects.
- Refactor cache.Options, deprecate MultiNamespacedCacheBuilder (#2157, #2166)
cache.Options.Namespace
has been removed in favor ofcache.Options.Namespaces
, a slice.cache.Options.Resync
has been renamed toSyncPeriod
.cache.Options.DefaultSelector
has been removed and split in two fields:cache.Options.DefaultLabelSelector
cache.Options.DefaultFieldSelector
cache.Options.DefaultTransform
was added to provide a global transform function.cache.Options.UnsafeDisableDeepCopy
was added to provide a global toggle to disable DeepCopy of the objects from the cache before returning them to clients.- The following
[..]ByObject
field have been refactored:cache.Options.SelectorsByObject
has been removed, usecache.Options.ByObject[Object].Field
andcache.Options.ByObject[Object].Label
cache.Options.UnsafeDisableDeepCopyByObject
has been removed, usecache.Options.ByObject[Object].UnsafeDisableDeepCopy
.cache.Options.TransformByObject
has been removed, usecache.Options.ByObject[Object].Transform
.
cache.ObjectAll
has been removed. This type was previously used to set selectors or transformation functions for every object, use the newly introduced default global options instead.
- Add context to EventHandler(s) (#2139)
handler.EventHandler
andhandler.Funcs
interfaces requirecontext.Context
as the first parameter for every method.handler.MapFunc
signature has changed and now requires acontext.Context
.
- Add client.{GroupVersionKindFor, IsObjectNamespaced} (#2136)
- The
client.Client
interface now requires and exposes these helper functions:GroupVersionKindFor(Object)
which returns theschema.GroupVersionKind
for the object.IsObjectNamespaced(Object)
which returnstrue
if the object's GroupVersionKind is namespaced, orfalse
for global ones.
- The
- Remove DelegatedClient, move all related options in
client.New
(#2150)client.NewDelegatingClient
constructor andclient.NewDelegatingClientInput
struct have been removed.- The DelegatingClient created a Client backed by a cache, use
client.New
and setclient.Options.Cache
to customize the client's caching behavior.
- The DelegatingClient created a Client backed by a cache, use
cluster.NewClientFunc
has been moved toclient.NewClientFunc
.cluster.ClientOptions
has been removed.cluster.DefaultNewClient
has been removed.cluster.ClientBuilderWithOptions
has been removed.
- Expose Manager.Cache/Client options, deprecate older options (#2199, #2177)
manager.Options.Cache
is now the preferred way to customize the cache options for the manager.- Users can also keep using
manager.Options.NewCache
, which has now been marked as a low level primitive.
- Users can also keep using
manager.Options.Client
is now the preferred way to customize the client options for the manager.- Users can also keep using
manager.Options.NewClient
, which has now been marked as a low level primitive.
- Users can also keep using
manager.Options.SyncPeriod
has been deprecated in favor ofmanager.Options.Cache.SyncPeriod
.manager.Options.Namespace
has been deprecated in favor ofmanager.Options.Cache.Namespaces
.manager.Options.DryRunClient
has been deprecated in favor ofmanager.Options.Client.DryRun
.manager.Options.ClientDisableCacheFor
has been deprecated in favor ofmanager.Options.Client.Cache.DisableCacheFor
.- The following webhook server options have been deprecated, use
manager.WebhookServer
instead.manager.Options.Port
manager.Options.Host
manager.Options.CertDir
manager.Options.TLSOpts
- Remove
cache.BuilderWithOptions
(#2300) - Add constructors for
webhook/conversion
, removewebhook/admission.GetDecoder()
(#2144)- There are two set of changes related to the webhooks and how they're exposed. For users using the Manager, there should be minimal to no required changes.
webhook/admission/Webhook.GetDecoder()
method has been removed, it was unused before and relied on runtime dependency injection.webhook/conversion.Webhook
struct has been un-exported. Users should usewebhook/conversion.NewWebhookHandler
instead.
pkg/webhook/admission
:- Testing: Fake client status handling (#2259)
- Added a new
WithStatusSubresource
option and pre-populating it with
all in-tree resources that have a status subresource Update
andPatch
methods now don't change the status for any such
resource anymore- The status clients
Update
andPatch
methods now only change the status
for any such resource
- Added a new
- Remove high cardinality metrics (#2217, #2298)
rest_client_request_latency_seconds
rest_client_request_duration_seconds
rest_client_request_size_bytes
rest_client_response_size_bytes
- Allow passing a custom webhook server (#2293, #2329)
- The
webhook.Server
struct is now an interface webhook.NewServer
can be used to pass in and customize the default server
- The
- Flatten fields in controller.Options (#2307)
- Update fake client deletionTimestamp behavior (#2316)
- The fake client will panic if initialized with an object that has a DeletionTimestamp and no finalizer
- The fake client will silently ignore a DeletionTimestamp on an object in a Create request, matching the behavior of the kube-apiserver
- Unexport delegating logger, remove async init (#2317)
log.DelegatingLogSink
has been unexported, this logger should never be used on its own, and it's only meant to be used within controller-runtime initialization process.- Previously, when the
pkg/log
package was imported, there was aninit
function that spawned a goroutine, which set a null logger after 30 seconds. Now this logic has been removed, and instead incorporated into the delegating logger private implementation.
- Change webhook request received / response written logs to log level 4 (#2334)
- Use and offer a single dynamic lazy RESTMapper (#2116, #2296)
- The following options have been removed:
WithCustomMapper
,WithExperimentalLazyMapper
,WithLazyDiscovery
,WithLimiter
. - The
DynamicRESTMapperOption
type has been removed.
- The following options have been removed:
✨ New Features
- Add cross-version compatibility with client-go 1.27 (#2223)
- Introduce pprof server to manager (#1943)
- To enable, use
Manager.Options.PprofBindAddress
.
- To enable, use
- Added interceptor client to intercept calls to a client (#2248 #2306)
- Add
reconcile.TerminalError(...)
(#2325)- By wrapping an error with the above package-level function, the controller won't retry the request again in an exponential backoff loop.
- The error is logged, and the
controller_runtime_terminal_reconcile_errors_total
metric is incremented.
🐛 Bug Fixes
v0.14.6
What's Changed
- 🐛 Preserve unstructured object GVKs when using *ByObject cache options by @joelanford in #2249
Full Changelog: v0.14.5...v0.14.6
v0.14.5
What's Changed
- 🐛 Allow to set GracefulShutdownTimeout to -1, disabling timeouts in #2198
- 🌱 GVKForObject should handle multiple GVKs in Scheme gracefully in #2202
- ✨ Add rest client request duration and size metrics in #2218
- 🐛 Allow lazy restmapper to work with CRDs created at runtime in #2219
Full Changelog: v0.14.4...v0.14.5
v0.14.4
What's Changed
- ✨ Provide a truly lazy restmapper by @k8s-infra-cherrypick-robot in #2179
Full Changelog: v0.14.3...v0.14.4