大数据01-Flume 日志收集

作为大数据,我们需要获取大数据来源,今天把日志收集这块整理下,采用 Apache 的 开源技术 Flume 作为日志收集的工具。接下来根据官方文档按照自己的理解进行梳理。

1、理论理解

Flume 是一个日志采集模块,需要根据源、通道、目的地三个组件来完成把源的日志或者信息通过这个管道运输到另外一个地方,如下图


官方数据流模型-单个代理

当然管道的目的地(Sink)也可以是下一个模块的源,如下图


官方数据流模型-多代理

一个管道可以有多个源,如下图
官方数据流模型-多源

一旦有多个代理进行嵌套,他们之间基本是采用 avro 这样的source和sink。

2、搭建环境

环境搭建非常简单,首先是基于 java,所以需要 JDK 支持,这里使用目前最新的 Flume 1.8.0,官方说明需要至少 JDK1.8以上。
按照 JDK 不再描述,装完之后,我们需要下载最新的 Flume 安装包
链接地址
为了使用方便,解压该包之后,配置下环境变量

环境变量

之后再新开命令窗口,输入

flume-ng help
测试命令

可以看到基本信息内容,其中包括命令和参数,其中命令如下

help display this help text,显示帮助信息
agent run a Flume agent ,运行一个 flume 代理
avro-client run an avro Flume client 运行一个 avro 客户端
version show Flume version info
参数部分较多,常用的是
--conf,-c <conf> use configs in <conf> directory
--name,-n <name> the name of this agent (required)
--conf-file,-f <file> specify a config file (required if -z missing)
还是比较好理解的。接下来我们来运行官方的一个例子

3、从指定网络端口采集数据到控制台

官方有个例子的配置文件,其实 flume 大部分功能只需要配置就可以搞定,特殊的需要额外的第三方包,或者自行定义 Source、Channel 和 Sink 组件。这里我们进行简单的配置,能够入门即可。

为了方便,把配置文件统一放在 $FLUME_HOME/conf/目录下,我们在该目录下建立一个配置文件叫 example.conf,内容如下,说明非常细致了。

#使用 Flume 的关键就是写配置文件
# A)配置 Source
# B) 配置 Channel
# C) 配置 Sink
# D) 配置 把三组件串起来
#下面是在这个 agent 上命名组件
# a1 是 agent的名称
# r1是数据源的名称,a1可能有多个数据源,这里是复数
# k1是sink 的名称
# c1是 channel 的名称
a1.sources = r1
a1.sinks = k1
a1.channels = c1

#配置 source
# a1的数据源,其中叫 r1的进行配置
# https://flume.apache.org/FlumeUserGuide.html#netcat-tcp-source
a1.sources.r1.type = netcat
a1.sources.r1.bind = localhost
a1.sources.r1.port = 44444

# a1的 sinks 中叫 k1的进行配置
# https://flume.apache.org/FlumeUserGuide.html#logger-sink
a1.sinks.k1.type = logger

# 使用一个带有 buffer 的内存式的 channel
# https://flume.apache.org/FlumeUserGuide.html#memory-channel
a1.channels.c1.type = memory
#a1.channels.c1.capacity = 1000
#a1.channels.c1.transactionCapacity = 100

# Bind the source and sink to the channel
# 配置源到 channel 注意复数,一个 source 可以输出到多个 channel
# 配置 sink 和 channel,一个 channel 可以输出到的 sink 只有1个
a1.sources.r1.channels = c1
a1.sinks.k1.channel = c1

有了上面的配置文件,就需要运行他了,根据官方的提示,我们得知

#运行 
$ bin/flume-ng agent \ 表示运行代理
--conf $FLUME_HOME/conf \ 表示配置文件的目录
--conf-file $FLUME_HOME/conf/example.conf \ 指定配置文件
--name a1 \ 指定运行的代理名称
-Dflume.root.logger=DEBUG,console
-Dorg.apache.flume.log.printconfig=true
-Dorg.apache.flume.log.rawdata=true

然后我们telnet 到本地44444端口,进行消息发送,看看控制台有什么变化


image

接收到的数据

Event: { headers:{} body: 68 61 68 61 61 68 0D                            hahaah. }

一个 Event 就是 Flume 的一个最小单元,包括可选 headers 和 body。

4、监控文件实时采集到控制台输出

一般我们的项目都是把日志通过 logback 输出到文件,然后需要把这些文件迁移到另外个地方进行分析处理,现在我们使用 Flume 进行日志移动。

先分析下 Source,Channel 和 Sink 和上一个类似
Source 我们需要使用一个Exec Source,他可以执行一个命令,比如 tail ....


