Skip to content

6.1.0.M1

Pre-release
Pre-release
Compare
Choose a tag to compare
@mp911de mp911de released this 08 Feb 08:35
· 470 commits to main since this release
66c079a

The Lettuce team is delighted to announce the availability of the first Lettuce 6.1 milestone.

This is a massive release thanks to all the community contributions. Most notable changes that ship with this release are:

  • Support for most Redis 6.2 commands and command changes
  • Micrometer integration
  • CommandListeners API to intercept Redis commands
  • extended Keep-Alive options
  • Coroutine variant of ScanStream
  • TCP NoDelay enabled by default
  • Experimental support for io_uring

Lettuce 6 supports Redis 2.6+ up to Redis 6.x. In terms of Java runtime, Lettuce requires at least Java 8 and works with Java 16.

Thanks to all contributors who made Lettuce 6.1.0.M1 possible.

Documentation

Reference documentation: https://lettuce.io/core/6.1.0.M1/reference/
Javadoc: https://lettuce.io/core/6.1.0.M1/api/

Micrometer Integration

Lettuce ships an integration for Micrometer. Commands are tracked by using two Micrometer Times: lettuce.command.firstresponse and lettuce.command.completion. The following tags are attached to each timer:

  • command: Name of the command (GET, SET, …)
  • local: Local socket (localhost/127.0.0.1:45243 or ANY when local distinction is disabled, which is the default behavior)
  • remote: Remote socket (localhost/127.0.0.1:6379)

To enable Micrometer, create MicrometerCommandLatencyRecorder from MeterRegistry and register it in ClientResources:

MeterRegistry meterRegistry = …;
MicrometerOptions options = MicrometerOptions.create();
ClientResources resources = ClientResources.builder().commandLatencyRecorder(new MicrometerCommandLatencyRecorder(meterRegistry, options)).build();

RedisClient client = RedisClient.create(resources);

Make sure to have Micrometer on your class path (example from a Maven pom.xml):

<dependency>
    <groupId>io.micrometer</groupId>
    <artifactId>micrometer-core</artifactId>
    <version>${micrometer.version}</version> <!-- e.g. micrometer.version==1.6.0 -->
</dependency>

See also: https://github.com/lettuce-io/lettuce-core/wiki/Command-Latency-Metrics#command.latency.metrics.micrometer

CommandListeners

Command listeners allow intercepting Redis Command calls before the command is sent and upon completion (success/failure). A CommandListener can be registered with RedisClient and RedisClusterClient:

RedisClient client = …;

client.addListener(new CommandListener() {
    @Override
    public void commandStarted(CommandStartedEvent event) {
        Map<String, Object> context = event.getContext();
        context.put(…);
    }

    @Override
    public void commandSucceeded(CommandSucceededEvent event) {
        Map<String, Object> context = event.getContext();
    }

    @Override
    public void commandFailed(CommandFailedEvent event) {
        CommandListener.super.commandFailed(event);
    }
});


StatefulRedisConnection<String, String> connection = client.connect();

Command events allow attaching contextual details that can be accessed upon completion.

Experimental support for io_uring

We've adopted Netty's experimental io_uring support for Linux-based systems to allow participating in improved I/O performance.

io_uring will be enabled automatically if you're running on Linux and you have the dependency on your classpath:

<dependency>
    <groupId>io.netty.incubator</groupId>
    <artifactId>netty-incubator-transport-native-io_uring</artifactId>
    <version>${netty.transport-native-io_uring.version}</version>
    <classifier>linux-x86_64</classifier>
</dependency>

When having both native transports enabled (io_uring and epoll), then io_uring has precedence over epoll.
We'd love to hear from you how io_uring works out for you.

