`

spring cloud微服务云架构-用java使用 redlock

 
阅读更多

一、 在pom文件引入redis和redisson依赖:

<!-- redis-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-redis</artifactId>
        </dependency>
        <!-- redisson-->
        <dependency>
            <groupId>org.redisson</groupId>
            <artifactId>redisson</artifactId>
            <version>3.3.2</version>
        </dependency>

 AquiredLockWorker接口类,,主要是用于获取锁后需要处理的逻辑:

/**
 * Created by fangzhipeng on 2017/4/5.
 * 获取锁后需要处理的逻辑
 */
public interface AquiredLockWorker<T> {
     T invokeAfterLockAquire() throws Exception;
}

 二、DistributedLocker 获取锁管理类:

/**
 * Created by fangzhipeng on 2017/4/5.
 * 获取锁管理类
 */
public interface DistributedLocker {
     /**
      * 获取锁
      * @param resourceName  锁的名称
      * @param worker 获取锁后的处理类
      * @param <T>
      * @return 处理完具体的业务逻辑要返回的数据
      * @throws UnableToAquireLockException
      * @throws Exception
      */
     <T> T lock(String resourceName, AquiredLockWorker<T> worker) throws UnableToAquireLockException, Exception;
     <T> T lock(String resourceName, AquiredLockWorker<T> worker, int lockTime) throws UnableToAquireLockException, Exception;
}

 nableToAquireLockException ,不能获取锁的异常类:

/**
 * Created by fangzhipeng on 2017/4/5.
 * 异常类
 */
public class UnableToAquireLockException extends RuntimeException {
    public UnableToAquireLockException() {
    }
    public UnableToAquireLockException(String message) {
        super(message);
    }
    public UnableToAquireLockException(String message, Throwable cause) {
        super(message, cause);
    }
}

 三、RedissonConnector 连接类:

/**
 * Created by fangzhipeng on 2017/4/5.
 * 获取RedissonClient连接类
 */
@Component
public class RedissonConnector {
    RedissonClient redisson;
    @PostConstruct
    public void init(){
        redisson = Redisson.create();
    }
    public RedissonClient getClient(){
        return redisson;
    }
}

 四、RedisLocker 类,实现了DistributedLocker:

import org.redisson.api.RLock;
import org.redisson.api.RedissonClient;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import java.util.concurrent.TimeUnit;
/**
 * Created by fangzhipeng on 2017/4/5.
 */
@Component
public class RedisLocker  implements DistributedLocker{
    private final static String LOCKER_PREFIX = "lock:";
    @Autowired
    RedissonConnector redissonConnector;
    @Override
    public <T> T lock(String resourceName, AquiredLockWorker<T> worker) throws InterruptedException, UnableToAquireLockException, Exception {
        return lock(resourceName, worker, 100);
    }
    @Override
    public <T> T lock(String resourceName, AquiredLockWorker<T> worker, int lockTime) throws UnableToAquireLockException, Exception {
        RedissonClient redisson= redissonConnector.getClient();
        RLock lock = redisson.getLock(LOCKER_PREFIX + resourceName);
      // Wait for 100 seconds seconds and automatically unlock it after lockTime seconds
        boolean success = lock.tryLock(100, lockTime, TimeUnit.SECONDS);
        if (success) {
            try {
                return worker.invokeAfterLockAquire();
            } finally {
                lock.unlock();
            }
        }
        throw new UnableToAquireLockException();
    }
}

 五、测试类:

 @Autowired
    RedisLocker distributedLocker;
    @RequestMapping(value = "/redlock")
    public String testRedlock() throws Exception{
        CountDownLatch startSignal = new CountDownLatch(1);
        CountDownLatch doneSignal = new CountDownLatch(5);
        for (int i = 0; i < 5; ++i) { // create and start threads
            new Thread(new Worker(startSignal, doneSignal)).start();
        }
        startSignal.countDown(); // let all threads proceed
        doneSignal.await();
        System.out.println("All processors done. Shutdown connection");
        return "redlock";
    }
     class Worker implements Runnable {
        private final CountDownLatch startSignal;
        private final CountDownLatch doneSignal;
        Worker(CountDownLatch startSignal, CountDownLatch doneSignal) {
            this.startSignal = startSignal;
            this.doneSignal = doneSignal;
        }
        public void run() {
            try {
                startSignal.await();
                distributedLocker.lock("test",new AquiredLockWorker<Object>() {
                    @Override
                    public Object invokeAfterLockAquire() {
                        doTask();
                        return null;
                    }
                });
            }catch (Exception e){
            }
        }
        void doTask() {
            System.out.println(Thread.currentThread().getName() + " start");
            Random random = new Random();
            int _int = random.nextInt(200);
            System.out.println(Thread.currentThread().getName() + " sleep " + _int + "millis");
            try {
                Thread.sleep(_int);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            System.out.println(Thread.currentThread().getName() + " end");
            doneSignal.countDown();
        }
    }

 六、运行测试类:

 

Thread-48 start

Thread-48 sleep 99millis

Thread-48 end

Thread-49 start

Thread-49 sleep 118millis

Thread-49 end

Thread-52 start

Thread-52 sleep 141millis

Thread-52 end

Thread-50 start

Thread-50 sleep 28millis

Thread-50 end

Thread-51 start

Thread-51 sleep 145millis

Thread-51 end

不管怎么样,这是redis官方推荐的一种方案,可靠性比较高。

欢迎大家和我一起学习spring cloud构建微服务云架构,我这边会将近期研发的spring cloud微服务云架构的搭建过程和精髓记录下来,帮助更多有兴趣研发spring cloud框架的朋友,大家来一起探讨spring cloud架构的搭建过程及如何运用于企业项目。Spring Cloud大型企业分布式微服务云构建的B2B2C电子商务平台源码请加企鹅求求:三五三六二四七二五九

 

分享到:
评论

相关推荐

    Java分布式架构设计实战视频课程(2022最新版,13章全)

    微服务架构的测试策略和监控方案是必不可少的。课程会讲解如何使用JUnit、Mockito进行单元测试,以及使用Prometheus、Grafana进行系统监控。 十、分布式配置管理 配置管理在分布式环境中尤为重要,本章将介绍如何...

    Java 分布式应用程序设计

    在现代企业级应用中,尤其是在云计算和微服务架构盛行的今天,掌握Java分布式应用的设计原则和技术至关重要。下面将详细介绍Java分布式应用程序设计的相关知识点。 1. **分布式系统基础**: - 分布式系统的概念:...

    Java后端体系高级面试题

    Java后端体系高级面试题是针对Java... - 微服务架构:Docker,Kubernetes,Service Mesh 这些知识点是Java后端开发人员在面试过程中可能会遇到的,深入了解并掌握这些内容,将有助于提升个人的技术水平和面试竞争力。

    java面试笔试题大汇总

    以上内容仅涵盖了Java面试笔试题可能涉及的部分知识点,实际准备过程中还需要关注Java 8及以上版本的新特性,如Lambda表达式、Stream API、Optional类等,以及最新的技术趋势,如微服务架构、Spring Cloud、Docker...

    分布式java应用基础与实践附带源码(完整版)

    在Java中,分布式计算主要通过RMI(远程方法调用)、JMS(Java消息服务)、EJB(企业级JavaBean)和现代微服务架构来实现。这些技术允许程序跨越网络边界进行通信,使得数据和处理可以在不同的计算机上分布执行。 ...

    SpringBoot实现Java高并发秒杀系统.zip

    在秒杀系统中,SpringBoot可以提供微服务架构支持,便于模块化设计和独立部署。 2. **RESTful API设计**:为了处理高并发请求,秒杀系统通常会采用HTTP RESTful API进行通信。这允许客户端通过简单的HTTP方法(GET...

    springboot193基于SpringBoot的秒杀系统设计与实现.rar

    2. **Spring Cloud组件**:秒杀系统可能使用了Spring Cloud组件,例如Eureka(服务注册与发现)、Zuul或Gateway(API网关)进行路由和过滤,Hystrix(熔断器)处理服务降级和容错,Ribbon(客户端负载均衡器)用于...

    基于SpringBoot的秒杀系统.zip

    2. **微服务架构**:秒杀系统往往需要高并发处理能力,因此可能采用微服务架构设计,将系统拆分为多个独立的服务,如商品服务、库存服务、订单服务等,每个服务都可以独立部署和扩展,提高系统的灵活性和可维护性。...

    distributedsystems:分享主题分布式系统的项目和解决方案

    7. **微服务架构**:微服务提倡将单一应用拆分为一组小型、独立的服务,每个服务都可以独立部署和扩展。Spring Boot和Spring Cloud是实现微服务的关键工具。 8. **负载均衡**:Nginx、HAProxy和Zuul等组件用于在...

Global site tag (gtag.js) - Google Analytics