基于Flume的美团日志收集系统二

基于Flume的美团日志收集系统二

ID:38623566

大小:165.00 KB

页数:8页

时间:2019-06-16

基于Flume的美团日志收集系统二_第1页
基于Flume的美团日志收集系统二_第2页
基于Flume的美团日志收集系统二_第3页
基于Flume的美团日志收集系统二_第4页
基于Flume的美团日志收集系统二_第5页
基于Flume的美团日志收集系统二_第6页
基于Flume的美团日志收集系统二_第7页
基于Flume的美团日志收集系统二_第8页
资源描述:

《基于Flume的美团日志收集系统二》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、基于Flume的美团日志收集系统(二)改进和优化在《基于Flume的美团日志收集系统(一)架构和设计》中,我们详述了基于Flume的美团日志收集系统的架构设计,以及为什么做这样的设计。在本节中,我们将会讲述在实际部署和使用过程中遇到的问题,对Flume的功能改进和对系统做的优化。1Flume的问题总结在Flume的使用过程中,遇到的主要问题如下:a.Channel“水土不服”:使用固定大小的MemoryChannel在日志高峰时常报队列大小不够的异常;使用FileChannel又导致IO繁忙的问题;b.H

2、dfsSink的性能问题:使用HdfsSink向Hdfs写日志,在高峰时间速度较慢;c.系统的管理问题:配置升级,模块重启等;2Flume的功能改进和优化点从上面的问题中可以看到,有一些需求是原生Flume无法满足的,因此,基于开源的Flume我们增加了许多功能,修改了一些Bug,并且进行一些调优。下面将对一些主要的方面做一些说明。2.1增加Zabbixmonitor服务一方面,Flume本身提供了http,ganglia的监控服务,而我们目前主要使用zabbix做监控。因此,我们为Flume添加了zab

3、bix监控模块,和sa的监控服务无缝融合。另一方面,净化Flume的metrics。只将我们需要的metrics发送给zabbix,避免zabbixserver造成压力。目前我们最为关心的是Flume能否及时把应用端发送过来的日志写到Hdfs上,对应关注的metrics为:·Source:接收的event数和处理的event数·Channel:Channel中拥堵的event数·Sink:已经处理的event数2.2为HdfsSink增加自动创建index功能首先,我们的HdfsSink写到hadoop的

4、文件采用lzo压缩存储。HdfsSink可以读取hadoop配置文件中提供的编码类列表,然后通过配置的方式获取使用何种压缩编码,我们目前使用lzo压缩数据。采用lzo压缩而非bz2压缩,是基于以下测试数据:event大小(Byte)sink.batch-sizehdfs.batchSize压缩格式总数据大小(G)耗时(s)平均events/s压缩后大小(G)54430010000bz29.1244868331.3654430010000lzo9.1612273333.49其次,我们的HdfsSink增加了

5、创建lzo文件后自动创建index功能。Hadoop提供了对lzo创建索引,使得压缩文件是可切分的,这样HadoopJob可以并行处理数据文件。HdfsSink本身lzo压缩,但写完lzo文件并不会建索引,我们在close文件之后添加了建索引功能。/** *RenamebucketPathfilefrom.tmptopermanentlocation. */ privatevoidrenameBucket()throwsIOException,InterruptedException{ if(bucket

6、Path.equals(targetPath)){ return; } finalPathsrcPath=newPath(bucketPath); finalPathdstPath=newPath(targetPath); callWithTimeout(newCallRunner(){ @Override publicObjectcall()throwsException{ if(fileSystem.exists(srcPath)){//couldblock LOG.info("R

7、enaming"+srcPath+"to"+dstPath); fileSystem.rename(srcPath,dstPath);//couldblock //indexthedstPathlzofile if(codeC!=null&&".lzo".equals(codeC.getDefaultExtension())){ LzoIndexerlzoIndexer=newLzoIndexer(newConfiguration()); lzoIndexer.index(dstPath); } } r

8、eturnnull; } }); }2.3增加HdfsSink的开关我们在HdfsSink和DualChannel中增加开关,当开关打开的情况下,HdfsSink不再往Hdfs上写数据,并且数据只写向DualChannel中的FileChannel。以此策略来防止Hdfs的正常停机维护。2.4增加DualChannelFlume本身提供了MemoryChannel和FileChannel。MemoryChannel处理速度快,

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。