Skip to content

Commit 895fbd7

Browse files
committed
Merge pull request #40484 from SOOHYUN-LIM
* gh-40484: Polish "Add a customizer for Lettuce's ClientOptions" Add a customizer for Lettuce's ClientOptions Closes gh-40484
2 parents 4f6860f + 1dfb4c9 commit 895fbd7

File tree

4 files changed

+74
-14
lines changed

4 files changed

+74
-14
lines changed

spring-boot-project/spring-boot-autoconfigure/src/main/java/org/springframework/boot/autoconfigure/data/redis/LettuceClientConfigurationBuilderCustomizer.java

+4-2
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,5 @@
11
/*
2-
* Copyright 2012-2023 the original author or authors.
2+
* Copyright 2012-2024 the original author or authors.
33
*
44
* Licensed under the Apache License, Version 2.0 (the "License");
55
* you may not use this file except in compliance with the License.
@@ -23,7 +23,9 @@
2323
* Callback interface that can be implemented by beans wishing to customize the
2424
* {@link LettuceClientConfiguration} through a {@link LettuceClientConfigurationBuilder
2525
* LettuceClientConfiguration.LettuceClientConfigurationBuilder} whilst retaining default
26-
* auto-configuration.
26+
* auto-configuration. To customize only the
27+
* {@link LettuceClientConfiguration#getClientOptions() client options} of the
28+
* configuration, use {@link LettuceClientOptionsBuilderCustomizer} instead.
2729
*
2830
* @author Mark Paluch
2931
* @since 2.0.0
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,42 @@
1+
/*
2+
* Copyright 2012-2024 the original author or authors.
3+
*
4+
* Licensed under the Apache License, Version 2.0 (the "License");
5+
* you may not use this file except in compliance with the License.
6+
* You may obtain a copy of the License at
7+
*
8+
* https://www.apache.org/licenses/LICENSE-2.0
9+
*
10+
* Unless required by applicable law or agreed to in writing, software
11+
* distributed under the License is distributed on an "AS IS" BASIS,
12+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13+
* See the License for the specific language governing permissions and
14+
* limitations under the License.
15+
*/
16+
17+
package org.springframework.boot.autoconfigure.data.redis;
18+
19+
import io.lettuce.core.ClientOptions;
20+
import io.lettuce.core.ClientOptions.Builder;
21+
22+
import org.springframework.data.redis.connection.lettuce.LettuceClientConfiguration;
23+
24+
/**
25+
* Callback interface that can be implemented by beans wishing to customize the
26+
* {@link ClientOptions} of the {@link LettuceClientConfiguration} through a
27+
* {@link Builder} whilst retaining default auto-configuration. To customize the entire
28+
* configuration, use {@link LettuceClientConfigurationBuilderCustomizer} instead.
29+
*
30+
* @author Soohyun Lim
31+
* @since 3.4.0
32+
*/
33+
@FunctionalInterface
34+
public interface LettuceClientOptionsBuilderCustomizer {
35+
36+
/**
37+
* Customize the {@link Builder}.
38+
* @param clientOptionsBuilder the builder to customize
39+
*/
40+
void customize(Builder clientOptionsBuilder);
41+
42+
}

spring-boot-project/spring-boot-autoconfigure/src/main/java/org/springframework/boot/autoconfigure/data/redis/LettuceConnectionConfiguration.java

