zoukankan      html  css  js  c++  java
  • 整合Flume和Kafka完成数据采集

    Flume-Kafka

    1. 修改 avro-memory-kafka.conf文件:

    # Name the components on this agent
    avro-memory-kafka.sources = avro-source
    avro-memory-kafka.sinks = kafka-sink
    avro-memory-kafka.channels = memory-channel
    
    # Describe/configure the source
    avro-memory-kafka.sources.avro-source.type = avro
    avro-memory-kafka.sources.avro-source.bind = 192.168.1.143
    avro-memory-kafka.sources.avro-source.port = 44444
    
    # Describe the sink
    avro-memory-kafka.sinks.kafka-sink.type = org.apache.flume.sink.kafka.KafkaSink
    avro-memory-kafka.sinks.kafka-sink.brokerList = 192.168.1.143:9092
    avro-memory-kafka.sinks.kafka-sink.topic = hello_topic
    avro-memory-kafka.sinks.kafka-sink.batchSize = 5
    avro-memory-kafka.sinks.kafka-sink.requiredAcks = 1
    
    # Use a channel which buffers events in memory
    avro-memory-kafka.channels.memory-channel.type = memory
    
    # Bind the source and sink to the channel
    avro-memory-kafka.sources.avro-source.channels = memory-channel
    avro-memory-kafka.sinks.kafka-sink.channel = memory-channel

    2.启动Flume:

    (1)先启动44444端口的Flume

    flume-ng agent 
    --name avro-memory-kafka 
    --conf $FLUME_HOME/conf 
    --conf-file $FLUME_HOME/conf/avro-memory-kafka.conf 
    -Dflume.root.logger=INFO,console

    (2)再启动exec-memory-avro.conf的Flume

    flume-ng agent 
    --name exec-memory-avro 
    --conf $FLUME_HOME/conf 
    --conf-file $FLUME_HOME/conf/exec-memory-avro.conf 
    -Dflume.root.logger=INFO,console

     *(3)如果报错,可能是没有启动zookeeper, 

    zookeeper-server-start.sh zookeeper.properties

      (4) 开启Kafka消费者:

    kafka-console-consumer.sh --zookeeper 192.168.1.143:2181 --topic hello_topic

      (5)在data.log中输入一些数据。(生产数据)

    echo helloaaa >> data.log
    echo helloaaa >> data.log
    echo helloaaa >> data.log
    echo helloaaa >> data.log
    echo helloaaa >> data.log
    echo helloaaa >> data.log
    echo helloaaa >> data.log
    echo helloaaa >> data.log
    echo helloaaa >> data.log

      (6)如下图,消费者消费了这些

     以上就是简单实现了Flume-Kakfa的数据产生到消费。

  • 相关阅读:
    前端开发规范:命名规范、html 规范、css 规范、js 规范
    node.js入门系列(一)--Node.js简介
    浅析前端开发中的 MVC/MVP/MVVM 模式
    网页加载进度条的实现
    JavaScript深入系列(一)--原型和原型链详解
    vue2.0项目实战(5)vuex快速入门
    既然写CSS很容易,那为什么大家还是把CSS写的那么烂呢?
    vue2.0项目实战(4)生命周期和钩子函数详解
    vue2.0项目实战(3)使用axios发送请求
    【css技能提升】完美的 Sticky Footer 布局
  • 原文地址:https://www.cnblogs.com/BigStupid/p/9765037.html
Copyright © 2011-2022 走看看