#下面是在这个 agent 上命名组件
# a1 是 agent的名称
# r1是数据源的名称,a1可能有多个数据源,这里是复数
# k1是sink 的名称
# c1是 channel 的名称
a1.sources = r1
a1.sinks = k1
a1.channels = c1

#配置 source
# a1的数据源,其中叫 r1的进行配置
# https://flume.apache.org/FlumeUserGuide.html#exec-source
a1.sources.r1.type = exec
a1.sources.r1.command = tail -F /tmp/log/log.log


# a1的 sinks 中叫 k1的进行配置
# https://flume.apache.org/FlumeUserGuide.html#logger-sink
a1.sinks.k1.type = logger

# 使用一个带有 buffer 的内存式的 channel
# https://flume.apache.org/FlumeUserGuide.html#memory-channel
a1.channels.c1.type = memory
#a1.channels.c1.capacity = 1000
#a1.channels.c1.transactionCapacity = 100

# Bind the source and sink to the channel
# 配置源到 channel 注意复数,一个 source 可以输出到多个 channel
# 配置 sink 和 channel,一个 channel 可以输出到的 sink 只有1个
a1.sources.r1.channels = c1
a1.sinks.k1.channel = c1

配置完成之后,我们开始测试
先启动整个配置文件example01.conf

$ bin/flume-ng agent \ 表示运行代理
--conf $FLUME_HOME/conf \ 表示配置文件的目录
--conf-file $FLUME_HOME/conf/example01.conf \ 指定配置文件
--name a1 \ 指定运行的代理名称
-Dflume.root.logger=DEBUG,console
-Dorg.apache.flume.log.printconfig=true
-Dorg.apache.flume.log.rawdata=true

启动之后,我们现在追加日志到/tmp/log/log.log 文件,就可以看到控制台输出日志。

5、将一个服务器的内容迁移到另外一个服务器

需要2台机器进行模拟


机器间日志迁移模型

技术选型

根据这个示意图,我们开始编写配置文件

############  exec-mem-avro.conf  ############
# Base
exec-mem-avro.sources = exec-source
exec-mem-avro.sinks = avro-sink
exec-mem-avro.channels = mem-channel
# Source
exec-mem-avro.sources.exec-source.type = exec
exec-mem-avro.sources.exec-source.command = tail -F /tmp/log/log.log
# Sink  这里修改为 avro Sink
exec-mem-avro.sinks.avro-sink.type = avro
exec-mem-avro.sinks.avro-sink.hostname = localhost 
exec-mem-avro.sinks.avro-sink.port = 44444
# Channel
exec-mem-avro.channels.mem-channel.type = memory
# Link
exec-mem-avro.sources.exec-source.channels = mem-channel
exec-mem-avro.sinks.avro-sink.channel = mem-channel

############  avro-mem-log.conf  ############
# Base
avro-mem-log.sources = avro-source
avro-mem-log.sinks = log-sink
avro-mem-log.channels = mem-channel
# Source
avro-mem-log.sources.avro-source.type = avro
avro-mem-log.sources.avro-source.bind = localhost 
avro-mem-log.sources.avro-source.port = 44444
# Sink  
avro-mem-log.sinks.log-sink.type = logger
# Channel
avro-mem-log.channels.mem-channel.type = memory
# Link
avro-mem-log.sources.avro-source.channels = mem-channel
avro-mem-log.sinks.log-sink.channel = mem-channel


需要先在第二机器上启动 avro-mem-log.conf
然后在第一个机器上启动 exec-mem-avro.conf

#第二个机器运行
$ bin/flume-ng agent \
--conf $FLUME_HOME/conf \
--conf-file $FLUME_HOME/conf/avro-mem-log.conf \
--name avro-mem-log \
-Dflume.root.logger=DEBUG,console 
-Dorg.apache.flume.log.printconfig=true 
-Dorg.apache.flume.log.rawdata=true

#第一个机器运行
$ bin/flume-ng agent \
--conf $FLUME_HOME/conf \
--conf-file $FLUME_HOME/conf/exec-mem-avro.conf \
--name exec-mem-avro \
-Dflume.root.logger=DEBUG,console 
-Dorg.apache.flume.log.printconfig=true 
-Dorg.apache.flume.log.rawdata=true

在第一个机器输入日志到/tmp/log/log.log 在第二个机器就会收集到,到此,我们的 Flume 的基本入门告一段落

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 196,099评论 5 462
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 82,473评论 2 373
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 143,229评论 0 325
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,570评论 1 267
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,427评论 5 358
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,335评论 1 273
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,737评论 3 386
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,392评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,693评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,730评论 2 312
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,512评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,349评论 3 314
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,750评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,017评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,290评论 1 251
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,706评论 2 342
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,904评论 2 335

推荐阅读更多精彩内容