摘要:準(zhǔn)備環(huán)境系統(tǒng)下載并解壓啟動(dòng)啟動(dòng)啟動(dòng)創(chuàng)建我修改了默認(rèn)的端口查看創(chuàng)建的查看的詳細(xì)信息測試運(yùn)行并在控制臺(tái)中輸一些消息測試注意需要開兩個(gè)終端搭建開發(fā)環(huán)境生產(chǎn)者
準(zhǔn)備環(huán)境
系統(tǒng)
CentOS release 6.6 (Final)
下載并解壓
wget http://mirror.bit.edu.cn/apache/kafka/0.8.0/kafka_2.10-0.8.0.tgz tar -zxvf kafka_2.10-0.8.0.tgz`啟動(dòng)
啟動(dòng)Zookeeper
bin/zookeeper-server-start.sh config/zookeeper.properties &
啟動(dòng)kafka
bin/kafka-server-start.sh config/server.properties &
創(chuàng)建topic
我修改了默認(rèn)的端口
bin/kafka-topics.sh --create --zookeeper localhost:2182 --replication-factor 1 --partitions 1 --topic testweixuan &
查看創(chuàng)建的topic
bin/kafka-topics.sh --list --zookeeper localhost:2182
查看topic的詳細(xì)信息
bin/kafka-topics.sh --describe --zookeeper localhost:2182
測試producer
運(yùn)行producer并在控制臺(tái)中輸一些消息:
bin/kafka-console-producer.sh --broker-list 192.168.1.116:2182:9092 --topic testweixuan
測試consumer
bin/kafka-console-consumer.sh --zookeeper 192.168.1.116:2182 --topic testweixuan --from-beginning
注意:需要開兩個(gè)終端
搭建開發(fā)環(huán)境 生產(chǎn)者代碼package com.fengtang; import java.util.Properties; import kafka.javaapi.producer.Producer; import kafka.producer.KeyedMessage; import kafka.producer.ProducerConfig; /** * Create by fengtang * 2015/10/8 0008 * KafkaDemo_01 */ public class KafkaProducer { private final Producer消費(fèi)者代碼producer; public final static String TOPIC = "TEST-TOPIC"; private KafkaProducer() { Properties props = new Properties(); /** * 此處配置的是kafka的端口 */ props.put("metadata.broker.list", "192.168.1.116:9092"); /** * 配置value的序列化類 */ props.put("serializer.class", "kafka.serializer.StringEncoder"); /** * 配置key的序列化類 */ props.put("key.serializer.class", "kafka.serializer.StringEncoder"); props.put("request.required.acks", "-1"); producer = new Producer<>(new ProducerConfig(props)); } void produce() { int messageNo = 1000; final int COUNT = 10000; while (messageNo < COUNT) { String key = String.valueOf(messageNo); String data = "hello kafka message " + key; producer.send(new KeyedMessage<>(TOPIC, key, data)); System.out.println(data); messageNo++; } } public static void main(String[] args) { new KafkaProducer().produce(); } }
package com.fengtang; import kafka.consumer.ConsumerConfig; import kafka.consumer.ConsumerIterator; import kafka.consumer.KafkaStream; import kafka.javaapi.consumer.ConsumerConnector; import kafka.serializer.StringDecoder; import kafka.utils.VerifiableProperties; import java.util.HashMap; import java.util.List; import java.util.Map; import java.util.Properties; /** * Create by fengtang * 2015/10/8 0008 * KafkaDemo_01 */ public class KafkaConsumer { private final ConsumerConnector consumer; private KafkaConsumer() { Properties props = new Properties(); /** * zookeeper 配置 */ props.put("zookeeper.connect", "192.168.1.116:2182"); /** * group 代表一個(gè)消費(fèi)組 */ props.put("group.id", "jd-group"); /** * zk連接超時(shí) */ props.put("zookeeper.session.timeout.ms", "400000"); props.put("zookeeper.sync.time.ms", "200"); props.put("auto.commit.interval.ms", "1000"); props.put("auto.offset.reset", "smallest"); /** * 序列化類 */ props.put("serializer.class", "kafka.serializer.StringEncoder"); ConsumerConfig config = new ConsumerConfig(props); consumer = kafka.consumer.Consumer.createJavaConsumerConnector(config); } void consume() { MaptopicCountMap = new HashMap (); topicCountMap.put(KafkaProducer.TOPIC, new Integer(1)); StringDecoder keyDecoder = new StringDecoder(new VerifiableProperties()); StringDecoder valueDecoder = new StringDecoder(new VerifiableProperties()); Map >> consumerMap = consumer.createMessageStreams(topicCountMap, keyDecoder, valueDecoder); KafkaStream stream = consumerMap.get(KafkaProducer.TOPIC).get(0); ConsumerIterator it = stream.iterator(); while (it.hasNext()) System.out.println(it.next().message()); } public static void main(String[] args) { new KafkaConsumer().consume(); } }
pom.xml
解決報(bào)錯(cuò)4.0.0 com.fengtang kafkademo 1.0-SNAPSHOT jar kafkademo http://maven.apache.org UTF-8 org.apache.kafka kafka_2.10 0.8.0 log4j log4j 1.2.15 jmxtools com.sun.jdmk jmxri com.sun.jmx jms javax.jms javax.mail
kafka.common.FailedToSendMessageException: Failed to send messages after 3 tries.
需要改動(dòng)config文件夾下的server.properties中的以下兩個(gè)屬性
zookeeper.connect=localhost:2181改成zookeeper.connect=192.168.1.116 (自己的服務(wù)器IP地址):2181
以及默認(rèn)注釋掉的 #host.name=localhost 改成 host.name=192.168.1.116 (自己的服務(wù)器IP地址)
成功截圖文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/64659.html
摘要:項(xiàng)目地址前言大數(shù)據(jù)技術(shù)棧思維導(dǎo)圖大數(shù)據(jù)常用軟件安裝指南一分布式文件存儲(chǔ)系統(tǒng)分布式計(jì)算框架集群資源管理器單機(jī)偽集群環(huán)境搭建集群環(huán)境搭建常用命令的使用基于搭建高可用集群二簡介及核心概念環(huán)境下的安裝部署和命令行的基本使用常用操作分區(qū)表和分桶表視圖 項(xiàng)目GitHub地址:https://github.com/heibaiying... 前 言 大數(shù)據(jù)技術(shù)棧思維導(dǎo)圖 大數(shù)據(jù)常用軟件安裝指...
閱讀 4038·2021-11-22 13:53
閱讀 3632·2021-11-19 11:29
閱讀 1288·2021-09-08 09:35
閱讀 3181·2020-12-03 17:26
閱讀 522·2019-08-29 16:06
閱讀 2119·2019-08-26 13:50
閱讀 1192·2019-08-23 18:32
閱讀 2164·2019-08-23 18:12