Commands

  • Add support for SET … GET option #1442
  • Add support for (B)LMOVE source destination LEFT|RIGHT LEFT|RIGHT command #1448
  • Add support for ZMSCORE key member [member ...] command #1449
  • Add support for ZINTER/ZUNION commands #1450
  • Add support for SMISMEMBER key member [member ...] command #1452
  • Support NOMKSTREAM option in XADD command #1502
  • Support option CREATECONSUMER in XGROUP command #1505 (Thanks to @dengliming)
  • Add support for ZRANGESTORE command #1506
  • Add support for ZDIFF and ZDIFFSTORE commands #1507
  • Add support for COPY command #1508
  • Add support for local addr in CLIENT KILL #1536
  • Add support for LPOP and RPOP with COUNT #1545
  • Missing support for TYPE parameter of SCAN command #1559 (Thanks to @mvmn)
  • Add support for GEOSEARCH and GEOSEARCHSTORE #1561
  • Add support for ReadFrom.subnet #1569 (Thanks to @yueki1993)
  • Add exclusive range query to XPENDING #1585
  • Add support for PXAT/EXAT arguments to SET command #1607
  • Add support for ZADD GT/LT options #1451

Enhancements

  • Add Micrometer integration #795
  • Add support for CommandListeners #1382 (Thanks to @sokomishalov)
  • Provide a Coroutine variant of ScanStream/ScanIterator #1435
  • Introduce extended Keep-Alive options #1437
  • Add anyReplica setting for ReadFrom #1444 (Thanks to @omer-cilingir)
  • Option to configure SSL/TLS verification level #1460 (Thanks to @Lucas3oo)
  • netty's asynchronous DNS resolver seems not to be used #1498 (Thanks to @yueki1993)
  • Extend CommandDetailParser to include ACL details #1503
  • Consider reinstating master-replica wording #1518 (Thanks to @perlun)
  • Add support for io_uring #1522
  • Provide VoidOutput for Fire&Forget command usage #1529 (Thanks to @jaredpetersen)
  • Improve unsupported error logging for CommandOutput #1532
  • Allow providing custom ClusterTopologyRefresh implementation. #1598 (Thanks to @alessandrosimi-sa)
  • Introduce LettuceStrings.isEmpty(String) overload with optimized isEmpty checking #1609

Fixes

  • Fix EXEC without MULTI when using coroutines over async #1441 (Thanks to @sokomishalov)
  • Lettuce with Tracing enabled fails to connect to a Redis Sentinel #1470 (Thanks to @jsonwan)
  • Lettuce doesn't handle deleted stream items (NullPointerException) #1474 (Thanks to @chemist777)
  • LettuceStrings does not handle -nan which is returned by FT.INFO in redisearch #1482 (Thanks to @krm1312)
  • Improperly decoding command responses #1512 (Thanks to @johnny-costanzo)
  • Fix timeout parameter for nanoseconds in RedisURI #1528 (Thanks to @izeye)
  • Fix build break when missing netty-dns-resolver #1546 (Thanks to @yueki1993)
  • Sentinel lookup connection leaks if no master address reported #1558 (Thanks to @wwwjinlong)
  • Lettuce 6.0.1 fails with GraalVM 20.3 #1562 (Thanks to @atrianac)
  • Reactive stream spec violation when using command timeout #1576 (Thanks to @martin-tarjanyi)
  • Fix copyright replace bug for Kotlin api generator #1588 (Thanks to @dengliming)
  • FixNullPointerException in BoundedAsyncPool.createIdle() when at capacity #1611

Other

  • Fix integration test password #1445
  • Un-Deprecate io.lettuce.core.LettuceFutures #1453 (Thanks to @andrewsensus)
  • Switch to Flux/Mono.expand(…) for ScanStream #1458
  • Enable TCP NoDelay by default #1462
  • Update contrib guide #1472
  • Adapt tests to changed Redis response #1473
  • Upgrade dependencies #1476
  • Remove JUnit 4 dependency management #1477
  • Replace ClusterRule #1478
  • Remove Redis Command retrieval for Redis Cluster Connections #1481
  • Implement set(double) in NestedMultiOutput #1486 (Thanks to @jruaux)
  • Start HashWheelTimer in ClientResources to avoid blocking calls in EventLoop #1489
  • DefaultClientResources: fix typos #1497 (Thanks to @perlun)
  • API generator problems #1499 (Thanks to @sokomishalov)
  • Reduce build matrix to Java 8, 11, 15, and EA #1519
  • Upgrade to Netty 4.1.54.Final #1541
  • netty 4.1.56 #1556 (Thanks to @sullis)
  • Move Mailing list forum to GitHub discussions #1557
  • Let coroutines dispatch-method be flowable #1567 (Thanks to @sokomishalov)
  • Update copyright years to 2021 #1573
  • Upgrade to netty 4.1.58.Final #1610