Flume中的HDFSSink配置

Flume中的HDFS Sink配置参数说明。

官方配置网址:http://flume.apache.org/FlumeUserGuide.html#hdfs-sink

type:hdfs

path:hdfs的路径,需要包含文件系统标识,比如:hdfs://namenode/flume/flumedata/

filePrefix:默认值:FlumeData,写入hdfs的文件名前缀

fileSuffix:写入 hdfs 的文件名后缀,比如:.lzo .log等。

inUsePrefix:临时文件的文件名前缀,hdfs sink 会先往目标目录中写临时文件,再根据相关规则重命名成最终目标文件;

inUseSuffix:默认值:.tmp,临时文件的文件名后缀。

rollInterval:默认值:30:hdfs sink 间隔多长将临时文件滚动成最终目标文件,单位:秒;

如果设置成0,则表示不根据时间来滚动文件;

注:滚动(roll)指的是,hdfs sink 将临时文件重命名成最终目标文件,并新打开一个临时文件来写入数据;

rollSize:默认值:1024:当临时文件达到多少(单位:bytes)时,滚动成目标文件;如果设置成0,则表示不根据临时文件大小来滚动文件;

rollCount:默认值:10:当 events 数据达到该数量时候,将临时文件滚动成目标文件;如果设置成0,则表示不根据events数据来滚动文件;

idleTimeout:默认值:0:当目前被打开的临时文件在该参数指定的时间(秒)内,没有任何数据写入,则将该临时文件关闭并重命名成目标文件;

batchSize:默认值:100:每个批次刷新到 HDFS 上的 events 数量;

codeC:文件压缩格式,包括:gzip, bzip2, lzo, lzop, snappy

fileType:默认值:SequenceFile,文件格式,包括:SequenceFile, DataStream,CompressedStream

当使用DataStream时候,文件不会被压缩,不需要设置hdfs.codeC;

当使用CompressedStream时候,必须设置一个正确的hdfs.codeC值;

maxOpenFiles:默认值:5000:最大允许打开的HDFS文件数,当打开的文件数达到该值,最早打开的文件将会被关闭;

minBlockReplicas:默认值:HDFS副本数,写入 HDFS 文件块的最小副本数。

该参数会影响文件的滚动配置,一般将该参数配置成1,才可以按照配置正确滚动文件。

writeFormat:写 sequence 文件的格式。包含:Text, Writable(默认)

callTimeout:默认值:10000,执行HDFS操作的超时时间(单位:毫秒);

threadsPoolSize:默认值:10,hdfs sink 启动的操作HDFS的线程数。

rollTimerPoolSize:默认值:1,hdfs sink 启动的根据时间滚动文件的线程数。

kerberosPrincipal:HDFS安全认证kerberos配置;

kerberosKeytab:HDFS安全认证kerberos配置;

proxyUser:代理用户

round:默认值:false,是否启用时间上的”舍弃”;

roundValue:默认值:1,时间上进行“舍弃”的值;

roundUnit:默认值:seconds,时间上进行”舍弃”的单位,包含:second,minute,hour

示例:

a1.sinks.k1.hdfs.path = /flume/events/%y-%m-%d/%H%M/%S

a1.sinks.k1.hdfs.round = true

a1.sinks.k1.hdfs.roundValue = 10

a1.sinks.k1.hdfs.roundUnit = minute

当时间为2015-10-16 17:38:59时候,hdfs.path依然会被解析为:/flume/events/20151016/17:30/00

因为设置的是舍弃10分钟内的时间,因此,该目录每10分钟新生成一个。

timeZone:默认值:Local Time,时区。

useLocalTimeStamp:默认值:flase,是否使用当地时间。

closeTries:默认值:0,hdfs sink 关闭文件的尝试次数;

如果设置为1,当一次关闭文件失败后,hdfs sink将不会再次尝试关闭文件,这个未关闭的文件将会一直留在那,并且是打开状态。

设置为0,当一次关闭失败后,hdfs sink会继续尝试下一次关闭,直到成功。

retryInterval:默认值:180(秒),hdfs sink 尝试关闭文件的时间间隔,如果设置为0,表示不尝试,相当于于将hdfs.closeTries设置成1.

serializer:默认值:TEXT,序列化类型。

比如:

agent1.sinks.sink1.type = hdfs

agent1.sinks.sink1.hdfs.path = hdfs://cdh5/tmp/data/%Y%m%d

agent1.sinks.sink1.hdfs.filePrefix = log_%Y%m%d_%H

agent1.sinks.sink1.hdfs.fileSuffix = .lzo

agent1.sinks.sink1.hdfs.useLocalTimeStamp = true

agent1.sinks.sink1.hdfs.writeFormat = Text

agent1.sinks.sink1.hdfs.fileType = CompressedStream

agent1.sinks.sink1.hdfs.rollCount = 0

agent1.sinks.sink1.hdfs.rollSize = 0

agent1.sinks.sink1.hdfs.rollInterval = 600

agent1.sinks.sink1.hdfs.codeC = lzop

agent1.sinks.sink1.hdfs.batchSize = 100

agent1.sinks.sink1.hdfs.threadsPoolSize = 10

agent1.sinks.sink1.hdfs.idleTimeout = 0

agent1.sinks.sink1.hdfs.minBlockReplicas = 1

上面的配置中,在 HDFS 的 /tmp/data/ 目录下,每天生成一个格式为20151016的目录,目标文件每10分钟生成一个,目标文件格式为:log_20151016_13.1444973768543.lzo目标文件采用lzo压缩。

附上测试用的telnet.py代码:

import time

import telnetlib

if __name__ = '__main__':

