A logo showing the text blog.marcnuri.com
Español
Home»Cloud Native»Fabric8 Kubernetes Client 7.8 is now available!

Recent Posts

  • Fabric8 Kubernetes Client 7.8 is now available!
  • Fabric8 Kubernetes Client 7.7 is now available!
  • Superpowers: The Claude Code Skills Framework Shipped as Markdown
  • The Missing Levels of AI-Assisted Development: From Agent Chaos to Orchestration
  • Promoted to Senior Principal Software Engineer at Red Hat

Categories

  • Artificial Intelligence
  • Backend Development
  • Cloud Native
  • Engineering Insights
  • Frontend Development
  • JavaScript
  • Legacy
  • Operations
  • Personal
  • Pet projects
  • Quality Engineering
  • Tools

Archives

  • June 2026
  • May 2026
  • April 2026
  • March 2026
  • February 2026
  • January 2026
  • December 2025
  • October 2025
  • September 2025
  • July 2025
  • May 2025
  • April 2025
  • March 2025
  • February 2025
  • January 2025
  • December 2024
  • November 2024
  • August 2024
  • June 2024
  • May 2024
  • April 2024
  • March 2024
  • February 2024
  • January 2024
  • December 2023
  • November 2023
  • October 2023
  • September 2023
  • August 2023
  • July 2023
  • June 2023
  • May 2023
  • April 2023
  • March 2023
  • February 2023
  • January 2023
  • December 2022
  • November 2022
  • October 2022
  • September 2022
  • August 2022
  • July 2022
  • June 2022
  • May 2022
  • March 2022
  • February 2022
  • January 2022
  • December 2021
  • November 2021
  • October 2021
  • September 2021
  • August 2021
  • July 2021
  • January 2021
  • December 2020
  • November 2020
  • October 2020
  • September 2020
  • August 2020
  • July 2020
  • June 2020
  • May 2020
  • March 2020
  • February 2020
  • January 2020
  • December 2019
  • November 2019
  • October 2019
  • September 2019
  • July 2019
  • March 2019
  • November 2018
  • July 2018
  • June 2018
  • May 2018
  • April 2018
  • March 2018
  • February 2018
  • December 2017
  • October 2017
  • August 2017
  • July 2017
  • January 2017
  • May 2016
  • December 2015
  • November 2015
  • December 2014
  • November 2014
  • October 2014
  • March 2014
  • February 2011
  • November 2008
  • June 2008
  • May 2008
  • April 2008
  • January 2008
  • November 2007
  • September 2007
  • August 2007
  • July 2007
  • June 2007
  • May 2007
  • April 2007
  • March 2007

Fabric8 Kubernetes Client 7.8 is now available!

2026-06-29 in Cloud Native tagged Client / Cloud / Fabric8 / Java / Kubernetes / Open Source / OpenShift / Releases by Marc Nuri | Last updated: 2026-06-29
Versión en Español

On behalf of the Fabric8 team and everyone who has contributed, I'm happy to announce that the Fabric8 Kubernetes Client 7.8.0 has been released and is now available from Maven Central 🎉.

This marks the eighth minor release of the Fabric8 Kubernetes Client 7, bringing new features, bug fixes, and improvements while keeping the breaking changes minimal.

Thanks to all of you who have contributed with issue reports, pull requests, feedback, and spreading the word with blogs, videos, comments, and so on. We really appreciate your help, keep it up!

What's new?

Without further ado, let's have a look at the most significant updates:

  • Shard selectors for list, watch and informers
  • Opt-in TLS warm-up for the Vert.x HTTP client
  • CRD generator: class-level descriptions via @JsonClassDescription
  • 🐛 Many other bug fixes and minor improvements

You can find the full changelog for this version in our GitHub release page.

Shard selectors for list, watch and informers

List and watch operations, including informers, now support shard selectors through the new withShardSelector method. This lets you partition a large set of resources across multiple consumers, so each instance only lists and watches the slice it is responsible for. It's a handy building block when you need to scale controllers or operators horizontally and distribute the watch load, instead of having every instance receive every event.

A shard selector is a CEL expression, typically a shardRange(...) over the resource UID, that you attach to any list, watch, inform or delete operation:

try (KubernetesClient client = new KubernetesClientBuilder().build()) {
  // This instance only sees the first half of the UID space
  String shard = "shardRange(object.metadata.uid, '0x0000000000000000', '0x8000000000000000')";
  client.configMaps()
    .withShardSelector(shard)
    .inform(handler);
}

Note that this relies on the server-side sharded list and watch support, an alpha Kubernetes feature, so the corresponding feature gate must be enabled on your cluster. The initial support was rounded out with a few follow-ups to smooth out the rough edges.

Opt-in TLS warm-up for the Vert.x HTTP client

The Vert.x HTTP client factories (Vertx5HttpClientFactory and VertxHttpClientFactory) now expose a setTlsWarmup(TlsWarmup) method with three modes: OFF, CONTEXT (the default, with unchanged behaviour) and FULL.

When set to FULL, the client performs a synchronous, once-per-JVM, throwaway loopback TLS handshake off the event loop when it's built. This pays the one-time cost of JDK/Netty TLS class loading up front, so the first real connection no longer blocks the event loop on it. It's specifically aimed at users running on cold or hard CPU-throttled JVMs who were hitting first-connection stalls or timeouts.

You opt in by configuring the warm-up mode on the HTTP client factory and passing it to the builder:

Vertx5HttpClientFactory factory = new Vertx5HttpClientFactory();
factory.setTlsWarmup(TlsWarmup.FULL);
try (KubernetesClient client = new KubernetesClientBuilder()
    .withHttpClientFactory(factory)
    .build()) {
  // The first TLS connection no longer pays the class-loading cost on the event loop
}

The default behaviour (CONTEXT) is unchanged, so you only opt in if you need it.

CRD generator: class-level descriptions via @JsonClassDescription

The CRD generator now honors Jackson's @JsonClassDescription annotation, allowing you to add descriptions to whole classes in the generated CRD schema. This complements the existing field-level description support, so the documentation embedded in your CRDs can be more complete and closer to your source model.

Using this release

If your project is based on Maven, you just need to add the Fabric8 Kubernetes Client to your Maven dependencies:

pom.xml
<dependency>
  <groupId>io.fabric8</groupId>
  <artifactId>kubernetes-client</artifactId>
  <version>7.8.0</version>
</dependency>

If your project is based on Gradle, you just need to add the Fabric8 Kubernetes Client to your Gradle dependencies:

build.gradle
dependencies {
  api "io.fabric8:kubernetes-client:7.8.0"
}

Once your project is ready, you can create a new instance of the client to perform operations. In the following code snippet, I show you how to instantiate the client and retrieve a list of Pods:

try (KubernetesClient client = new KubernetesClientBuilder().build()) {
  client.pods().list().getItems().forEach(p -> System.out.println(p.getMetadata().getName()));
}

How can you help?

If you're interested in helping out and are a first-time contributor, check out the "good first issue" tag in the issue repository. We've tagged extremely easy issues so that you can get started contributing to Open Source.

We're also excited to read articles and posts mentioning our project and sharing the user experience. Giving a star to the project, and spreading the word in general, helps us reach more users and broaden the feedback. Feedback is the only way to improve.

Project Page | Issues | Discussions | Gitter | Stack Overflow

The logo of Fabric8 Kubernetes Client
The logo of Fabric8 Kubernetes Client
Twitter iconFacebook iconLinkedIn iconPinterest iconEmail icon

Post navigation
Fabric8 Kubernetes Client 7.7 is now available!
© 2007 - 2026 Marc Nuri