首先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;