host = 'localhost'

port = 44444

tn = telnetlib.Telnet(host=host,port=port)

for i in range(10000):

print i

tn.write(str(i) + '\n')

time.sleep(1)

时间: 2024-10-29 04:32:03

Flume中的HDFSSink配置的相关文章

Flume环境部署和配置详解及案例大全_Linux

一.什么是Flume? flume 作为 cloudera 开发的实时日志收集系统受到了业界的认可与广泛应用.Flume 初始的发行版本目前被统称为 Flume OGoriginal generation属于 cloudera.但随着 FLume 功能的扩展Flume OG 代码工程臃肿.核心组件设计不合理.核心配置不标准等缺点暴露出来尤其是在 Flume OG 的最后一个发行版本 0.94.0 中日志传输不稳定的现象尤为严重为了解决这些问题2011 年 10 月 22 号cloudera 完成

深入理解php中的ini配置(1)

这篇文章不会详细叙述某个ini配置项的用途,这些在手册上已经讲解的面面俱到.我只是想从某个特定的角度去挖掘php的实现机制,会涉及到一些php内核方面的知识:-)   使用php的同学都知道php.ini配置的生效会贯穿整个SAPI的生命周期.在一段php脚本的执行过程中,如果手动修改ini配置,是不会启作用的.此时如果无法重启apache或者nginx等,那么就只能显式的在php代码中调用ini_set接口.ini_set是php向我们提供的一个动态修改配置的函数,需要注意的是,利用ini_s

.NET 2.0 中的自定义配置处理

引言 现代软件开发中,各种技术.技巧越来越依赖配置,譬如客户端对用户体验的个性化设置.系统的各种运行时参数设置.可插拔的插件机制.基于配置的IoC架构模式等.配置方式也从最初的二进制存储格式逐步过度到INI文本格式直至今时所广泛使用的Xml格式.使用Xml格式进行配置,大大提高了对设置数据的表现能力,但是在 .NET 1.x 中对Xml配置的操控还有诸多不便,尤其是对Xml配置的存储同步机制很不完善,而从 .NET 2.0 开始,框架提供了更丰富和易于操控使用的机制. .NET 中的配置文件(X

dom4j实战(一)——使用dom4j从XML中读取数据源配置

目前XML文件的应用越来越广泛,而操作XML的技术更有不少,其中以dom4j强大的性能,丰富的API以及简单的易用性,受到了很多人的喜爱,本文以一个读取数据源的小例子,来说明一下dom4j的一些基本操作. dom4j是一个Java的XML API,同时也是一种解析XML文档的开源软件.由dom4j.org开发,具有性能优异.功能强大和极端易用的特点,大名鼎鼎的Hibernate就是用它来读取配置文件滴.本文只是对dom4j的一些基本操作进行说明,不包含深入分析.(本文最后有源码和相关JAR包下载

Struts 2中的constant配置详解_java

1.<constant name="struts.i18n.encoding" value="UTF-8" /> 指定Web应用的默认编码集,相当于调用 HttpServletRequest的setCharacterEncoding方法. 2.<constant name="struts.i18n.reload" value="false"/> 该属性设置是否每次HTTP请求到达时,系统都重新加载资源文

Hadoop-2.8.0集群搭建、hadoop源码编译和安装、host配置、ssh免密登录、hadoop配置文件中的参数配置参数总结、hadoop集群测试,安装过程中的常见错误

25.集群搭建 25.1 HADOOP集群搭建 25.1.1集群简介 HADOOP集群具体来说包含两个集群:HDFS集群和YARN集群,两者逻辑上分离,但物理上常在一起 HDFS集群: 负责海量数据的存储,集群中的角色主要有NameNode / DataNode YARN集群: 负责海量数据运算时的资源调度,集群中的角色主要有 ResourceManager /NodeManager 25.1.2服务器准备 本案例使用虚拟机服务器来搭建HADOOP集群,所用软件及版本: ü Vmware 11.

phpstrom10.0-phpStrom10.0中的环境配置

问题描述 phpStrom10.0中的环境配置 本人新手一枚,现在学习php,公司使用的php ide是phpstrom10.0的,找了很久都没找到可以用的配置方法,不知道是什么原因.想看看论坛里面的高手能不能帮我解决下这个问题.我的目的很简单就是把环境配置好,写一个简单的hello world之类的能在浏览器访问. 解决方案 安装XAMPP 设置好网站根目录,假设设置到D:WWW 然后你直接访问127.0.0.1 就可以 解决方案二: 本地安装一个XAMPP 就可以 具体的可以联系我 phps

vmware-请问centos中是如何配置网关的

问题描述 请问centos中是如何配置网关的 在学习<网络攻防与技术实践>,本书实例中有一个是在VMware虚拟机中安装centos,是配置蜜网网关虚拟机 .在安装好虚拟机后打开虚拟机配置密网网管,下面 进入centos网关调试界面,有没有哪位老师知道这个界面是如何进入的 解决方案 补充一下Honeywall是这个centos的名称 解决方案二: [Linux]CentOS网关服务器配置

如何在CentOS中安装及配置Asterisk

Asterisk 是第一套以开放源代码软件实作的 用户交换机 (PBX) 系统.Asterisk 由 Digium 的创办人 Mark Spencer 于 1999 年间,他还在奥本大学念书时开发出.与其他的用户交换机系统相同,Asterisk 同样支援电话拨打另一只分机,和拨打到公共交换电话网与IP电话系统.Asterisk 这个名称源自于星号 "*". Asterisk 采用双轨授权模式,http://www.aliyun.com/zixun/aggregation/8173.ht