[发明专利]数据访问的方法及服务器在审
申请号: | 201810929639.6 | 申请日: | 2018-08-15 |
公开(公告)号: | CN109324877A | 公开(公告)日: | 2019-02-12 |
发明(设计)人: | 余九峰;史英端 | 申请(专利权)人: | 北京天元创新科技有限公司 |
主分类号: | G06F9/46 | 分类号: | G06F9/46;G06F9/48;G06F9/52 |
代理公司: | 北京路浩知识产权代理有限公司 11002 | 代理人: | 王莹;吴欢燕 |
地址: | 100193 北京市海淀区*** | 国省代码: | 北京;11 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 控制锁 任务访问 空闲状态 数据访问 数据访问请求 服务器 任务发起 任务发送 任务分配 任务执行 同一时段 占用状态 检测 分配 保证 访问 | ||
本发明实施例提供一种数据访问的方法及服务器,该方法包括:对于多个任务中任一任务,若当前检测到任一任务发起的数据访问请求且控制锁处于空闲状态,则为任一任务分配控制锁,并将控制锁设置为占用状态,以使得任一任务访问指定数据;其中,控制锁用于控制多个任务访问指定数据。本发明实施例提供的方法,在多个任务访问同一指定数据时,通过接收多个任务中任一任务发送的数据访问请求,设置控制锁,控制任务访问所述指定数据,再判断控制锁是否处于空闲状态,若控制锁处于空闲状态,则将控制锁分配给任务,以使得任务执行数据访问的操作,从而保证了同一时段只有一个任务对指定数据进行访问。
技术领域
本发明涉及计算机技术领域,尤其涉及一种数据访问的方法及服务器。
背景技术
目前,各种分布式应用级和系统软件越来越普及。在分布式系统中,多个进程需要访问相同的数据或共享相同的计算资源。在相关技术中,多个进程在访问同一数据时,可能会出现如下情况:进程1需要获取某一时刻下的数据A,而进程1在获取数据A的过程中,可能会存在其它进程对数据A的具体数值进行了修改,从而导致进程1获取到的不是该时刻下的数据A,而获取到的是其它进程对该时刻下的数据A进行修改后的修改结果,进而导致进程1数据访问出错。
发明内容
针对现有技术中存在的问题,本发明实施例提供一种数据访问的方法及服务器。
第一方面,本发明实施例提供一种数据访问的方法,包括:
对于多个任务中任一任务,若当前检测到所述任一任务发起的数据访问请求且控制锁处于空闲状态,则为所述任一任务分配所述控制锁,并将所述控制锁设置为占用状态,以使得所述任一任务访问指定数据;其中,所述控制锁用于控制所述多个任务访问所述指定数据。
第二方面,本发明实施例提供一种服务器,包括:
判断模块,用于对于多个任务中任一任务,若当前检测到所述任一任务发起的数据访问请求且控制锁处于空闲状态,则为所述任一任务分配所述控制锁,并将所述控制锁设置为占用状态,以使得所述任一任务访问指定数据;其中,所述控制锁用于控制所述多个任务访问所述指定数据。
第三方面,本发明实施例提供一种电子设备,包括存储器、处理器及存储在存储器上并可在处理器上运行的计算机程序,所述处理器执行所述程序时实现本发明第一方面实施例提供的数据访问的方法的步骤。
第四方面,本发明实施例提供一种非暂态计算机可读存储介质,其上存储有计算机程序,该计算机程序被处理器执行时实现本发明第一方面实施例提供的数据访问的方法的步骤。
本发明实施例提供的方法,在多个任务访问同一指定数据时,通过接收多个任务中任一任务发送的数据访问请求,设置控制锁,控制任务访问所述指定数据,再判断控制锁是否处于空闲状态,若控制锁处于空闲状态,则将控制锁分配给任务,以使得任务执行数据访问的操作,从而保证了同一时段只有一个任务对指定数据进行访问。
附图说明
图1为本发明实施例提供的数据访问的方法的示意图;
图2为本发明实施例提供的一种服务器的结构示意图;
图3为本发明实施例提供的一种电子设备的结构示意图。
具体实施方式
为使本发明实施例的目的、技术方案和优点更加清楚,下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚地描述,显然,所描述的实施例是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于北京天元创新科技有限公司,未经北京天元创新科技有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201810929639.6/2.html,转载请声明来源钻瓜专利网。