应用办公生活信息教育商业
投稿投诉
商业财经
汽车智能
教育国际
房产环球
信息数码
热点科技
生活手机
晨报新闻
办公软件
科学动态
应用生物
体育时事

基于redissonzookeeper实现的分布式锁kyli

  1、简介1。1、开源项目kylinlock:麒麟分布式锁支持redisson、zookeeper重入锁、读写锁、联锁、红锁、公平锁
  已上传jar到中央仓库,可直接引入依赖1。2、介绍支持redisson、zookeeper分布式锁redisson支持重入锁、读写锁、联锁、红锁、公平锁zookeeper支持重入锁、不可重入锁、读写锁、联锁支持注解、方法调用、函数式编程等方式加锁支持多注解,对同一方法加不同的锁锁的key支持SpEL表达式支持自定义全局、方法级加锁失败回调方法级失败回调:方法名、参数类型列表相同,支持相同类型的返回1。3分布式锁注解KylinLock字段使用说明name:锁的key一部分,为空则会使用:包名。类名。方法名keys:锁的key一部分支持SpEL表达式,锁的keyprefix:namekeysexpire:过期时间单位:毫秒acquireTimeout:获取锁超时时间单位:毫秒executor:锁执行器lockType:锁类型,默认重入锁keySuffix:联锁、红锁个数以及其中每个锁的后缀key,默认:{1,2,3},支持SpEL表达式lockFailure:加锁失败回调类2、使用说明2。1、引入依赖dependencygroupIdcom。gitee。wangjkuigroupIdkylinlockspringbootstarterartifactIdversionLatestVersionversiondependency2。2、配置2。2。1、application。ymlspring:redis:redisson:file:classpath:redisson。yml分布式锁kylin:lock:acquiretimeout:3000获取锁超时时间默认值3000L单位:毫秒expire:30000过期时间,默认值30000L单位:毫秒retryinterval:100获取锁失败时重试时间间隔,默认值100L单位:毫秒lockkeyprefix:kylinlock锁前缀默认配置primaryexecutor:com。wjk。kylin。lock。executor。redisson。RedissonLockExecutor默认执行器。默认redissonzookeeperredisson:true是否开启redisson默认truezookeeper:zkservers:127。0。0。1:2181zk的server地址,多个server之间使用英文逗号分隔开。配置地址则开启zookeepersessiontimeout:60000会话超时时间,默认值60000单位:毫秒connectiontimeout:15000连接超时时间,默认值15000单位:毫秒basesleeptimems:5000初始sleep时间,默认值5000单位:毫秒maxretries:3最大失败重试次数namespace:curatorkylinlock命名空间2。2。2、redisson。yml单节点配置singleServerConfig:连接空闲超时,单位:毫秒idleConnectionTimeout:10000连接超时,单位:毫秒connectTimeout:10000命令等待超时,单位:毫秒timeout:3000命令失败重试次数,如果尝试达到retryAttempts(命令失败重试次数)仍然不能将命令发送至某个指定的节点时,将抛出错误。如果尝试在此限制之内发送成功,则开始启用timeout(命令等待超时)计时。retryAttempts:3命令重试发送时间间隔,单位:毫秒retryInterval:1500密码password:redis123单个连接最大订阅数量subscriptionsPerConnection:5客户端名称clientName:axin节点地址address:redis:127。0。0。1:6379发布和订阅连接的最小空闲连接数subscriptionConnectionMinimumIdleSize:1发布和订阅连接池大小subscriptionConnectionPoolSize:50最小空闲连接数connectionMinimumIdleSize:32连接池大小connectionPoolSize:64数据库编号database:2DNS监测时间间隔,单位:毫秒dnsMonitoringInterval:5000线程池数量,默认值:当前处理核数量2threads:0Netty线程池数量,默认值:当前处理核数量2nettyThreads:0编码codec:!org。redisson。codec。JsonJacksonCodec{}传输模式transportMode:NIO2。3、使用案例2。3。1、重入锁KylinLock(namereentrantkey,expire60000)publicvoiddemoMethod2(){System。out。println(demoMethod2startgetClass());try{Thread。sleep(4000);}catch(InterruptedExceptione){e。printStackTrace();}重入锁indexService。demoMethod2();System。out。println(demoMethod2endgetClass());}2。3。2、读写锁OverrideKylinLock(namereadwrite,acquireTimeout0,lockTypeLockType。READ)publicvoidread1(Stringkey){try{Thread。sleep(5000);}catch(InterruptedExceptione){e。printStackTrace();}System。out。println(执行方法read1,当前线程:Thread。currentThread()。getName()threadId:Thread。currentThread()。getId());}2。3。3、联锁KylinLock(lockTypeLockType。MULTI)publicvoiddemoMethod6(){System。out。println(demoMethod6startgetClass());try{Thread。sleep(40000);}catch(InterruptedExceptione){e。printStackTrace();}System。out。println(demoMethod6endgetClass());}2。3。4、红锁KylinLock(lockTypeLockType。RED,keySuffix{user。id,red2},executorRedissonLockExecutor。class)publicvoiddemoMethod11(Useruser){System。out。println(demoMethod11startgetClass());try{Thread。sleep(40000);}catch(InterruptedExceptione){e。printStackTrace();}System。out。println(demoMethod11id:user。getId(),name:user。getName());}2。3。5、公平锁KylinLock(namefairlockkey,lockTypeLockType。FAIR,executorRedissonLockExecutor。class)publicvoiddemoMethod8(){System。out。println(demoMethod8startgetClass());try{Thread。sleep(4000);}catch(InterruptedExceptione){e。printStackTrace();}indexService。demoMethod8();System。out。println(demoMethod8endgetClass());}2。3。6、多注解KylinLock(namereentrantkey1,expire60000)KylinLock(namereentrantkey2,expire60000)KylinLock(namereentrantkey3,expire60000)publicvoiddemoMethod3(){System。out。println(demoMethod3startgetClass());try{Thread。sleep(4000);}catch(InterruptedExceptione){e。printStackTrace();}System。out。println(demoMethod3endgetClass());}2。3。7、函数式编程publicvoidexecute1(Stringkey){IntegernumlockTemplate。execute(key,IndexServiceImpl::getNumber);System。out。println(执行execute方法1,当前线程:Thread。currentThread()。getName(),获取的返回值是:num);}publicstaticIntegergetNumber(){try{Thread。sleep(40000);}catch(InterruptedExceptione){e。printStackTrace();}System。out。println(执行getNumber方法,当前线程:Thread。currentThread()。getName());return1;}2。3。8、自定义加锁失败执行方法加锁失败,会调用DemoLockFailureCallBack中方法名称、参数类型列表相同的方法KylinLock(acquireTimeout0,lockFailureDemoLockFailureCallBack。class)publicIntegerdemoMethod14(Integernum){System。out。println(demoMethod12start,num:num);try{Thread。sleep(4000);}catch(InterruptedExceptione){e。printStackTrace();}System。out。println(demoMethod12end,num:num);returnnum2;}Slf4jComponentpublicclassDemoLockFailureCallBackimplementsLockFailureCallBack{方法名称、参数类型列表相同publicIntegerdemoMethod14(Integernum){log。error(demoMethod14方法自定义失败回调,入参num:{},num);return1;}}

