解决Redis分布式锁setnx和setexpire

String script = "local rs=redis.call('setnx',KEYS[1],ARGV[1]);if(rs<1) then return 'F';end;redis.call('expire',KEYS[1],tonumber(ARGV[2]));return 'S';";
Jedis jedis = shardedJedis.getShard(redisKey);  
Object result = jedis.evalsha(script, keys, args);
if ("S".equals(result)) {
    return true;
}

解决Redis分布式锁setnx后setexpire因某种问题导致没执行,导致锁一直被占的问题;

参考地址:http://redisdoc.com/script/eval.html

你可能感兴趣的:(Redis)