国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

使用 Docker 與 Apache Flume - 第一部分

BlackFlagBin / 1778人閱讀

摘要:注該文的作文是原文地址為在,我們使用處理我們架構(gòu)的一部分,因為它很容易設(shè)置和減少自定義和,在我的創(chuàng)新時間,我嘗試設(shè)置一些拓撲來學習和集裝箱化。酷現(xiàn)在我們有一個工作的可以提取和處理數(shù)據(jù)了。第二部分的地址

  

注:該文的作文是 mrwilson ,原文地址為 Using Docker with Apache Flume - Part 1

在 Unruly,我們使用 Apache Flume 處理我們 event-streaming 架構(gòu)的一部分,因為它很容易設(shè)置和減少自定義 sources 和 sinks,在我的創(chuàng)新時間,我嘗試設(shè)置一些 Flume 拓撲來學習 Docker 和 集裝箱化。

設(shè)置基礎(chǔ)鏡像

Docker 有鏡像的概念,從鏡像中我們可以啟動一個容器,因此,第一步就是創(chuàng)建一個 Flume pre-installed 的鏡像。Flume 僅僅依賴 JAVA(它是一個 JAVA 工程),我從 Ubuntu 基礎(chǔ)鏡像中創(chuàng)建它,將執(zhí)行以下步驟:

安裝 java 和 wget

下載和解壓 flume 工程到 /opt/flume

設(shè)置 JAVA_HOME 并且把 flume-ng 加入 PATH

下面是我們需要做的

FROM ubuntu

# install wget + java
RUN apt-get update -q
RUN DEBIAN_FRONTEND=noninteractive apt-get install 
  -qy --no-install-recommends 
  wget openjdk-7-jre

# download and unzip Flume
RUN mkdir /opt/flume
RUN wget -qO- 
  https://archive.apache.org/dist/flume/stable/apache-flume-1.4.0-bin.tar.gz 
  | tar zxvf - -C /opt/flume --strip 1

# set environment variables
ENV JAVA_HOME /usr/lib/jvm/java-7-openjdk-amd64
ENV PATH /opt/flume/bin:$PATH

從這個 Dockerfile 中構(gòu)建一個鏡像(使用 docker build -t flume .),可行的版本在 Docker index 中。

一個基礎(chǔ)的 Flume 拓撲

一個 Flume 拓撲由 agents 組成,它由三個核心概念:sources, channels, 和 sinks。

我們從 sources 接收數(shù)據(jù),把它傳遞進一個或多個 channels,然后被 sinks 讀取和處理。大部分基礎(chǔ)的拓撲包含一個多帶帶的節(jié)點,下面我構(gòu)建一個叫做 Docker 的 agent,有以下結(jié)構(gòu):

一個 NetcatSource,從一個端口讀取數(shù)據(jù),并且傳遞進 events。

一個 MemoryChannel,在內(nèi)存中 buffering events 。

一個 LoggerSink,僅僅記錄它接收到的 events。

這個拓撲的配置文件如下,我們會以 flume-example.conf 作為參考,看起來像這樣:

docker.sinks = logSink
docker.sources = netcatSource
docker.channels = inMemoryChannel

docker.sources.netcatSource.type = netcat
docker.sources.netcatSource.bind = 0.0.0.0
docker.sources.netcatSource.port = 44444
docker.sources.netcatSource.channels = inMemoryChannel

docker.channels.inMemoryChannel.type = memory
docker.channels.inMemoryChannel.capacity = 1000
docker.channels.inMemoryChannel.transactionCapacity = 100

docker.sinks.logSink.type = logger
docker.sinks.logSink.channel = inMemoryChannel

從這里,我們可以通過這個配置文件創(chuàng)建一個新的容器,并且啟動這個 docker agent。

FROM probablyfine/flume

ADD flume-example.conf /var/tmp/flume-example.conf

EXPOSE 44444

ENTRYPOINT [ "flume-ng", "agent",
  "-c", "/opt/flume/conf", "-f", "/var/tmp/flume-example.conf", "-n", "docker",
  "-Dflume.root.logger=INFO,console" ]

在 ENTRYPOINT 點的 flume-ng 命令將在容器啟動的時候被運行(需要配置目錄,配置文件,和 agent 的名字),EXPOSE 指令使得端口在運行時可用,這個端口 NetcatSource 將監(jiān)聽。

  

注:關(guān)于 CMD、RUN、ENTRYPOING 的區(qū)別請看這里 http://segmentfault.com/q/1010000000417103

一旦我們構(gòu)建了這個新的鏡像(我們稱作 flume-example),我們使用 ocker run -p 444:44444 -t flume-example 命令啟動這個容器,

-p 444:44444 參數(shù)將容器中的 44444 端口映射到本地主機上的 444 端口。現(xiàn)在我們可以給它寫消息,使用 echo foo bar baz | nc localhost 444 然后看事件被記錄。

...
2014-05-05 19:26:13,218 (SinkRunner-PollingRunner-DefaultSinkProcessor)
  [INFO - org.apache.flume.sink.LoggerSink.process(LoggerSink.java:70)]
  Event: { headers:{} body: 66 6F 6F 20 62 61 72 20 62 61 7A foo bar baz }
...

酷!現(xiàn)在我們有一個工作的 Flume agent 可以提取和處理數(shù)據(jù)了。

下一篇文章將展示一些有趣的 Flume 拓撲,以及使得我們怎樣能更加容易的把 Docker 的功能(比如 共享卷以及只讀 mounting)整合進一個 Flume 中設(shè)置。

第二部分的地址 Using Docker with Apache Flume - Part 2

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/26339.html

相關(guān)文章

  • 基于 Docker 構(gòu)建 Flume -- Part1

    摘要:在,我們使用作為事件流架構(gòu)的一部分。在源斷和端,它使非常容易建立以及丟棄的。因此,第一步就是創(chuàng)建一個預安裝了的鏡像。一個基礎(chǔ)的拓撲一個拓撲由組成,它有個核心概念和。 注:該文的原文為 Using Docker with Apache Flume - Part 1,由 Alex Wilson 編寫。 在 Unruly ,我們使用 Apache Flume 作為事件流架構(gòu)的一部分...

    ShowerSun 評論0 收藏0
  • 基于 Docker 構(gòu)建 Flume -- Part1

    摘要:在,我們使用作為事件流架構(gòu)的一部分。在源斷和端,它使非常容易建立以及丟棄的。因此,第一步就是創(chuàng)建一個預安裝了的鏡像。一個基礎(chǔ)的拓撲一個拓撲由組成,它有個核心概念和。 注:該文的原文為 Using Docker with Apache Flume - Part 1,由 Alex Wilson 編寫。 在 Unruly ,我們使用 Apache Flume 作為事件流架構(gòu)的一部分...

    Youngdze 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<