[发明专利]消息存储方法、装置、设备及存储介质有效
申请号: | 201811597366.6 | 申请日: | 2018-12-26 |
公开(公告)号: | CN109739822B | 公开(公告)日: | 2021-04-13 |
发明(设计)人: | 徐朋朋 | 申请(专利权)人: | 中国移动通信集团江苏有限公司;中国移动通信集团有限公司 |
主分类号: | G06F16/18 | 分类号: | G06F16/18;G06F16/172 |
代理公司: | 北京东方亿思知识产权代理有限责任公司 11258 | 代理人: | 彭琼 |
地址: | 210029 江*** | 国省代码: | 江苏;32 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 消息 存储 方法 装置 设备 介质 | ||
1.一种消息存储方法,其特征在于,所述方法包括:
获得待存储消息;
将所述待存储消息存储在消息日志文件中;
从检查点文件中提取最大自增消息序列值对应的消息在消息日志文件中的偏移地址;
根据所述偏移地址,获取所述偏移地址对应的消息的自增消息序列值;
比较获得的自增消息序列值与所述待存储消息对应的自增消息序列值;
若所述获得的自增消息序列值不小于所述待存储消息对应的自增消息序列值,则生成所述待存储消息对应的消息索引信息;
将所述消息索引信息存储在消息索引文件中。
2.根据权利要求1所述的方法,其特征在于,所述方法还包括:
若所述获得的自增消息序列值小于所述待存储消息对应的自增消息序列值,则根据所述待存储消息对应的自增消息序列值、所述待存储消息在所述消息日志文件中的偏移地址、所述待存储消息占用的字节数与所述待存储消息对应的校验和占用的字节数之和,生成所述待存储消息对应的消息索引信息。
3.权利要求2所述的方法,其特征在于,所述方法还包括:
将所述检查点文件中存储的最大自增消息序列值对应的消息在消息日志文件中的偏移地址,修改为所述待存储消息在所述消息日志文件中的偏移地址。
4.根据权利要求1所述的方法,其特征在于,所述若所述获得的自增消息序列值不小于所述待存储消息对应的自增消息序列值,则生成所述待存储消息对应的消息索引信息,包括:
若所述获得的自增消息序列值不小于所述待存储消息对应的自增消息序列值,则将所述待存储消息对应的自增消息序列值修改为用于表示消息为重复消息的标识信息,根据所述标识信息、所述待存储消息在所述消息日志文件中的偏移地址、所述待存储消息占用的字节数与所述待存储消息对应的校验和占用的字节数之和,生成所述待存储消息对应的消息索引信息。
5.根据权利要求1所述的方法,其特征在于,消息日志文件的文件大小为M字节,消息索引文件的文件大小为N字节,消息索引文件中每条消息索引信息占用的字节数相同。
6.根据权利要求1所述的方法,其特征在于,消息日志文件的文件名称为消息日志文件的起始偏移量;消息索引文件的文件名称为消息索引文件的起始偏移量。
7.一种消息存储装置,其特征在于,所述装置包括:
第一获取模块,用于获取待存储消息;
第一存储模块,用于将所述待存储消息存储在消息日志文件中;
提取模块,用于从检查点文件中提取最大自增消息序列值对应的消息在消息日志文件中的偏移地址;
第二获取模块,用于根据所述偏移地址,获取所述偏移地址对应的消息的自增消息序列值;
比较模块,用于比较获得的自增消息序列值与所述待存储消息对应的自增消息序列值;
生成模块,用于若所述获得的自增消息序列值不小于所述待存储消息对应的自增消息序列值,则生成所述待存储消息对应的消息索引信息;
第二存储模块,用于将所述消息索引信息存储在消息索引文件中。
8.根据权利要求7所述的装置,其特征在于,所述生成模块,具体还用于:
若所述获得的自增消息序列值小于所述待存储消息对应的自增消息序列值,则根据所述待存储消息对应的自增消息序列值、所述待存储消息在所述消息日志文件中的偏移地址、所述待存储消息占用的字节数与所述待存储消息对应的校验和占用的字节数之和,生成所述待存储消息对应的消息索引信息。
9.根据权利要求8所述的装置,其特征在于,所述装置还包括:
修改模块,用于将所述检查点文件中存储的最大自增消息序列值对应的消息在消息日志文件中的偏移地址,修改为所述待存储消息在所述消息日志文件中的偏移地址。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于中国移动通信集团江苏有限公司;中国移动通信集团有限公司,未经中国移动通信集团江苏有限公司;中国移动通信集团有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201811597366.6/1.html,转载请声明来源钻瓜专利网。