spring-data-redis StreamReadOptions 源码
spring-data-redis StreamReadOptions 代码
文件路径:/src/main/java/org/springframework/data/redis/connection/stream/StreamReadOptions.java
/*
* Copyright 2018-2022 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* https://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.springframework.data.redis.connection.stream;
import java.time.Duration;
import org.springframework.lang.Nullable;
import org.springframework.util.Assert;
import org.springframework.util.ObjectUtils;
/**
* Options for reading messages from a Redis Stream.
*
* @author Mark Paluch
* @author Christoph Strobl
* @author Kaizhou Zhang
* @see 2.2
*/
public class StreamReadOptions {
private static final StreamReadOptions EMPTY = new StreamReadOptions(null, null, false);
private final @Nullable Long block;
private final @Nullable Long count;
private final boolean noack;
private StreamReadOptions(@Nullable Long block, @Nullable Long count, boolean noack) {
this.block = block;
this.count = count;
this.noack = noack;
}
/**
* Creates an empty {@link StreamReadOptions} instance.
*
* @return an empty {@link StreamReadOptions} instance.
*/
public static StreamReadOptions empty() {
return EMPTY;
}
/**
* Enable auto-acknowledgement by setting the {@code NOACK} flag when reading in the context of a consumer group. This
* method is an alias for {@link #autoAcknowledge()} for readability reasons.
*
* @return {@link StreamReadOptions} with {@code noack} applied.
*/
public StreamReadOptions noack() {
return autoAcknowledge();
}
/**
* Enable auto-acknowledgement by setting the {@code NOACK} flag when reading in the context of a consumer group. This
* method is an alias for {@link #noack()} for readability reasons.
*
* @return new instance of {@link StreamReadOptions} with {@code noack} applied.
* @since 2.3
*/
public StreamReadOptions autoAcknowledge() {
return new StreamReadOptions(block, count, true);
}
/**
* Use a blocking read and supply the {@link Duration timeout} after which the call will terminate if no message was
* read.
*
* @param timeout the timeout for the blocking read, must not be {@literal null} or negative.
* @return new instance of {@link StreamReadOptions} with {@code block} applied.
*/
public StreamReadOptions block(Duration timeout) {
Assert.notNull(timeout, "Block timeout must not be null");
Assert.isTrue(!timeout.isNegative(), "Block timeout must not be negative");
return new StreamReadOptions(timeout.toMillis(), count, noack);
}
/**
* Limit the number of messages returned per stream.
*
* @param count the maximum number of messages to read.
* @return {@link StreamReadOptions} with {@code count} applied.
*/
public StreamReadOptions count(long count) {
Assert.isTrue(count > 0, "Count must be greater or equal to zero");
return new StreamReadOptions(block, count, noack);
}
/**
* @return {@literal true} if the arguments indicate a blocking read.
* @since 2.3
*/
public boolean isBlocking() {
return getBlock() != null && getBlock() >= 0;
}
@Nullable
public Long getBlock() {
return block;
}
@Nullable
public Long getCount() {
return count;
}
public boolean isNoack() {
return noack;
}
@Override
public String toString() {
return "StreamReadOptions{" + "block=" + block + ", count=" + count + ", noack=" + noack + ", blocking="
+ isBlocking() + '}';
}
@Override
public boolean equals(Object o) {
if (this == o)
return true;
if (o == null || getClass() != o.getClass())
return false;
StreamReadOptions that = (StreamReadOptions) o;
if (noack != that.noack)
return false;
if (!ObjectUtils.nullSafeEquals(block, that.block)) {
return false;
}
return ObjectUtils.nullSafeEquals(count, that.count);
}
@Override
public int hashCode() {
int result = ObjectUtils.nullSafeHashCode(block);
result = 31 * result + ObjectUtils.nullSafeHashCode(count);
result = 31 * result + (noack ? 1 : 0);
return result;
}
}
相关信息
相关文章
spring-data-redis ByteBufferRecord 源码
spring-data-redis ByteRecord 源码
spring-data-redis MapRecord 源码
spring-data-redis ObjectRecord 源码
spring-data-redis PendingMessage 源码
spring-data-redis PendingMessages 源码
spring-data-redis PendingMessagesSummary 源码
0
赞
热门推荐
-
2、 - 优质文章
-
3、 gate.io
-
8、 golang
-
9、 openharmony
-
10、 Vue中input框自动聚焦