本文共 3839 字,大约阅读时间需要 12 分钟。
redLock我这里不介绍了。想必大家应该都了解。毕竟在分布式锁领域,它被这么多人认可
引入maven依赖
org.redisson redisson 3.11.5
import org.redisson.Redisson;import org.redisson.api.RLock;import org.redisson.api.RedissonClient;import org.redisson.config.Config;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.beans.factory.annotation.Value;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration;import java.lang.reflect.Method;import java.util.concurrent.TimeUnit;@Configurationpublic class RedisRedLock{ @Value("${spring.redis.sentinel.nodesRedis}") private String[] nodes; @Value("${spring.redis.sentinel.master}") private String master; /** * 单个服务 * @return */ @Bean public RedissonClient redissonClientSign(){ Config config = new Config(); config.useSingleServer() .setIdleConnectionTimeout(10000)//如果当前连接池里的连接数量超过了最小空闲连接数,而同时有连接空闲时间超过了该数值,那么这些连接将会自动被关闭,并从连接池里去掉。时间单位是毫秒。 .setConnectTimeout(30000)//同任何节点建立连接时的等待超时。时间单位是毫秒。 .setTimeout(3000)//等待节点回复命令的时间。该时间从命令发送成功时开始计时。 .setPingTimeout(30000) .setReconnectionTimeout(3000)//当与某个节点的连接断开时,等待与其重新建立 .setPassword("root123456abc").setDatabase(0); return Redisson.create(config); } /** * 哨兵模式 * @return */ @Bean public RedissonClient redissonClient(){ Config config = new Config(); config.useSentinelServers().setMasterName(master) .setFailedSlaveReconnectionInterval(5000) .addSentinelAddress(nodes) .setMasterConnectionPoolSize(500)//设置对于master节点的连接池中连接数最大为500 .setSlaveConnectionPoolSize(500)//设置对于slave节点的连接池中连接数最大为500 .setIdleConnectionTimeout(10000)//如果当前连接池里的连接数量超过了最小空闲连接数,而同时有连接空闲时间超过了该数值,那么这些连接将会自动被关闭,并从连接池里去掉。时间单位是毫秒。 .setConnectTimeout(30000)//同任何节点建立连接时的等待超时。时间单位是毫秒。 .setTimeout(3000)//等待节点回复命令的时间。该时间从命令发送成功时开始计时。 .setPingTimeout(30000) .setReconnectionTimeout(3000)//当与某个节点的连接断开时,等待与其重新建立 .setPassword("root123456abc").setDatabase(0); return Redisson.create(config); } @Autowired RedissonClient redissonClient; public RLock create(String key){ return redissonClient.getRedLock(redissonClient.getLock(key)); } /** * 分布式锁并利用反射进行业务处理 * @param key * @param target * @param methodName * @param classes * @param args * @param* @return */ public boolean lockKey(String key,T target,String methodName,Class[] classes,Object...args){ RLock redissonRedLock = create(key); try { if(redissonRedLock.tryLock(200, 60000, TimeUnit.MILLISECONDS)){ Method method = target.getClass().getMethod(methodName, classes); method.invoke(target,args); return true; } } catch (Exception e) { e.printStackTrace(); }finally { try { //等待4秒释放锁 Thread.sleep(4000); } catch (InterruptedException e) { e.printStackTrace(); } redissonRedLock.unlock(); } return false; }}
这样就大功告成了。接下来调用
@RequestMapping("/isLock")@ResponseBodypublic Object isLock(HttpServletRequest request){ String key = request.getParameter("key"); EntityWrapper wrapper = new EntityWrapper(); wrapper.eq("member_id","1"); Class[] classes = new Class[]{Wrapper.class}; if(redisRedLock.lockKey(key,portalOrderService,"selectCount",classes,wrapper)){ System.out.println("获取锁成功"); }else{ System.out.println("获取锁失败"); } return null;}
我这边把业务写进去了。通过反射找到对应的方法。执行。只能帮到这里了
转载地址:http://glvbi.baihongyu.com/