[发明专利]数据写请求处理方法、装置及分布式数据存储系统有效
| 申请号: | 201710080036.9 | 申请日: | 2017-02-14 |
| 公开(公告)号: | CN106878414B | 公开(公告)日: | 2019-06-07 |
| 发明(设计)人: | 徐锐波;程卓 | 申请(专利权)人: | 北京奇虎科技有限公司 |
| 主分类号: | H04L29/08 | 分类号: | H04L29/08 |
| 代理公司: | 北京市浩天知识产权代理事务所(普通合伙) 11276 | 代理人: | 宋菲;陈翠 |
| 地址: | 100088 北京市西城区新*** | 国省代码: | 北京;11 |
| 权利要求书: | 查看更多 | 说明书: | 查看更多 |
| 摘要: | |||
| 搜索关键词: | 数据 请求 处理 方法 装置 分布式 存储系统 | ||
1.一种数据写请求处理方法,所述方法基于调用端发送的数据写请求向存储节点中写入数据,其中数据写请求包含主请求和至少一个子请求,所述方法包括:
对于每一个子请求,调用访问接口从全局变量中选择待写入数据的存储节点的存储节点地址,向所述存储节点发送子请求,其中将选择的存储节点地址保存至子请求的上下文中;
从子请求的上下文中提取出所选择的存储节点地址,并保存至所述存储节点的上下文中;
从所述存储节点的上下文中提取出存储节点地址,与存储节点建立连接,将数据写入到相应的存储节点。
2.根据权利要求1所述的方法,其中,在发送子请求之前,所述方法还包括:
加载配置文件,获取存储节点地址列表相关的配置信息;
将存储节点地址列表保存到所述全局变量中,生成所述全局变量的访问接口。
3.根据权利要求1或2所述的方法,其中,在发送子请求之前,所述方法还包括:
获取主请求的上下文;
判断所述主请求的上下文是否已创建;
若所述主请求的上下文未创建,创建所述主请求的上下文,并将所述主请求的上下文与主请求关联。
4.根据权利要求3所述的方法,其中,在发送子请求之前,所述方法还包括:若所述主请求的上下文已创建,判断待写入数据的存储节点是否为空;若是,则向发送数据写请求的调用端返回响应结果;
若否,则执行发送子请求的步骤。
5.根据权利要求1或2所述的方法,其中,在将数据写入到相应的存储节点之后,所述方法还包括:
调用子请求完成回调函数,回到主循环过程中;
在主循环过程中,调用用于处理子请求的处理器的入口函数,利用所述用于处理子请求的处理器处理下一个子请求。
6.根据权利要求5所述的方法,其中,在将数据写入到相应的存储节点之后,所述方法还包括:保存所述子请求的上下文。
7.根据权利要求5所述的方法,其中,所述子请求的上下文中定义有状态字段;
在将数据写入到相应的存储节点之后,所述方法还包括:更新子请求的上下文的状态字段;
所述用于处理子请求的处理器处理下一个子请求具体为:所述用于处理子请求的处理器根据更新的状态字段识别出数据写请求所处的阶段,以便处理下一个子请求。
8.根据权利要求1或2所述的方法,其中,所述方法利用部署在调用端与存储节点之间的分布式组件实现,所述分布式组件为反向代理服务器。
9.根据权利要求8所述的方法,其中,所述反向代理服务器为Nginx服务器。
10.一种数据写请求处理装置,所述装置基于调用端发送的数据写请求向存储节点中写入数据,其中数据写请求包含主请求和至少一个子请求,所述装置包括:用于处理子请求的处理器;
所述用于处理子请求的处理器包括:
选择单元,适于对于每一个子请求,调用访问接口从全局变量中选择待写入数据的存储节点的存储节点地址;
子请求处理单元,适于向所述存储节点发送子请求,其中将选择的存储节点地址保存至子请求的上下文中;
提取单元,适于从子请求的上下文中提取出所选择的存储节点地址;
上下文写入单元,适于将提取出的存储节点地址保存至所述存储节点的上下文中;
连接单元,适于从所述存储节点的上下文中提取出存储节点地址,与存储节点建立连接;
数据写入单元,适于将数据写入到相应的存储节点。
11.根据权利要求10所述的装置,其中,所述装置还包括:初始化模块,适于加载配置文件,获取存储节点地址列表相关的配置信息;将存储节点地址列表保存到所述全局变量中,生成所述全局变量的访问接口。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于北京奇虎科技有限公司,未经北京奇虎科技有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201710080036.9/1.html,转载请声明来源钻瓜专利网。
- 上一篇:汽车维修设备网络管理系统
- 下一篇:数据消费的负载均衡方法及装置
- 数据显示系统、数据中继设备、数据中继方法、数据系统、接收设备和数据读取方法
- 数据记录方法、数据记录装置、数据记录媒体、数据重播方法和数据重播装置
- 数据发送方法、数据发送系统、数据发送装置以及数据结构
- 数据显示系统、数据中继设备、数据中继方法及数据系统
- 数据嵌入装置、数据嵌入方法、数据提取装置及数据提取方法
- 数据管理装置、数据编辑装置、数据阅览装置、数据管理方法、数据编辑方法以及数据阅览方法
- 数据发送和数据接收设备、数据发送和数据接收方法
- 数据发送装置、数据接收装置、数据收发系统、数据发送方法、数据接收方法和数据收发方法
- 数据发送方法、数据再现方法、数据发送装置及数据再现装置
- 数据发送方法、数据再现方法、数据发送装置及数据再现装置





