zoukankan      html  css  js  c++  java
  • 搭建Flume

    下载地址:http://www.apache.org/dyn/closer.lua/flume/1.6.0/apache-flume-1.6.0-bin.tar.gz

    1.解压

      tar -zxvf apache-flume-1.6.0-bin.tar.gz -C /opt/bigdata/

    2.改名

      mv apache-flume-1.6.0-bin flume-1.6.0

    3.cd  flume-1.6.0

    4.删除文档

      rm -rf docs/

    5.cd conf

    6.改名

      mv flume-env.sh.template flume.env.sh

    7.编辑 vi flume.env.sh

    配置java环境
    export JAVA_HOME=/usr/java/xxx
    
    可以通过 :! ls /usr/java 查看具体路径

    8.配置flume环境 、etc/profile

    9.source /etc/profile

    10. fl + table键测试安装是否成功

     11.查看版本信息

     12.启动Flume

    1. 创建文件 option
    2. 配置option文件
      # example.conf: A single-node Flume configuration
      
      # Name the components on this agent
      a1.sources = r1
      a1.sinks = k1
      a1.channels = c1
      
      # Describe/configure the source
      a1.sources.r1.type = netcat
      a1.sources.r1.bind = node03
      a1.sources.r1.port = 44444
      
      # Describe the sink
      a1.sinks.k1.type = logger
      
      # Use a channel which buffers events in memory
      a1.channels.c1.type = memory
      a1.channels.c1.capacity = 1000
      a1.channels.c1.transactionCapacity = 100
      
      # Bind the source and sink to the channel
      a1.sources.r1.channels = c1
      a1.sinks.k1.channel = c1


      #a1agent的名称 因为flumn就是个agent

      #Sources 数据源

      #Sinks 发送

      #channels管道

      #R1.type netcat 网咯传输方式

      #Ke02 那台机器

      #端口号

      #logger sink输出方式到控制台

      #管道的存储方式内存、缓存区内容纳多少条记录、每次传输拿多少条记录

      #将sinksourceschannels之间连接起来

    3. 启动命令
      flume-ng agent --conf-file option --name a1 -Dflume.root.logger=INFO,console
      option 上面的文件
       --name a1 文件名 a1也是内容里面的开头信息,不能乱写

    13.测试

    1. linux测试 
      1. 下载telnet工具 yum install telnet -y
      2. telnet node03 44444
      3. 发送消息,flume界面会接受到
    2. windows测试
      1. 打开telnet,在软件卸载哪里
      2. telnet node03 44444
    3. 关闭telnet
        1.ctrl + ]
        2.quit

    两台Flume配置,telnet访问方式

    #ke02、ke03配置flume对应的环境信息
    #ke02:
    # Name the components on this agent
    a1.sources = r1
    a1.sinks = k1
    a1.channels = c1
    
    # Describe/configure the source
    a1.sources.r1.type = netcat
    a1.sources.r1.bind = ke02
    a1.sources.r1.port = 44444
    
    # Describe the sink
    a1.sinks.k1.type = avro
    a1.sinks.k1.hostname = ke03
    a1.sinks.k1.port = 10086
    
    # Use a channel which buffers events in memory
    a1.channels.c1.type = memory
    a1.channels.c1.capacity = 1000
    a1.channels.c1.transactionCapacity = 100
    
    # Bind the source and sink to the channel
    a1.sources.r1.channels = c1
    a1.sinks.k1.channel = c1
    # flume-ng agent --conf-file option2 --name a1 -Dflume.root.logger=INFO,console
    
    #ke03
    # Name the components on this agent
    a1.sources = r1
    a1.sinks = k1
    a1.channels = c1
    
    # Describe/configure the source
    a1.sources.r1.type = avro
    a1.sources.r1.bind = ke03
    a1.sources.r1.port = 10086
    
    # Describe the sink
    a1.sinks.k1.type = logger
    
    # Use a channel which buffers events in memory
    a1.channels.c1.type = memory
    a1.channels.c1.capacity = 1000
    a1.channels.c1.transactionCapacity = 100
    
    # Bind the source and sink to the channel
    a1.sources.r1.channels = c1
    a1.sinks.k1.channel = c1
    # flume-ng agent --conf-file option3 --name a1 -Dflume.root.logger=INFO,console

    备注: 先启动ke03、在启动ke02

    flume指定加载文件

    # Name the components on this agent
    a1.sources = r1
    a1.sinks = k1
    a1.channels = c1
    
    # Describe/configure the source
    a1.sources.r1.type = exec
    a1.sources.r1.command = tail -F /root/log
    
    # Describe the sink
    a1.sinks.k1.type = logger
    
    # Use a channel which buffers events in memory
    a1.channels.c1.type = memory
    a1.channels.c1.capacity = 1000
    a1.channels.c1.transactionCapacity = 100
    
    # Bind the source and sink to the channel
    a1.sources.r1.channels = c1
    a1.sinks.k1.channel = c1

    备注:

    • 每次重启都会重新加载/root/log文件,至于想每次加载多少行根据tail命令决定
    • 如下,给/root/log文件追加内容,实时被flume读取

     

    flume指定加载文件夹下所有文件

    # Name the components on this agent
    a1.sources = r1
    a1.sinks = k1
    a1.channels = c1
    
    # Describe/configure the source
    a1.sources.r1.type = spooldir
    a1.sources.r1.spoolDir = /root/data/
    a1.sources.r1.fileHeader = true
    #a1.sources.r1.fileSuffix=.msb
    
    # Describe the sink
    a1.sinks.k1.type = logger
    
    # Use a channel which buffers events in memory
    a1.channels.c1.type = memory
    a1.channels.c1.capacity = 1000
    a1.channels.c1.transactionCapacity = 100
    
    # Bind the source and sink to the channel
    a1.sources.r1.channels = c1
    a1.sinks.k1.channel = c1

    备注:

    • 目标文件夹/root/data/需要先创建
    • .COMPLETED是已经读取过该文件,则下次重启不加载该文件
    • 如果想加载已经读取过得文件,则增加配置a1.sources.r1.fileSuffix=.msb(配置任意后缀)
    • 如下将log文件移入/root/data文件夹中,数据被加载

     

    fulme加载telnet内容到HDFS中

    # Name the components on this agent
    a1.sources = r1
    a1.sinks = k1
    a1.channels = c1
    
    # Describe/configure the source
    a1.sources.r1.type = netcat
    a1.sources.r1.bind = ke02
    a1.sources.r1.port = 44444
    
    # Describe the sink
    a1.sinks.k1.type = hdfs
    a1.sinks.k1.hdfs.path = /flume/events/%y-%m-%d/%H%M/%S
    a1.sinks.k1.hdfs.filePrefix = events-
    a1.sinks.k1.hdfs.round = true
    a1.sinks.k1.hdfs.roundValue = 10
    a1.sinks.k1.hdfs.roundUnit = second
    a1.sinks.k1.hdfs.useLocalTimeStamp = true
    
    # Use a channel which buffers events in memory
    a1.channels.c1.type = memory
    a1.channels.c1.capacity = 1000
    a1.channels.c1.transactionCapacity = 100
    
    # Bind the source and sink to the channel
    a1.sources.r1.channels = c1
    a1.sinks.k1.channel = c1

    备注:以上代表意义查看官网

    1. 访问https://flume.apache.org/
    2. Documentation
    3. Flume User Guide 
    4. 找对应文档内容及解释说明
  • 相关阅读:
    codevs 3305 水果姐逛水果街Ⅱ&&codevs3006
    开发webrtc通过Js调用Go接口发送数据报错500(Internal Sever Error)排查分析
    TSINGSEE青犀视频开发单通道 Go WebRTC服务端拉流接口无响应导致程序堵塞,如何处理?
    H265网页视频播放器项目EasyPlayer.JS版本不支持PCM/711音频格式如何转换?
    网络穿透/视频拉转推服务系统EasyNTS通过gomod管理工具编译提示缺少依赖库解决方法
    WebRTC播放器通过js Video标签拉流播放有时无法刷新视频画面的原因排查
    开源框架WebRTC终极指南:3大 API 详解
    开源框架WebRTC 10年发展,现已成为官方Web标准
    IE8 下 iframe 滚动条的问题
    父窗口jquery触发iframe按钮事件(转载)
  • 原文地址:https://www.cnblogs.com/bigdata-familyMeals/p/14053902.html
Copyright © 2011-2022 走看看