成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

基于 Docker 構建 Flume -- Part1

Youngdze / 1359人閱讀

摘要:在,我們使用作為事件流架構的一部分。在源斷和端,它使非常容易建立以及丟棄的。因此,第一步就是創(chuàng)建一個預安裝了的鏡像。一個基礎的拓撲一個拓撲由組成,它有個核心概念和。

  

注:該文的原文為 Using Docker with Apache Flume - Part 1,由 Alex Wilson 編寫。

在 Unruly ,我們使用 Apache Flume 作為事件流架構的一部分。在源斷和 sinks 端,它使非常容易建立以及丟棄的。在我的創(chuàng)新時間,我嘗試創(chuàng)立一些 Flume 技術來獲得 Docker 和集裝箱運輸?shù)闹R。

建立一個基礎鏡像

Docker 有鏡像的概念,在這個鏡像中我們能運行一個容器。因此,第一步就是創(chuàng)建一個預安裝了 Flume 的鏡像。Flume 僅僅依賴 java(它是一個java工程),我在一個 Ubuntu 基礎鏡像的基礎上創(chuàng)建了它,創(chuàng)建它需要執(zhí)行以下步驟:

安裝 java 和 wget

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

設置 JAVA_HOME 和把 flume-ng 添加進 PATH

如下所做,創(chuàng)建一個 dockerfile :

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 構建一個鏡像(使用 docker build -t flume .),將給我們一個基礎鏡像,以使 Flume 容器使用。它是可用的,你可以在 Docker index 找到它。

一個基礎的 Flume 拓撲

一個 Flume 拓撲由 agent 組成,它有3個核心概念:sources、channels 和 sinks。

我們從 sources 接收數(shù)據(jù),把它放入一個或是多個的 channels ,它能被 sinks 讀取和加工。大部分的基礎拓撲由一個節(jié)點組成,我們建立了以下一個由 Docker 創(chuàng)建的節(jié)點,使用:

一個 NetcatSource,從一個端口讀取數(shù)據(jù)并且變成事件

一個 MemoryChannel,存放在內存中的事件 buffering 。

一個 LoggerSink,記錄它接收到的事件

這個拓撲的配置文件,我們稱之為 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)聽這個端口。

一旦我們創(chuàng)建了這個新鏡像(我們叫做 flume-example),我們就可以通過使用命令 docker run -p 444:44444 -t flume-example 啟動這個容器,p 444:44444 指令將讓容器中的 4444 端口和本機的 444 端口做映射?,F(xiàn)在我們可以通過 echo foo bar baz | nc localhost 444 給它發(fā)送消息了,然后看被記錄的事件。

...
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 的特性和 Flume 的建立整合起來(比如共享一個卷和只讀的掛載)。

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

轉載請注明本文地址:http://systransis.cn/yun/28104.html

相關文章

  • 基于 Docker 構建 Flume -- Part1

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

    ShowerSun 評論0 收藏0
  • 使用 Docker 與 Apache Flume - 第一部分

    摘要:注該文的作文是原文地址為在,我們使用處理我們架構的一部分,因為它很容易設置和減少自定義和,在我的創(chuàng)新時間,我嘗試設置一些拓撲來學習和集裝箱化??岈F(xiàn)在我們有一個工作的可以提取和處理數(shù)據(jù)了。第二部分的地址 注:該文的作文是 mrwilson ,原文地址為 Using Docker with Apache Flume - Part 1 在 Unruly,我們使用 Apache Fl...

    BlackFlagBin 評論0 收藏0
  • 基于kubernetes的docker集群實踐

    摘要:健康監(jiān)控檢查,可以說是集群中最重要的一部分了。我們在這里沒有使用推薦的方式,我們自己將其與內部的系統(tǒng)做了結合,通過來對整個集群進行監(jiān)控報警自動化操作。 在公司內部,基于kubernetes實現(xiàn)了簡單的docker應用集群系統(tǒng),拿出來和大家分享下,在這個系統(tǒng)中,實現(xiàn)了應用的自動部署、動態(tài)擴容、節(jié)點切換、健康檢查、AB式版本更新等功能,也歡迎大家將各自的實現(xiàn)也分享給我。 整體架構 整體架構...

    meislzhua 評論0 收藏0
  • 基于kubernetes的docker集群實踐

    摘要:健康監(jiān)控檢查,可以說是集群中最重要的一部分了。我們在這里沒有使用推薦的方式,我們自己將其與內部的系統(tǒng)做了結合,通過來對整個集群進行監(jiān)控報警自動化操作。 在公司內部,基于kubernetes實現(xiàn)了簡單的docker應用集群系統(tǒng),拿出來和大家分享下,在這個系統(tǒng)中,實現(xiàn)了應用的自動部署、動態(tài)擴容、節(jié)點切換、健康檢查、AB式版本更新等功能,也歡迎大家將各自的實現(xiàn)也分享給我。 整體架構 整體架構...

    Flink_China 評論0 收藏0

發(fā)表評論

0條評論

Youngdze

|高級講師

TA的文章

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