[发明专利]一种基于Flume的数据处理方法及装置有效
申请号: | 201611161579.5 | 申请日: | 2016-12-15 |
公开(公告)号: | CN106855837B | 公开(公告)日: | 2020-12-18 |
发明(设计)人: | 陈尧 | 申请(专利权)人: | 咪咕文化科技有限公司 |
主分类号: | G06F11/30 | 分类号: | G06F11/30 |
代理公司: | 北京派特恩知识产权代理有限公司 11270 | 代理人: | 张颖玲;蒋雅洁 |
地址: | 100032 北京市西城区德*** | 国省代码: | 北京;11 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 基于 flume 数据处理 方法 装置 | ||
本发明公开了一种基于Flume的数据处理方法,所述方法包括:在源文件读取完毕后,获取被读取完毕的所述源文件的源文件名称;保存所述源文件名称到源文件名称组;通过查询所述源文件名称组过滤掉已读取完毕的源文件。本发明还公开了一种基于Flume的数据处理装置。
技术领域
本发明涉及数据处理技术,尤其涉及一种基于Flume的数据处理方法及装置。
背景技术
Flume是Cloudera提供的一个高可用、高可靠、分布式的海量日志采集、聚合和传输的系统,Flume支持在日志系统中定制各类数据发送方,用于收集数据,其中,Flume提供了从控制台(console)、RPC(Thrift-RPC)、文件(text)、tail(UNIX tail)、syslog及命令执行(exec)等数据源上收集数据的能力;同时,Flume提供对数据进行简单处理,并写到各种可定制的数据接收方的能力。
图1为现有技术中Flume的系统架构示意图,如图1所示,采集agent负责进行数据采集,该数据指服务器等待采集的设备中的日志;在数据采集过程中,为agent指定监听目录后,agent默认读取该目录下所有文件的源文件;读取源文件的过程中,需要过滤已经传输完毕即已被读取的源文件。
现有技术中,对已经传输完毕的源文件进行过滤时,agent对已经传输完毕的源文件进行重命名;通过重命名,可以实现在已经传输完毕的源文件的名称中,加入用以表征“该源文件已被读取完毕”的标识。
但是,在重命名源文件后,可能导致agent或源文件所在的设备无法根据源文件的原有命名格式查找到具有原始名称的源文件,从而导致文件查找失败。
发明内容
为解决上述技术问题,本发明实施例提供一种基于Flume的数据处理方法及装置,能在不改变源文件名称的情况下,过滤已被读取的源文件。
本发明实施例的技术方案是这样实现的:
本发明实施例提供一种基于Flume的数据处理方法及装置,包括:在源文件读取完毕后,获取被读取完毕的所述源文件的源文件名称;保存所述源文件名称到源文件名称组;通过查询所述源文件名称组过滤掉已读取完毕的源文件。
上述方案中,所述保存所述源文件名称到源文件名称组,包括:保存所述源文件名称到表格文件中的源文件名称组;或者,保存所述源文件名称到数据库中的源文件名称组。
上述方案中,所述方法还包括:根据正则表达式对所述源文件进行过滤。
上述方案中,所述过滤掉已读取完毕的源文件之后,所述方法还包括:按照所述源文件的末次更改时间顺序优先读取末次更改时间最早的源文件。
上述方案中,所述根据正则表达式对所述源文件进行过滤之前,所述方法还包括:在不需要过滤的源文件名称中预先设置筛选字段。
本发明实施例提供一种基于Flume的数据处理装置,所述装置包括:
获取单元,用于在源文件读取完毕后,获取被读取完毕的所述源文件的源文件名称;保存单元,用于保存所述源文件名称到源文件名称组;过滤单元,用于通过查询所述源文件名称组过滤掉已读取完毕的源文件。
上述方案中,所述保存单元具体用于:保存所述源文件名称到表格文件中的源文件名称组;或者,保存所述源文件名称到数据库中的源文件名称组。
上述方案中,所述过滤单元,还用于根据正则表达式对所述源文件进行过滤。
上述方案中,所述装置还包括读取单元,用于按照所述源文件的末次更改时间顺序优先读取末次更改时间最早的源文件。
上述方案中,所述装置还包括预设单元,用于在不需要过滤的源文件名称中预先设置筛选字段。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于咪咕文化科技有限公司,未经咪咕文化科技有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201611161579.5/2.html,转载请声明来源钻瓜专利网。
- 上一篇:计算机功耗测试方法以及装置
- 下一篇:一种工作频率调整方法、装置及系统