目前有很多项目还在使用jedis的 setNx 充当分布式锁,然而这个锁是有问题的,redisson是java支持redis的redlock的唯一实现,官方目前只有javaweb版本,配置起来很麻烦.集成该项目后只需要极少的配置.就能够使用redisson的全部功能.目前支持集群模式,云托管模式,单Redis节点模式,哨兵模式,主从模式 配置.支持 可重入锁,公平锁,联锁,红锁,读写锁 锁定模式
介绍我们为什么需要redisson?redisson目前是官方唯一推荐的java版的分布式锁,他支持 redlock.具体请查看 官方文档
jedis为什么有问题?目前jedis是只支持单机的.
jedissetNx和设置过期时间是不同步的,在某些极端的情况下会发生死锁.导致程序崩溃.如果没有设置value,线程1可能会释放线程2的锁详情看下这篇 博客
软件架构redissonspringboot安装教程引入pom.xml<dependency><groupId>com.zengtengpeng</groupId><artifactId>redisson-spring-boot-starter</artifactId><version>1.0.0</version></dependency>使用说明在 application.properties 增加#单Redis节点模式redisson.singleServerConfig.address=127.0.0.1:63792.在方法增加 @Lock 注解
//支持spel表达式如果后面需要接字符串的话请用`+`连接.字符串一定要打`单引号`@Lock(keys="#user.name+'locks'")publicStringtest(Useruser){System.out.println("进来了test");return"test";}完毕进阶篇@Lock注解参数介绍/***REENTRANT(可重入锁),FAIR(公平锁),MULTIPLE(联锁),REDLOCK(红锁),READ(读锁),WRITE(写锁),*AUTO(自动模式,当参数只有一个.使用REENTRANT参数多个MULTIPLE)*/LockModellockModel()defaultLockModel.AUTO;/***需要锁定的keys*@return*/String[]keys()default{};/***锁超时时间,默认30000毫秒(可在配置文件全局设置)*@return*/longlockWatchdogTimeout()default0;/***等待加锁超时时间,默认10000毫秒-1则表示一直等待(可在配置文件全局设置)*@return*/longattemptTimeout()default0;如何使用redisson 客户端实现自定义操作,只需要在spring容器中注入redisson客户端就行,如下:@AutowiredprivateRedissonClientredissonClient;集群模式配置(也可以使用yml写法)单例模式
单机版redis
#单Redis节点模式redisson.singleServerConfig.address=127.0.0.1:6379集群模式
集群模式除了适用于Redis集群环境,也适用于任何云计算服务商提供的集群模式,例如AWSElastiCache集群版、AzureRedisCache和阿里云(Aliyun)的云数据库Redis版。
#集群模式redisson.model=CLUSTER#redis机器.一直累加下去redisson.multiple-server-config.node-addresses[0]=127.0.0.1:6379redisson.multiple-server-config.node-addresses[1]=127.0.0.1:6380redisson.multiple-server-config.node-addresses[2]=127.0.0.1:6381云托管模式
云托管模式适用于任何由云计算运营商提供的Redis云服务,包括亚马逊云的AWSElastiCache、微软云的AzureRedis缓存和阿里云(Aliyun)的云数据库Redis版
#云托管模式redisson.model=REPLICATED#redis机器.一直累加下去redisson.multiple-server-config.node-addresses[0]=127.0.0.1:6379redisson.multiple-server-config.node-addresses[1]=127.0.0.1:6380redisson.multiple-server-config.node-addresses[2]=127.0.0.1:6381哨兵模式
redisson.model=SENTINEL#主服务器的名称是哨兵进程中用来监测主从服务切换情况的。redisson.multiple-server-config.master-name="mymaster"#redis机器.一直累加下去redisson.multiple-server-config.node-addresses[0]=127.0.0.1:6379redisson.multiple-server-config.node-addresses[1]=127.0.0.1:6380redisson.multiple-server-config.node-addresses[2]=127.0.0.1:6381主从模式
redisson.model=MASTERSLAVE#第一台机器就是主库.其他的为从库redisson.multiple-server-config.node-addresses[0]=127.0.0.1:6379redisson.multiple-server-config.node-addresses[1]=127.0.0.1:6380redisson.multiple-server-config.node-addresses[2]=127.0.0.1:6381属性列表(基本都是官方参数.我将参数整合了下.分为 公共参数,单例模式参数,集群模式参数)1.公共参数
属性名默认值备注redisson.password 用于节点身份验证的密码。redisson.attemptTimeout10000L等待获取锁超时时间,-1则是一直等待redisson.lockModel单个key默认可重入锁多个key默认联锁锁的模式.如果不设置,REENTRANT(可重入锁),FAIR(公平锁),MULTIPLE(联锁),REDLOCK(红锁),READ(读锁),WRITE(写锁)redisson.modelSINGLE集群模式:SINGLE(单例),SENTINEL(哨兵),MASTERSLAVE(主从),CLUSTER(集群),REPLICATED(云托管)redisson.codecorg.redisson.codec.JsonJacksonCodecRedisson的对象编码类是用于将对象进行序列化和反序列化,以实现对该对象在Redis里的读取和存储redisson.threads当前处理核数量*2这个线程池数量被所有RTopic对象监听器,RRemoteService调用者和RExecutorService任务共同共享。redisson.nettyThreads当前处理核数量*2这个线程池数量是在一个Redisson实例内,被其创建的所有分布式数据类型和服务,以及底层客户端所一同共享的线程池里保存的线程数量。redisson.transportModeNIOTransportMode.NIO,TransportMode.EPOLL-需要依赖里有netty-transport-native-epoll包(Linux)TransportMode.KQUEUE-需要依赖里有netty-transport-native-kqueue包(macOS)redisson.idleConnectionTimeout10000如果当前连接池里的连接数量超过了最小空闲连接数,而同时有连接空闲时间超过了该数值,那么这些连接将会自动被关闭,并从连接池里去掉。时间单位是毫秒redisson.connectTimeout10000同任何节点建立连接时的等待超时。时间单位是毫秒。redisson.timeout3000等待节点回复命令的时间。该时间从命令发送成功时开始计时。redisson.retryAttempts3如果尝试达到retryAttempts(命令失败重试次数)仍然不能将命令发送至某个指定的节点时,将抛出错误。如果尝试在此限制之内发送成功,则开始启用timeout(命令等待超时)计时。redisson.retryInterval1500在一条命令发送失败以后,等待重试发送的时间间隔。时间单位是毫秒。redisson.subscriptionsPerConnection5每个连接的最大订阅数量。redisson.clientName 在Redis节点里显示的客户端名称。redisson.sslEnableEndpointIdentificationtrue开启SSL终端识别能力。redisson.sslProviderJDK确定采用哪种方式(JDK或OPENSSL)来实现SSL连接。redisson.sslTruststore 指定SSL信任证书库的路径。redisson.sslTruststorePassword 指定SSL信任证书库的密码。redisson.sslKeystore 指定SSL钥匙库的路径。redisson.sslKeystorePassword 指定SSL钥匙库的密码。redisson.lockWatchdogTimeout30000监控锁的看门狗超时时间单位为毫秒。该参数只适用于分布式锁的加锁请求中未明确使用leaseTimeout参数的情况。如果该看门口未使用lockWatchdogTimeout去重新调整一个分布式锁的lockWatchdogTimeout超时,那么这个锁将变为失效状态。这个参数可以用来避免由Redisson客户端节点宕机或其他原因造成死锁的情况。redisson.keepPubSubOrdertrue通过该参数来修改是否按订阅发布消息的接收顺序出来消息,如果选否将对消息实行并行处理,该参数只适用于订阅发布消息的情况。单例模式参数属性名默认值备注redisson.singleServerConfig.address 服务器地址,必填ip:portredisson.singleServerConfig.database0尝试连接的数据库编号。redisson.singleServerConfig.subscriptionConnectionMinimumIdleSize1用于发布和订阅连接的最小保持连接数(长连接)。Redisson内部经常通过发布和订阅来实现许多功能。长期保持一定数量的发布订阅连接是必须的。redisson.singleServerConfig.subscriptionConnectionPoolSize50用于发布和订阅连接的连接池最大容量。连接池的连接数量自动弹性伸缩。redisson.singleServerConfig.connectionMinimumIdleSize32最小保持连接数(长连接)。长期保持一定数量的连接有利于提高瞬时写入反应速度。redisson.singleServerConfig.connectionPoolSize64连接池最大容量。连接池的连接数量自动弹性伸缩。redisson.singleServerConfig.dnsMonitoringInterval5000用来指定检查节点DNS变化的时间间隔。使用的时候应该确保JVM里的DNS数据的缓存时间保持在足够低的范围才有意义。用-1来禁用该功能。集群模式属性名默认值备注redisson.multiple-server-config.node-addresses 服务器节点地址.必填 redisson.multiple-server-config.node-addresses[0]=127.0.0.1:6379redisson.multiple-server-config.node-addresses[1]=127.0.0.1:6380redisson.multiple-server-config.node-addresses[2]=127.0.0.1:6381redisson.multiple-server-config.loadBalancerorg.redisson.connection.balancer.RoundRobinLoadBalancer在多Redis服务节点的环境里,可以选用以下几种负载均衡方式选择一个节点:org.redisson.connection.balancer.WeightedRoundRobinBalancer-权重轮询调度算法org.redisson.connection.balancer.RoundRobinLoadBalancer-轮询调度算法org.redisson.connection.balancer.RandomLoadBalancer-随机调度算法redisson.multiple-server-config.slaveConnectionMinimumIdleSize32多从节点的环境里,每个从服务节点里用于普通操作(非发布和订阅)的最小保持连接数(长连接)。长期保持一定数量的连接有利于提高瞬时读取反映速度。redisson.multiple-server-config.slaveConnectionPoolSize64多从节点的环境里,每个从服务节点里用于普通操作(非发布和订阅)连接的连接池最大容量。连接池的连接数量自动弹性伸缩。redisson.multiple-server-config.masterConnectionMinimumIdleSize32多节点的环境里,每个主节点的最小保持连接数(长连接)。长期保持一定数量的连接有利于提高瞬时写入反应速度。redisson.multiple-server-config.masterConnectionPoolSize64多主节点的环境里,每个主节点的连接池最大容量。连接池的连接数量自动弹性伸缩。redisson.multiple-server-config.readModeSLAVE设置读取操作选择节点的模式。可用值为:SLAVE-只在从服务节点里读取。MASTER-只在主服务节点里读取。MASTER_SLAVE-在主从服务节点里都可以读取。redisson.multiple-server-config.subscriptionModeSLAVE设置订阅操作选择节点的模式。可用值为:SLAVE-只在从服务节点里订阅。MASTER-只在主服务节点里订阅。redisson.multiple-server-config.subscriptionConnectionMinimumIdleSize1用于发布和订阅连接的最小保持连接数(长连接)。Redisson内部经常通过发布和订阅来实现许多功能。长期保持一定数量的发布订阅连接是必须的。redisson.multiple-server-config.subscriptionConnectionPoolSizeredisson.multiple-server-config.dnsMonitoringInterval5000监测DNS的变化情况的时间间隔。redisson.multiple-server-config.scanInterval1000(集群,哨兵,云托管模特特有)对Redis集群节点状态扫描的时间间隔。单位是毫秒。redisson.multiple-server-config.database0(哨兵模式,云托管,主从模式特有)尝试连接的数据库编号。redisson.multiple-server-config.masterName (哨兵模式特有)主服务器的名称是哨兵进程中用来监测主从服务切换情况的。
评论