redission分布式锁

  • Post author:
  • Post category:其他


<dependency>
      <groupId>org.redisson</groupId>
      <artifactId>redisson</artifactId>
      <version>3.15.5</version>
</dependency>
@Configuration
public class LockConfig {

    @Bean
    public RedissonClient redissonClient(){
        Config config = new Config();
        config.useSingleServer().setAddress("redis://xx.xx.xx.xx:6379").setPassword("xxxxx");
        return Redisson.create(config);
    }
}
@Service
public class LockService {

    public static int stock = 100;

    @Resource
    private RedissonClient redissonClient;

    public boolean getStock(){
        RLock lock = redissonClient.getLock("lock-test3");
        try {
            lock.lock();
            if(stock <= 0){
                return false;
            }
            stock--;
            System.out.println("线程名称 = " + Thread.currentThread().getName() + ", 库存数量 = " + stock);
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            lock.unlock();
        }
        return true;
    }
}



版权声明:本文为baidu_35760874原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。