首先Java中使用Redis有2种方式: 一种是使用标准Jedis来操作Redis实例,另一种是使用spring-data-redis来操作Redis实例。
如果使用jedis来操作redis,可以通过java代码实现setNX指令来保证操作的原子性。
jedis.set(lockKey, requestId, "NX", "PX", expireTime);
如果使用spring-data-redis,只能先通过redisTemplate丰富setIfAbsent()方法。
Boolean verifyResult = (Boolean) redisTemplate.execute(new RedisCallback<Boolean>() {
@Override
public Boolean doInRedis(RedisConnection connection) throws DataAccessException {
RedisSerializer valueSerializer = redisTemplate.getValueSerializer();
RedisSerializer keySerializer = redisTemplate.getKeySerializer();
Object obj = connection.execute("set", keySerializer.serialize(ip),
valueSerializer.serialize(RandomStringUtils.random(4)),
SafeEncoder.encode("NX"),
SafeEncoder.encode("EX"),
Protocol.toByteArray(30));
return obj != null;
}
});
return verifyResult;