+21-12
Original file line numberDiff line numberDiff line change
@@ -88,29 +88,34 @@ DefaultClientResources lettuceClientResources(ObjectProvider<ClientResourcesBuil
8888
@ConditionalOnMissingBean(RedisConnectionFactory.class)
8989
@ConditionalOnThreading(Threading.PLATFORM)
9090
LettuceConnectionFactory redisConnectionFactory(
91-
ObjectProvider<LettuceClientConfigurationBuilderCustomizer> builderCustomizers,
91+
ObjectProvider<LettuceClientConfigurationBuilderCustomizer> clientConfigurationBuilderCustomizers,
92+
ObjectProvider<LettuceClientOptionsBuilderCustomizer> clientOptionsBuilderCustomizers,
9293
ClientResources clientResources) {
93-
return createConnectionFactory(builderCustomizers, clientResources);
94+
return createConnectionFactory(clientConfigurationBuilderCustomizers, clientOptionsBuilderCustomizers,
95+
clientResources);
9496
}
9597

9698
@Bean
9799
@ConditionalOnMissingBean(RedisConnectionFactory.class)
98100
@ConditionalOnThreading(Threading.VIRTUAL)
99101
LettuceConnectionFactory redisConnectionFactoryVirtualThreads(
100-
ObjectProvider<LettuceClientConfigurationBuilderCustomizer> builderCustomizers,
102+
ObjectProvider<LettuceClientConfigurationBuilderCustomizer> clientConfigurationBuilderCustomizers,
103+
ObjectProvider<LettuceClientOptionsBuilderCustomizer> clientOptionsBuilderCustomizers,
101104
ClientResources clientResources) {
102-
LettuceConnectionFactory factory = createConnectionFactory(builderCustomizers, clientResources);
105+
LettuceConnectionFactory factory = createConnectionFactory(clientConfigurationBuilderCustomizers,
106+
clientOptionsBuilderCustomizers, clientResources);
103107
SimpleAsyncTaskExecutor executor = new SimpleAsyncTaskExecutor("redis-");
104108
executor.setVirtualThreads(true);
105109
factory.setExecutor(executor);
106110
return factory;
107111
}
108112

109113
private LettuceConnectionFactory createConnectionFactory(
110-
ObjectProvider<LettuceClientConfigurationBuilderCustomizer> builderCustomizers,
114+
ObjectProvider<LettuceClientConfigurationBuilderCustomizer> clientConfigurationBuilderCustomizers,
115+
ObjectProvider<LettuceClientOptionsBuilderCustomizer> clientOptionsBuilderCustomizers,
111116
ClientResources clientResources) {
112-
LettuceClientConfiguration clientConfig = getLettuceClientConfiguration(builderCustomizers, clientResources,
113-
getProperties().getLettuce().getPool());
117+
LettuceClientConfiguration clientConfig = getLettuceClientConfiguration(clientConfigurationBuilderCustomizers,
118+
clientOptionsBuilderCustomizers, clientResources, getProperties().getLettuce().getPool());
114119
return createLettuceConnectionFactory(clientConfig);
115120
}
116121

@@ -125,16 +130,17 @@ private LettuceConnectionFactory createLettuceConnectionFactory(LettuceClientCon
125130
}
126131

127132
private LettuceClientConfiguration getLettuceClientConfiguration(
128-
ObjectProvider<LettuceClientConfigurationBuilderCustomizer> builderCustomizers,
133+
ObjectProvider<LettuceClientConfigurationBuilderCustomizer> clientConfigurationBuilderCustomizers,
134+
ObjectProvider<LettuceClientOptionsBuilderCustomizer> clientOptionsBuilderCustomizers,
129135
ClientResources clientResources, Pool pool) {
130136
LettuceClientConfigurationBuilder builder = createBuilder(pool);
131137
applyProperties(builder);
132138
if (StringUtils.hasText(getProperties().getUrl())) {
133139
customizeConfigurationFromUrl(builder);
134140
}
135-
builder.clientOptions(createClientOptions());
141+
builder.clientOptions(createClientOptions(clientOptionsBuilderCustomizers));
136142
builder.clientResources(clientResources);
137-
builderCustomizers.orderedStream().forEach((customizer) -> customizer.customize(builder));
143+
clientConfigurationBuilderCustomizers.orderedStream().forEach((customizer) -> customizer.customize(builder));
138144
return builder.build();
139145
}
140146

@@ -163,7 +169,8 @@ private void applyProperties(LettuceClientConfiguration.LettuceClientConfigurati
163169
}
164170
}
165171

166-
private ClientOptions createClientOptions() {
172+
private ClientOptions createClientOptions(
173+
ObjectProvider<LettuceClientOptionsBuilderCustomizer> clientConfigurationBuilderCustomizers) {
167174
ClientOptions.Builder builder = initializeClientOptionsBuilder();
168175
Duration connectTimeout = getProperties().getConnectTimeout();
169176
if (connectTimeout != null) {
@@ -183,7 +190,9 @@ private ClientOptions createClientOptions() {
183190
}
184191
builder.sslOptions(sslOptionsBuilder.build());
185192
}
186-
return builder.timeoutOptions(TimeoutOptions.enabled()).build();
193+
builder.timeoutOptions(TimeoutOptions.enabled());
194+
clientConfigurationBuilderCustomizers.orderedStream().forEach((customizer) -> customizer.customize(builder));
195+
return builder.build();
187196
}
188197

189198
private ClientOptions.Builder initializeClientOptionsBuilder() {

spring-boot-project/spring-boot-autoconfigure/src/test/java/org/springframework/boot/autoconfigure/data/redis/RedisAutoConfigurationTests.java

+7
Original file line numberDiff line numberDiff line change
@@ -127,6 +127,8 @@ void testCustomizeRedisConfiguration() {
127127
this.contextRunner.withUserConfiguration(CustomConfiguration.class).run((context) -> {
128128
LettuceConnectionFactory cf = context.getBean(LettuceConnectionFactory.class);
129129
assertThat(cf.isUseSsl()).isTrue();
130+
assertThat(cf.getClientConfiguration().getClientOptions())
131+
.hasValueSatisfying((options) -> assertThat(options.isAutoReconnect()).isFalse());
130132
});
131133
}
132134

@@ -638,6 +640,11 @@ LettuceClientConfigurationBuilderCustomizer customizer() {
638640
return LettuceClientConfigurationBuilder::useSsl;
639641
}
640642

643+
@Bean
644+
LettuceClientOptionsBuilderCustomizer clientOptionsBuilderCustomizer() {
645+
return (builder) -> builder.autoReconnect(false);
646+
}
647+
641648
}
642649

643650
@Configuration(proxyBeanMethods = false)

0 commit comments

Comments
 (0)