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