使用Docker快速搭建Kafka開發(fā)環(huán)境

Docker在很多時候都可以幫助我們快速搭建想要的開發(fā)環(huán)境姜盈,免去了很多安裝配置上的麻煩。在涉及到Apache Kafka的快速demo時,使用Docker Hub上提供的鏡像也是一個很好的選擇锅很。

Kafka & ZooKeeper Docker鏡像

spotify/kafka

在demo時窿冯,很多情況下我們并不追求Kafka與ZooKeeper的區(qū)隔赵抢,來自spotify的kafka鏡像同時包含了kafka與zookeeper剧蹂,因此基本上可以“隨裝隨用”。
但已經(jīng)較長時間沒有維護烦却,Kafka版本仍然停留在0.10宠叼。對需要使用1.0版本的同仁已經(jīng)不適合了。

landoop/fast-data-dev

提供了一整套包括Kafka其爵,ZooKeeper冒冬,Schema Registry,,Kafka-Connect等在內(nèi)的多種開發(fā)工具和Web UI監(jiān)視系統(tǒng)摩渺〖蚩荆基本上是我見過的最強大的開發(fā)環(huán)境。尤其是對于Kafka Connect的支持摇幻,包含了MongoDB横侦,ElasticSearch,Twitter等超過20種Connector绰姻,并且提供了通過REST API提交Connector配置的Web UI枉侧。
基本是我測試Kafka Connect的首選。

wurstmeister/kafka

維護較為頻繁的一個Kafka鏡像狂芋。只包含了Kafka榨馁,因此需要另行提供ZooKeeper,推薦使用同一作者提交的wurstmeister/zookeeper帜矾。
現(xiàn)在已經(jīng)提供較新的1.1.0版本翼虫。

搭建開發(fā)環(huán)境

1 ZooKeeper 1 Kafka

這里以我自己最常用的wurstmeister/kafka為例,使用docker-compose運行一個只有一個ZooKeeper node和一個Kafka broker的開發(fā)環(huán)境:

version: '2'

services:
  zoo1:
    image: wurstmeister/zookeeper
    restart: unless-stopped
    hostname: zoo1
    ports:
      - "2181:2181"
    container_name: zookeeper

  # kafka version: 1.1.0
  # scala version: 2.12
  kafka1:
    image: wurstmeister/kafka
    ports:
      - "9092:9092"
    environment:
      KAFKA_ADVERTISED_HOST_NAME: localhost
      KAFKA_ZOOKEEPER_CONNECT: "zoo1:2181"
      KAFKA_BROKER_ID: 1
      KAFKA_OFFSETS_TOPIC_REPLICATION_FACTOR: 1
      KAFKA_CREATE_TOPICS: "stream-in:1:1,stream-out:1:1"
    depends_on:
      - zoo1
    container_name: kafka

這里利用了wurstmeister/kafka提供的環(huán)境參數(shù)KAFKA_CREATE_TOPICS使Kafka運行后自動創(chuàng)建topics屡萤。

1 ZooKeeper 2 Kafka

ZooKeeper的部分與上個例子一樣珍剑,需要調(diào)整的是Kafka部分。

這里將第一個Kafka broker命名為kafka1灭衷,KAFKA_ADVERTISED_HOST_NAME參數(shù)設為kafka1次慢,KAFKA_ADVERTISED_PORT設為9092旁涤。

對于第二個broker翔曲,相較第一個broker所有kakfka1的部分改為kafka2,包括service name和coontainer name劈愚。同時KAFKA_BROKER_ID設為2瞳遍,KAFKA_ADVERTISED_PORT設為9093。

需要注意的是菌羽,當有不止一個kafka broker時掠械,這里的hostname不能再設為localhost。建議設為本機IP地址。以Mac為例猾蒂,使用ipconfig getifaddr en0指令來獲取均唉。

具體的docker-compose.yml文件內(nèi)容如下:

  # ZooKeeper部分不變

  kafka1:
    image: wurstmeister/kafka
    ports:
      - "9092:9092"
    environment:
      KAFKA_ADVERTISED_HOST_NAME: 192.168.1.2
      KAFKA_ADVERTISED_PORT: 9092
      KAFKA_ZOOKEEPER_CONNECT: "zoo1:2181"
      KAFKA_BROKER_ID: 1
      KAFKA_OFFSETS_TOPIC_REPLICATION_FACTOR: 1
      KAFKA_CREATE_TOPICS: "stream-in:2:1,stream-out:2:1"
    depends_on:
      - zoo1
    container_name: kafka1


  kafka2:
    image: wurstmeister/kafka
    ports:
      - "9093:9092"
    environment:
      KAFKA_ADVERTISED_HOST_NAME: {ipconfig getifaddr en0指令的結果}
      KAFKA_ADVERTISED_PORT: 9093
      KAFKA_ZOOKEEPER_CONNECT: "zoo1:2181"
      KAFKA_BROKER_ID: 2
      KAFKA_OFFSETS_TOPIC_REPLICATION_FACTOR: 1
    depends_on:
      - zoo1
    container_name: kafka2

