• 分布式锁实现


    我们已经知道可以通过Redis自带的函数setNX来实现分布式锁,具体实现步骤如下。

    我在一台CentOS7的linux虚拟机中安装了Redis服务,ip地址为:192.168.246.130,服务端口为:6379。

    下面是java通过redis实现分布式锁的例子:

    import redis.clients.jedis.Jedis;
    public class RedisLock {
    //锁的key
    private static final String key = "DistributedRedisLock";
    private static Integer count = 0;
    public static void main(String[] args) {
    for(int i=0;i<1000;i++){
    new Thread(new Runnable() {
    @Override
    public void run() {
    //获取Redis连接
    Jedis jedis = new Jedis("192.168.246.130", 6379);
    try{
    while(true){
    //获取锁
    if(jedis.setnx(key, Thread.currentThread().getName()) == 1){
    try{
    System.out.println("线程("+Thread.currentThread().getName()+")获取到锁,开始执行操作");
    count++;
    System.out.println(count);
    break;
    }finally{
    System.out.println("操作执行完成,释放锁");
    //操作执行完一定要释放锁,所以在finally块中执行
    jedis.del(key);
    }
    }else{
    //返回的不是1,说明已经有某个线程获取到了锁
    try {
    //等待100毫秒之后重试
    Thread.sleep(100l);
    } catch (InterruptedException e) {
    e.printStackTrace();
    }
    }
    }
    }catch(Exception e){
    e.printStackTrace();
    }finally{
    //释放Redis连接
    jedis.disconnect();
    }
    }
    }).start();
    }
    }
    }
     

    上述代码的输出结果为:

    线程(Thread-320)获取到锁,开始执行操作

    1

    操作执行完成,释放锁

    线程(Thread-463)获取到锁,开始执行操作

    2

    操作执行完成,释放锁

    线程(Thread-997)获取到锁,开始执行操作

    3

    操作执行完成,释放锁

    ...

    线程(Thread-409)获取到锁,开始执行操作

    998

    操作执行完成,释放锁

    线程(Thread-742)获取到锁,开始执行操作

    999

    操作执行完成,释放锁

    线程(Thread-286)获取到锁,开始执行操作

    1000

    操作执行完成,释放锁

    上述代码虽然是在单应用多线程情况下测试的,但即便是在分布式环境下多应用多线程去获取锁,结果依然是正确的。
    ---------------------

  • 相关阅读:
    JQuery EasyUi之界面设计——通用的JavaScript
    easyui datagrid 行右键 动态获取并生成toolbar 按钮
    Jq基础拓展 json to String
    电信光纤猫(HG8245)破解教程 开启无线网、路由器功能(第二章)
    plsql 无需配置客户端连接.
    中文分词常用算法之基于词典的正向最大匹配
    中文分词常用算法之基于词典的逆向最大匹配
    SQL SERVER安装序列号
    查询锁事务及语句
    SQL Server 数据库备份
  • 原文地址:https://www.cnblogs.com/ly570/p/11311259.html
Copyright © 2020-2023  润新知