spring-data-redis JedisStringCommands 源码
spring-data-redis JedisStringCommands 代码
文件路径:/src/main/java/org/springframework/data/redis/connection/jedis/JedisStringCommands.java
/*
* Copyright 2017-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.jedis;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.commands.PipelineBinaryCommands;
import redis.clients.jedis.params.BitPosParams;
import redis.clients.jedis.params.SetParams;
import java.util.List;
import java.util.Map;
import org.springframework.data.domain.Range;
import org.springframework.data.redis.connection.BitFieldSubCommands;
import org.springframework.data.redis.connection.RedisStringCommands;
import org.springframework.data.redis.connection.convert.Converters;
import org.springframework.data.redis.core.types.Expiration;
import org.springframework.lang.Nullable;
import org.springframework.util.Assert;
/**
* @author Christoph Strobl
* @author Mark Paluch
* @author dengliming
* @since 2.0
*/
class JedisStringCommands implements RedisStringCommands {
private final JedisConnection connection;
JedisStringCommands(JedisConnection connection) {
this.connection = connection;
}
@Override
public byte[] get(byte[] key) {
Assert.notNull(key, "Key must not be null");
return connection.invoke().just(Jedis::get, PipelineBinaryCommands::get, key);
}
@Nullable
@Override
public byte[] getDel(byte[] key) {
Assert.notNull(key, "Key must not be null");
return connection.invoke().just(Jedis::getDel, PipelineBinaryCommands::getDel, key);
}
@Nullable
@Override
public byte[] getEx(byte[] key, Expiration expiration) {
Assert.notNull(key, "Key must not be null");
Assert.notNull(expiration, "Expiration must not be null");
return connection.invoke().just(Jedis::getEx, PipelineBinaryCommands::getEx, key,
JedisConverters.toGetExParams(expiration));
}
@Override
public byte[] getSet(byte[] key, byte[] value) {
Assert.notNull(key, "Key must not be null");
Assert.notNull(value, "Value must not be null");
return connection.invoke().just(Jedis::getSet, PipelineBinaryCommands::getSet, key, value);
}
@Override
public List<byte[]> mGet(byte[]... keys) {
Assert.notNull(keys, "Keys must not be null");
Assert.noNullElements(keys, "Keys must not contain null elements");
return connection.invoke().just(Jedis::mget, PipelineBinaryCommands::mget, keys);
}
@Override
public Boolean set(byte[] key, byte[] value) {
Assert.notNull(key, "Key must not be null");
Assert.notNull(value, "Value must not be null");
return connection.invoke().from(Jedis::set, PipelineBinaryCommands::set, key, value)
.get(Converters.stringToBooleanConverter());
}
@Override
public Boolean set(byte[] key, byte[] value, Expiration expiration, SetOption option) {
Assert.notNull(key, "Key must not be null");
Assert.notNull(value, "Value must not be null");
Assert.notNull(expiration, "Expiration must not be null");
Assert.notNull(option, "Option must not be null");
SetParams params = JedisConverters.toSetCommandExPxArgument(expiration,
JedisConverters.toSetCommandNxXxArgument(option));
return connection.invoke().from(Jedis::set, PipelineBinaryCommands::set, key, value, params)
.getOrElse(Converters.stringToBooleanConverter(), () -> false);
}
@Override
public Boolean setNX(byte[] key, byte[] value) {
Assert.notNull(key, "Key must not be null");
Assert.notNull(value, "Value must not be null");
return connection.invoke().from(Jedis::setnx, PipelineBinaryCommands::setnx, key, value)
.get(Converters.longToBoolean());
}
@Override
public Boolean setEx(byte[] key, long seconds, byte[] value) {
Assert.notNull(key, "Key must not be null");
Assert.notNull(value, "Value must not be null");
if (seconds > Integer.MAX_VALUE) {
throw new IllegalArgumentException("Time must be less than Integer.MAX_VALUE for setEx in Jedis");
}
return connection.invoke().from(Jedis::setex, PipelineBinaryCommands::setex, key, seconds, value)
.getOrElse(Converters.stringToBooleanConverter(), () -> false);
}
@Override
public Boolean pSetEx(byte[] key, long milliseconds, byte[] value) {
Assert.notNull(key, "Key must not be null");
Assert.notNull(value, "Value must not be null");
return connection.invoke().from(Jedis::psetex, PipelineBinaryCommands::psetex, key, milliseconds, value)
.getOrElse(Converters.stringToBooleanConverter(), () -> false);
}
@Override
public Boolean mSet(Map<byte[], byte[]> tuples) {
Assert.notNull(tuples, "Tuples must not be null");
return connection.invoke().from(Jedis::mset, PipelineBinaryCommands::mset, JedisConverters.toByteArrays(tuples))
.get(Converters.stringToBooleanConverter());
}
@Override
public Boolean mSetNX(Map<byte[], byte[]> tuples) {
Assert.notNull(tuples, "Tuples must not be null");
return connection.invoke().from(Jedis::msetnx, PipelineBinaryCommands::msetnx, JedisConverters.toByteArrays(tuples))
.get(Converters.longToBoolean());
}
@Override
public Long incr(byte[] key) {
Assert.notNull(key, "Key must not be null");
return connection.invoke().just(Jedis::incr, PipelineBinaryCommands::incr, key);
}
@Override
public Long incrBy(byte[] key, long value) {
Assert.notNull(key, "Key must not be null");
return connection.invoke().just(Jedis::incrBy, PipelineBinaryCommands::incrBy, key, value);
}
@Override
public Double incrBy(byte[] key, double value) {
Assert.notNull(key, "Key must not be null");
return connection.invoke().just(Jedis::incrByFloat, PipelineBinaryCommands::incrByFloat, key, value);
}
@Override
public Long decr(byte[] key) {
Assert.notNull(key, "Key must not be null");
return connection.invoke().just(Jedis::decr, PipelineBinaryCommands::decr, key);
}
@Override
public Long decrBy(byte[] key, long value) {
Assert.notNull(key, "Key must not be null");
return connection.invoke().just(Jedis::decrBy, PipelineBinaryCommands::decrBy, key, value);
}
@Override
public Long append(byte[] key, byte[] value) {
Assert.notNull(key, "Key must not be null");
Assert.notNull(value, "Value must not be null");
return connection.invoke().just(Jedis::append, PipelineBinaryCommands::append, key, value);
}
@Override
public byte[] getRange(byte[] key, long start, long end) {
Assert.notNull(key, "Key must not be null");
return connection.invoke().just(Jedis::getrange, PipelineBinaryCommands::getrange, key, start, end);
}
@Override
public void setRange(byte[] key, byte[] value, long offset) {
Assert.notNull(key, "Key must not be null");
Assert.notNull(value, "Value must not be null");
connection.invokeStatus().just(Jedis::setrange, PipelineBinaryCommands::setrange, key, offset, value);
}
@Override
public Boolean getBit(byte[] key, long offset) {
Assert.notNull(key, "Key must not be null");
return connection.invoke().just(Jedis::getbit, PipelineBinaryCommands::getbit, key, offset);
}
@Override
public Boolean setBit(byte[] key, long offset, boolean value) {
Assert.notNull(key, "Key must not be null");
return connection.invoke().just(Jedis::setbit, PipelineBinaryCommands::setbit, key, offset, value);
}
@Override
public Long bitCount(byte[] key) {
Assert.notNull(key, "Key must not be null");
return connection.invoke().just(Jedis::bitcount, PipelineBinaryCommands::bitcount, key);
}
@Override
public Long bitCount(byte[] key, long start, long end) {
Assert.notNull(key, "Key must not be null");
return connection.invoke().just(Jedis::bitcount, PipelineBinaryCommands::bitcount, key, start, end);
}
@Override
public List<Long> bitField(byte[] key, BitFieldSubCommands subCommands) {
Assert.notNull(key, "Key must not be null");
Assert.notNull(subCommands, "Command must not be null");
return connection.invoke().just(Jedis::bitfield, PipelineBinaryCommands::bitfield, key,
JedisConverters.toBitfieldCommandArguments(subCommands));
}
@Override
public Long bitOp(BitOperation op, byte[] destination, byte[]... keys) {
Assert.notNull(op, "BitOperation must not be null");
Assert.notNull(destination, "Destination key must not be null");
if (op == BitOperation.NOT && keys.length > 1) {
throw new IllegalArgumentException("Bitop NOT should only be performed against one key");
}
return connection.invoke().just(Jedis::bitop, PipelineBinaryCommands::bitop, JedisConverters.toBitOp(op),
destination, keys);
}
@Nullable
@Override
public Long bitPos(byte[] key, boolean bit, Range<Long> range) {
Assert.notNull(key, "Key must not be null");
Assert.notNull(range, "Range must not be null Use Range.unbounded() instead");
if (range.getLowerBound().isBounded()) {
BitPosParams params = range.getUpperBound().isBounded()
? new BitPosParams(range.getLowerBound().getValue().get(), range.getUpperBound().getValue().get())
: new BitPosParams(range.getLowerBound().getValue().get());
return connection.invoke().just(Jedis::bitpos, PipelineBinaryCommands::bitpos, key, bit, params);
}
return connection.invoke().just(Jedis::bitpos, PipelineBinaryCommands::bitpos, key, bit);
}
@Override
public Long strLen(byte[] key) {
Assert.notNull(key, "Key must not be null");
return connection.invoke().just(Jedis::strlen, PipelineBinaryCommands::strlen, key);
}
}
相关信息
相关文章
spring-data-redis DefaultJedisClientConfiguration 源码
spring-data-redis JedisClientConfiguration 源码
spring-data-redis JedisClientUtils 源码
spring-data-redis JedisClusterConnection 源码
spring-data-redis JedisClusterGeoCommands 源码
spring-data-redis JedisClusterHashCommands 源码
spring-data-redis JedisClusterHyperLogLogCommands 源码
spring-data-redis JedisClusterKeyCommands 源码
0
赞
热门推荐
-
2、 - 优质文章
-
3、 gate.io
-
8、 golang
-
9、 openharmony
-
10、 Vue中input框自动聚焦