與容器內(nèi)的開發(fā)環(huán)境交互

可以使用docker exec命令直接調(diào)用kafka容器內(nèi)的腳本來進行創(chuàng)建/刪除topic,啟動console producer等等操作肚菠。

如果本地存有與容器內(nèi)相同的Kafka版本文件舔箭,也可以直接使用本地腳本文件。如上述docker-compose.yml文件所示蚊逢,kafka1的hostname即是kafka1层扶,端口為9092,通過kafka1:9092就可以連接到容器內(nèi)的Kafka服務烙荷。

列出所有topics (在本地kafka路徑下)
$ bin/kafka-topics.sh --zookeeper localhost:2181 --list

列出所有Kafka brokers
$ docker exec zookeeper bin/zkCli.sh ls /brokers/ids

最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末镜会,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子终抽,更是在濱河造成了極大的恐慌戳表,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,651評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件拿诸,死亡現(xiàn)場離奇詭異扒袖,居然都是意外死亡,警方通過查閱死者的電腦和手機亩码,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,468評論 3 392
  • 文/潘曉璐 我一進店門季率,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人描沟,你說我怎么就攤上這事飒泻。” “怎么了吏廉?”我有些...
    開封第一講書人閱讀 162,931評論 0 353
  • 文/不壞的土叔 我叫張陵泞遗,是天一觀的道長。 經(jīng)常有香客問我席覆,道長史辙,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,218評論 1 292
  • 正文 為了忘掉前任佩伤,我火速辦了婚禮聊倔,結果婚禮上,老公的妹妹穿的比我還像新娘生巡。我一直安慰自己耙蔑,他們只是感情好,可當我...
    茶點故事閱讀 67,234評論 6 388
  • 文/花漫 我一把揭開白布孤荣。 她就那樣靜靜地躺著甸陌,像睡著了一般须揣。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上钱豁,一...
    開封第一講書人閱讀 51,198評論 1 299
  • 那天耻卡,我揣著相機與錄音,去河邊找鬼牲尺。 笑死劲赠,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的秸谢。 我是一名探鬼主播凛澎,決...
    沈念sama閱讀 40,084評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼估蹄!你這毒婦竟也來了塑煎?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,926評論 0 274
  • 序言:老撾萬榮一對情侶失蹤臭蚁,失蹤者是張志新(化名)和其女友劉穎最铁,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體垮兑,經(jīng)...
    沈念sama閱讀 45,341評論 1 311
  • 正文 獨居荒郊野嶺守林人離奇死亡冷尉,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,563評論 2 333
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了系枪。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片雀哨。...
    茶點故事閱讀 39,731評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖私爷,靈堂內(nèi)的尸體忽然破棺而出雾棺,到底是詐尸還是另有隱情,我是刑警寧澤衬浑,帶...
    沈念sama閱讀 35,430評論 5 343
  • 正文 年R本政府宣布捌浩,位于F島的核電站,受9級特大地震影響工秩,放射性物質(zhì)發(fā)生泄漏尸饺。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,036評論 3 326
  • 文/蒙蒙 一助币、第九天 我趴在偏房一處隱蔽的房頂上張望浪听。 院中可真熱鬧,春花似錦奠支、人聲如沸馋辈。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,676評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽迈螟。三九已至,卻和暖如春尔崔,著一層夾襖步出監(jiān)牢的瞬間答毫,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,829評論 1 269
  • 我被黑心中介騙來泰國打工季春, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 47,743評論 2 368
  • 正文 我出身青樓郁岩,卻偏偏與公主長得像姐军,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子宇攻,可洞房花燭夜當晚...
    茶點故事閱讀 44,629評論 2 354

推薦閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構建分布式系統(tǒng)中一些常見模式的工具(例如配置管理惫叛,服務發(fā)現(xiàn),斷路器逞刷,智...
    卡卡羅2017閱讀 134,652評論 18 139
  • 在hyperledger fabric的orderer中嘉涌,目前發(fā)布的版本是使用kafka來做排序,并沒有用到所謂的...
    y9g閱讀 6,614評論 0 3
  • Kafka已經(jīng)發(fā)布了1.0版夸浅,為了緊跟時代的步伐仑最,最近學習了《Kafka權威指南》。書如其名帆喇,這本 Definit...
    阿貍不歌閱讀 23,042評論 11 32
  • Docker — 云時代的程序分發(fā)方式 要說最近一年云計算業(yè)界有什么大事件警医?Google Compute Engi...
    ahohoho閱讀 15,530評論 15 147
  • 《傷仲永》王安石金溪民方仲永法严,世隸耕。仲永生五年葫笼,未嘗識書具深啤,忽啼求之。父異焉路星,借旁近與之溯街,即書詩四句,并自為其名...
    快樂爸爸日記閱讀 588評論 0 2