[发明专利]一种利用代理程序更新缓存的方法、装置及系统在审
申请号: | 201710708043.9 | 申请日: | 2017-08-17 |
公开(公告)号: | CN109947780A | 公开(公告)日: | 2019-06-28 |
发明(设计)人: | 陈磊 | 申请(专利权)人: | 天津数观科技有限公司 |
主分类号: | G06F16/23 | 分类号: | G06F16/23;G06F16/2455;G06F11/30 |
代理公司: | 北京金信知识产权代理有限公司 11225 | 代理人: | 黄威;喻嵘 |
地址: | 300300 天津市西青区滨海高新区*** | 国省代码: | 天津;12 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 缓存 数据库 操作命令 代理程序 装置及系统 内容信息 数据发生 更新 数据更新 预设条件 判定 拦截 灵活 保证 分析 | ||
本发明公开了一种利用代理程序更新缓存的方法、装置及系统,所述缓存为数据库对应的缓存,所述方法包括:利用所述代理程序拦截发送给所述数据库的操作命令;获取所述操作命令包含的内容信息,并当所述内容信息符合预设条件时,判定所述数据库中的数据发生变化;根据变化后的所述数据库中的数据更新所述缓存。该方法能够直接的对发送给数据库的操作命令进行分析,从而准确的得知数据库中的数据是否发生变化,进而能够在数据发生变化的同时灵活而及时的更新缓存,保证正确的使用最新的缓存来对数据库中的数据进行操作。
技术领域
本发明涉及数据处理领域,特别涉及一种利用代理程序更新缓存的方法,一种数据分析系统更新缓存的方法,一种利用代理程序更新缓存的装置和一种数据分析系统。
背景技术
在对数据库存储的数据进行处理时,为了提高调用数据时的响应速度,提高数据处理的效率,需要建立并使用缓存,例如使用根据查询条件建立查询结果的缓存。但是一般情况下,为了将缓存与数据库中的数据及时对应,会根据数据业务定时更新缓存,例如数据分析系统一般会建立数据库,数据库每天更新一次,那么缓存也会采用每天更新的办法,但这种定期的缓存更新办法不灵活,有时因为数据更新频繁而缓存没有及时更新而导致数据无法使用或出现错误,或者数据更新频率极低而缓存更新频率极高导致系统资源的浪费。
发明内容
本发明实施例的目的在于提供一种利用代理程序更新缓存的方法、装置及系统,该方法能够灵活而及时的更新缓存,保证正确的使用最新的缓存来对数据库中的数据进行操作。
为了解决上述技术问题,本发明实施例采用了如下技术方案:一种利用代理程序更新缓存的方法,所述缓存为数据库对应的缓存,所述方法包括:
利用所述代理程序拦截发送给所述数据库的操作命令;
获取所述操作命令包含的内容信息,并当所述内容信息符合预设条件时,判定所述数据库中的数据发生变化;
根据变化后的所述数据库中的数据更新所述缓存。
作为优选,所述代理程序为数据库端口代理程序,所述利用所述代理程序拦截发送给所述数据库的操作命令包括:将所述数据库端口代理程序安装在所述数据库上;利用所述数据库端口代理程序拦截发送至所述数据库的输入端口的操作命令。
作为优选,所述获取所述操作命令包含的内容信息,并当所述内容信息符合预设条件时,判定所述数据库中的数据发生变化具体为:分析所述操作命令,获取所述操作命令包含的命令种类;当所述命令种类中包含非查询命令类型时,判定所述数据库中的数据发生变化。
作为优选,所述缓存在更新过程中不间断运行。
作为优选,所述方法还包括:所述代理程序将所述操作命令转发给所述数据库。
本发明实施例还提供了一种数据分析系统更新缓存的方法,使用如上所述的利用代理程序更新缓存的方法,对所述数据分析系统的数据库对应的缓存进行更新操作。
本发明实施例还提供了一种利用代理程序更新缓存的装置,所述缓存为数据库对应的缓存,所述装置包括代理程序,监控模块和更新模块:
所述代理程序配置为拦截发送给所述数据库的操作命令;
所述监控模块配置为获取所述操作命令包含的内容信息,并当所述内容信息符合预设条件时,判定所述数据库中的数据发生变化;
所述更新模块与缓存连接,所述更新模块配置为根据变化后的所述数据库中的数据更新所述缓存。
作为优选,所述代理程序为数据库端口代理程序,所述数据库端口代理程序安装在所述数据库上,所述数据库端口代理程序配置为拦截发送至所述数据库的输入端口的操作命令。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于天津数观科技有限公司,未经天津数观科技有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201710708043.9/2.html,转载请声明来源钻瓜专利网。