[发明专利]优化MySQL悲观锁的锁等待超时时间的方法及装置有效
申请号: | 201610318817.2 | 申请日: | 2016-05-13 |
公开(公告)号: | CN107368498B | 公开(公告)日: | 2020-08-04 |
发明(设计)人: | 湛滨瑜 | 申请(专利权)人: | 阿里巴巴集团控股有限公司 |
主分类号: | G06F16/23 | 分类号: | G06F16/23 |
代理公司: | 北京三友知识产权代理有限公司 11127 | 代理人: | 李辉;刘飞 |
地址: | 英属开曼*** | 国省代码: | 暂无信息 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 优化 mysql 悲观 等待 超时 时间 方法 装置 | ||
1.一种优化MySQL悲观锁的锁等待超时时间的方法,其特征在于,包括以下步骤:
在业务代码被执行的过程中,拦截所述业务代码中的切入点,获取目标参数,所述目标参数中包括指定的锁等待超时时间;
解析所述目标参数,获取指定的锁等待超时时间,所述指定的锁等待超时时间小于或等于MySQL数据库的全局锁等待超时时间;
执行与所述切入点对应的切面逻辑,以判断是否在所述指定的锁等待超时时间内获取到悲观锁。
2.根据权利要求1所述的优化MySQL悲观锁的锁等待超时时间的方法,其特征在于,所述切入点包括预先通过注解方式定义的锁等待注解,且所述业务代码中指定的锁等待超时时间的代码块上标识有所述锁等待注解,对应的,所述目标参数包括锁等待注解参数。
3.根据权利要求2所述的优化MySQL悲观锁的锁等待超时时间的方法,其特征在于,所述执行与所述切入点对应的切面逻辑,以判断是否在所述指定的锁等待超时时间内获取到悲观锁,包括:
创建一个线程池;
将所述锁等待注解作为Callable任务传递给所述线程池中的线程,获取Future对象;
指定所述Future对象获取悲观锁的超时时间为所述指定的锁等待超时时间;
使所述线程池中的线程执行所述Callable任务,并判断所述Future对象是否在所述指定的锁等待超时时间内获取到悲观锁;
如果未在所述指定的锁等待超时时间内获取到悲观锁,则抛出锁等待超时异常,并释放数据库连接。
4.根据权利要求3所述的优化MySQL悲观锁的锁等待超时时间的方法,其特征在于,所述释放数据库连接之前,还包括:
进行业务回滚。
5.根据权利要求3所述的优化MySQL悲观锁的锁等待超时时间的方法,其特征在于,还包括:
如果在所述指定的锁等待超时时间内获取到悲观锁,则获取悲观锁成功,并返回锁记录。
6.一种优化MySQL悲观锁的锁等待超时时间的装置,其特征在于,包括:
切入点拦截模块,用于在业务代码被执行的过程中,拦截所述业务代码中的切入点,获取目标参数,所述目标参数中包括指定的锁等待超时时间;
参数解析模块,用于解析所述目标参数,获取指定的锁等待超时时间,所述指定的锁等待超时时间小于或等于MySQL数据库的全局锁等待超时时间;
切面执行模块,用于执行与所述切入点对应的切面逻辑,以判断是否在所述指定的锁等待超时时间内获取到悲观锁。
7.根据权利要求6所述的优化MySQL悲观锁的锁等待超时时间的装置,其特征在于,所述切入点包括预先通过注解方式定义的锁等待注解,且所述业务代码中指定的锁等待超时时间的代码块上标识有所述锁等待注解,对应的,所述目标参数包括锁等待注解参数。
8.根据权利要求7所述的优化MySQL悲观锁的锁等待超时时间的装置,其特征在于,所述切面执行模块,包括:
线程池创建子模块,用于创建一个线程池;
Future对象获取子模块,用于将所述锁等待注解作为Callable任务传递给所述线程池中的线程,获取Future对象;
超时时间指定子模块,用于指定所述Future对象获取悲观锁的超时时间为所述指定的锁等待超时时间;
超时判断子模块,用于使所述线程池中的线程执行所述Callable任务,并判断所述Future对象是否在所述指定的锁等待超时时间内获取到悲观锁;
第一处理子模块,用于当所述超时判断子模块判断未在所述指定的锁等待超时时间内获取到悲观锁时,抛出锁等待超时异常,并释放数据库连接。
9.根据权利要求8所述的优化MySQL悲观锁的锁等待超时时间的装置,其特征在于,所述第一处理子模块还用于在释放数据库连接之前,进行业务回滚。
10.根据权利要求8所述的优化MySQL悲观锁的锁等待超时时间的装置,其特征在于,还包括:
第二处理子模块,用于当所述超时判断子模块判断在所述指定的锁等待超时时间内获取到悲观锁时,获取悲观锁成功,并返回锁记录。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于阿里巴巴集团控股有限公司,未经阿里巴巴集团控股有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201610318817.2/1.html,转载请声明来源钻瓜专利网。
- 上一篇:一种网页渲染方法及装置
- 下一篇:一种客户标签建模及推荐方法及装置