[发明专利]共享资源访问方法和装置有效
申请号: | 201611116940.2 | 申请日: | 2016-12-07 |
公开(公告)号: | CN106776052B | 公开(公告)日: | 2019-12-10 |
发明(设计)人: | 涂克东 | 申请(专利权)人: | 金蝶软件(中国)有限公司 |
主分类号: | G06F9/52 | 分类号: | G06F9/52 |
代理公司: | 44224 广州华进联合专利商标代理有限公司 | 代理人: | 谢曲曲 |
地址: | 518000 广东省深圳市南山区*** | 国省代码: | 广东;44 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 共享资源 访问 方法 装置 | ||
1.一种共享资源访问方法,所述方法包括:
获取业务处理请求,开始业务处理;
当所述业务处理使用共享资源时,创建独立的内部事务调用所述共享资源;执行所述内部事务,并在所述内部事务完成时释放共享资源的资源锁;
执行与所述内部事务对应的外部事务,所述外部事务使用所述内部事务的处理结果,执行所述业务处理中所述外部事务的后续事务,所述后续事务调用所述外部事务的处理结果,其中,所述外部事务是所述业务处理中所述内部事务的后续事务。
2.根据权利要求1所述的方法,其特征在于,所述方法还包括:若所述外部事务执行过程正常,则进行提交操作,修改数据库对应的日志状态为提交;若所述外部事务执行过程出现异常,则进行回滚操作,修改数据库对应的日志状态为回滚。
3.根据权利要求2所述的方法,其特征在于,所述进行提交操作,包括:
调用在外部事务中注册的提交事件,在所述提交事件中提交外部事务的处理结果。
4.根据权利要求2所述的方法,其特征在于,所述进行回滚操作,包括:
调用在外部事务中注册的回滚事件,在所述回滚事件中释放所述内部事务的处理结果,将所述内部事务的处理结果返回到所述数据库中。
5.根据权利要求1所述的方法,其特征在于,所述方法还包括:当执行与所述内部事务对应的外部事务时,修改数据库对应的日志状态为进行中;定时检测数据库日志状态,若所述数据库日志状态为进行中的时间超过预设的时间阈值,则对外部事务的处理结果进行补偿。
6.一种共享资源访问装置,其特征在于,所述装置包括:
请求获取模块,用于获取业务处理请求,开始业务处理;
事务创建模块,用于当所述业务处理使用共享资源时,创建独立的内部事务调用所述共享资源;
第一事务执行模块,用于执行所述内部事务,并在所述内部事务完成时释放共享资源的资源锁;
第二事务执行模块,用于执行与所述内部事务对应的外部事务,所述外部事务使用所述内部事务的处理结果,执行所述业务处理中所述外部事务的后续事务,所述后续事务调用所述外部事务的处理结果,其中,所述外部事务是所述业务处理中所述内部事务的后续事务。
7.根据权利要求6所述的装置,其特征在于,所述装置还包括:
提交模块,用于若所述外部事务执行过程正常,则进行提交操作;
日志处理模块,用于修改数据库对应的日志状态为提交;
回滚模块,用于若所述外部事务执行过程出现异常,则进行回滚操作;
所述日志处理模块还用于修改数据库对应的日志状态为回滚。
8.根据权利要求7所述的装置,其特征在于,所述提交模块还用于调用在外部事件中注册的提交事件,在所述提交事件中提交外部事务的处理结果。
9.根据权利要求7所述的装置,其特征在于,所述回滚模块还用于调用在外部事务中注册的回滚事件,在所述回滚事件中释放所述内部事务的处理结果,将所述内部事务的处理结果返回所述数据库中。
10.根据权利要求7所述的装置,其特征在于,所述日志处理模块还用于当执行与所述内部事务对应的外部事务时,修改数据库对应的日志状态为进行中;
所述装置还包括:补偿模块,用于定时检测数据库日志状态,若所述数据库日志状态为进行中的时间超过预设的时间阈值,则对外部事务的处理结果进行补偿。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于金蝶软件(中国)有限公司,未经金蝶软件(中国)有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201611116940.2/1.html,转载请声明来源钻瓜专利网。