双面预制菜疯涨的三季报和哑火的终端市场关注第一食品资讯,了解更多资讯。刚刚过去的双十一,预制菜迎来了一波小高峰。从天猫数据看,今年双11期间,包括半成品菜、速食菜在内的预制菜销售火爆,共生成了28个加购……贫富天注定穷真的是错吗?大多数人从出生就已经注定是穷人了,这里所指的穷是:不管你怎么努力你的收入只能够维持温饱。从古至今你觉得靠出卖体力,靠出卖时间能够致富吗?不管出生于任何时代,……步步高,音乐5G手机vivoT2x,搭配天玑1300芯片vivoT2屏幕:6。59英寸144Hz变速高刷护眼屏分辨率:2408x1080像素系统:OriginOS处理器:天玑1300芯片前摄像:1600……中国男篮面临重组,选材从两方面着手,防守能力与潜力是重要标准中国男篮更换了主教练,聘请来自塞尔维亚的乔尔杰维奇担任主帅,杜锋指导卸任,乔帅接手之后,势必会对国家队进行重组,距离明年的世界杯时间不多,主要以接下来的CBA联赛,以及世预赛第……922欧国联土耳其VS卢森堡,波兰VS荷兰,法国VS奥地利含欧国联:001哈萨克斯坦VS白俄罗斯谈什么理想嘞,竞技体育不分国度哈哈哈哈,难道赢球就是爱国,输了就是不爱?那岂非谬论(置我国足于何地?)哈萨克斯坦在C组目前是第一……写作,是没有地图的旅程筱晨读书公号里,原创作品已有127篇,大概20万字,记录了我生活的点点滴滴,和读书后的碎碎念念,虽然没有什么惊艳的文字,然而,对于我来说都是宝藏。时常,慢慢翻阅之前的每一……迪斯的复仇自从迪斯卸任大众集团CEO后,网上关于大众汽车的营销热点就少了一大半。同时,这个为大众汽车电动化转型鞠躬尽瘁的老黄牛自从恢复自由身后,下一站去哪便成了业界津津乐道的话题。……8小时3交易完成!开拓者签下巴特勒,湖人将签15号秀,詹姆斯头条创作挑战赛目前,NBA常规赛正在火热进行中,联赛各队都在积极备战着,力争帮助球队在新赛季拿到更多场次的胜利,以能捧起奥布莱恩杯,赛事变得愈加精彩白热化,吸睛无数。与此……盘点世界足球史上10大头球之王这10大头球之王的头球能力都在伯仲之间,而且是各具特点。(有争议之处欢迎指出)NO。10桑蒂拉纳:身高175cm西班牙足球史上最优秀的射手之一,上世纪七八十年代皇家……我的血尿从有到无血尿自愈自述我是2019夏天一个早晨,那天是星期六,休息日子,到单位吃早饭。回家上厕所,小便,尿跟刚刚喝过小豆粥的米汤一样颜色,当时想不通,难道胃肠道直接通尿道。也没有什么不舒服,就是昨晚……出个直屏旗舰这么难么?近期新机发布频繁,发布会上都在拿友商做对比,但是旗舰版清一色都是曲屏,大家都不比屏幕的么?难道曲屏就真的好吗?喜欢曲屏的用户真的有这么多么?好不容易出了gt2,外观设计真的爆赞……宏碁RTX3070游戏本价格创新低i917。3寸屏紧逼8千,随着开学季的到来,手机和笔记本电脑等数码产品已经成为必入物件纳入学生囊中,电脑商家们也结束了一年中最激烈的竞争时期,开始对笔记本电脑进行大调价。最近又因为ADM的7000系列处……
散文意境初冬,如诗如画作者:子墨绝爱初冬万瓦霜。初冬的世界,也是霜落的时节,拂面而来的北风,刚刚有个寒冷的苗头,尚不凌冽,也不狂躁。院子里,陆陆续续有各种美丽的树叶,一片一片落下,形状各……清痰在肺,粘痰在脾,老痰在肾,中医教你辩证止咳化痰清痰在肺,粘痰在脾,老痰在肾,我们怎样辨证化痰才最好呢?有很多人,总是痰多,咳都咳不完,止咳药吃了一大堆,但是病根儿还在,风吹草动他就反反复复,这就因为肺为娇脏,喜润勿燥……金观平推动重大项目早开工早见效临近年末,重大项目建设吹响了冲刺全年目标的冲锋号。继11月22日国务院常务会议强调推动重大项目加快建设之后,国家发展改革委近日也连续召开会议,就基金支持重大项目建设、稳经济政策……K60系列三款手机对比,配置全面解析,一文看懂如何选择没想到红米K60系列来得如此快,本该在2023年上半年上市的它却在2022年年底提早发布,这次的K60系列共有三款手机,分别是红米K60E,红米K60和红米K60Pro,三款手……世界杯提振电视换机需求11月下旬电视面板全线涨价根据TrendForce集邦咨询旗下面板研究中心WitsView睿智显示调研数据,2022年11月下旬,电视面板全线涨价。根据Omdia数据,随着韩厂产能退出及大陆厂商产能释放……2022年度上海市公园十大特色植物区名单出炉!游园有方向了为推进城市公园一园一品建设,提升公园园艺品质和精细化管养水平,为市民游客提供更多优质的游园选择,2020年起,市公园管理事务中心每年对全市城市公园进行十大特色植物区评选,经材料……次数多性状变宝宝可能患上了腹泻病,家长应如何照护?各位家长朋友,冬季不仅要担心宝贝们是否有咳嗽、发热,还要注意是否发生婴幼儿腹泻。如果宝宝发生腹泻,家长应如何护理呢?首先了解一下什么是婴幼儿腹泻。婴幼儿腹泻也称腹泻病,是……真正厉害的人,从来都不着急人们往往总是羡慕他人拥有较好的结果,相比之下,自己却显得碌碌无为,太过平庸了。其实,用不着与人攀比,一个人真正的成长,都是由内而发的,与人比较往往是出于自己的虚荣心,如果太过执……时光音乐会2第二期歌单8飞行,周深合唱王大陆被骂拉低水平作为去年评分最高的音乐类综艺,《时光音乐会》第一季大获成功,并且贡献了不少出圈舞台,如郁可唯的《水中花》,林志炫的《奢香夫人》等,因此观众对第二季的期待值格外高。在上周五……莫言经典语录摘抄1、人生四然:来是偶然,去是必然,尽其当然,顺其自然。2、慢热,沉默,喜欢独处,三观正,不记仇,健忘体质,比你想象的深情,也比你以为的冷漠。3、一个人,风尘仆仆地活……助听器配戴时间越长声音越小?很多用户在佩戴助听器一段时间以后,不管是定制机还是耳背机都会出现声音变小的情况,现在给大家总结一下具体是因为什么原因导致这种情况发生:1、电池电量不足,会导致声音越来越小……世界电子政务发展现状全球发展趋势全球电子政务水平持续提高。2022年调查结果显示,互联网和数字技术在支持可持续发展和社会进步方面具有几乎无限的能力,全球电子政务发展水平持续提高,电子政务发展……
友情链接:快好找快生活快百科快传网中准网文好找聚热点快软网