Kafka命令行操作及常用API
一、Kafka命令行操作
1.查看当前集群已存在的主题
bin/kafka-topic.sh --zookeeper hd09-01:2181 --list
2.创建主题
bin/kafka-topic.sh --zookeeper hd09-01:2181 --create --relication-factor 3 \
>--partition 1 \
>---topic xinnian
3.删除主题
bin/kafka-topic.sh --zookeeper hd09-01:2181 --delete --topic xinnian
4.启动生产者发送消息(相当于直接创建主题)
bin/kafka-console-producer.sh --broker-list hd09-01:9092 --topic xinnian
5.启动消费者接收消息
bin/kafka-console-consumer.sh --bootstrap-server hd09-01:9092 \
>--topic xinnian
>--from-beginning
6.查看主题的详细信息
bin/kafka-topic.sh --zookeeper hd09-01:2181 --describe --topic xinnian
二、Kafka的常用API(生产者和消费者)
注意!!!在本地编译器上编写kafka的生产者消费者API时,要在本地的hosts文件中添加映射!!
1.生产者
1)配置生产者属性(kafka节点地址,是否等待应答,发送消息失败是否重试,批处理消息大小,批处理数据延迟,内存缓冲,序列化等)生产者发送数据,只需序列化
Properties prop = new Properties();
prop.put("","");
2)实例化生产者
KafkaProducer<String,String> producer = new KafkaProducer<String,String>(prop);
3)生产者发送消息(使用只含有ProducerRecord的send方法)
for(~){
producer.send(new ProducerRecord<String,String>("topic","value"));
}
4)关闭生产者资源
producer.close();
/**
* @author: PrincessHug
* @date: 2019/2/28, 16:36
* @Blog: https://www.cnblogs.com/HelloBigTable/
*/
public class Prodecer {
public static void main(String[] args) {
Properties prop = new Properties(); //参数配置
//kafka节点的地址
prop.put("bootstrap.servers", "192.168.126.128:9092");
//发送消息是否等待应答
prop.put("acks", "all");
//配置发送消息失败重试
prop.put("retries", "");
//配置批量处理消息大小
prop.put("batch.size", "");
//配置批量处理数据延迟
prop.put("linger.ms","");
//配置内存缓冲大小
prop.put("buffer.memory", "");
//消息在发送前必须序列化
prop.put("key.serializer", "org.apache.kafka.common.serialization.StringSerializer");
prop.put("value.serializer", "org.apache.kafka.common.serialization.StringSerializer"); KafkaProducer<String, String> producer = new KafkaProducer<String, String>(prop); for (int i=;i<;i++){
producer.send(new ProducerRecord<String, String>("xinnian", "" + i + "年新年好!"));
} producer.close(); }
}
2.消费者
1)配置消费者属性(服务器地址,消费者组,自动确认偏移量,反序列化)
Properties prop = new Properties();
2)实例化消费者(线程安全,把consumer定义为常量)
final KafkaConsumer<String,String> consumer = new KafkaConsumer<String,String>(prop);
3)释放资源,线程安全
public class Runtime extends Object
每个Java应用程序都有一个Runtime类的Runtime ,允许应用程序与运行应用程序的环境进行接口。
void addShutdownHook(Thread hook) =>注册一个新的虚拟机关机挂钩。
static Runtime getRuntime() =>返回与当前Java应用程序关联的运行时对象。
4)订阅消息主题,消费者拉取消息poll
while(true){
ConsumerRecords<String,String> records = consumer.poll(1000);
//遍历消息
for(ConsumerRecord<String,String> r:records){
System.out.println(r.key() + "----------" + r.value());
}
}
/**
* @author: PrincessHug
* @date: 2019/2/28, 20:07
* @Blog: https://www.cnblogs.com/HelloBigTable/
*/
public class ConsumerDemo {
public static void main(String[] args) {
//配置消费者属性
Properties prop = new Properties();
prop.put("bootstrap.servers","192.168.126.129:9092");
prop.put("group.id","g1");
prop.put("enable.auto.commit","true");
prop.put("key.deserializer","org.apache.kafka.common.serialization.StringDeserializer");
prop.put("value.deserializer","org.apache.kafka.common.serialization.StringDeserializer"); //初始化消费的对象
final KafkaConsumer<String, String> consumer = new KafkaConsumer<String, String>(prop); //线程安全,释放资源
Runtime.getRuntime().addShutdownHook(new Thread(new Runnable() {
public void run() {
if (consumer!=null){
consumer.close();
}
}
})); //消费者订阅主题
consumer.subscribe(Arrays.asList("xinnian")); //消费者拉取消息
while (true){
ConsumerRecords<String, String> records = consumer.poll(1000);
for (ConsumerRecord<String, String> record:records){
System.out.println(record.topic()+"-----"+record.value());
}
} }
}
Kafka命令行操作及常用API的更多相关文章
- 4、Kafka命令行操作
Kafka命令行操作 1)查看当前服务器中的所有topic [test@ip101 kafka]$ bin/kafka-topics.sh --zookeeper ip101:2181 --list ...
- Kafka命令行操作
Kafka命令行操作 1)查看当前服务器中的所有topic [bingo@hadoop101 kafka]$ bin/kafka-topics.sh --list --zookeeper hadoop ...
- DOS命令行操作MySQL常用命令
平时用可视化界面用惯了,如果紧急排查问题,没有安装可视化工具的话,只能通过命令来看了. 以备不时之需,我们要熟悉一下命令行操作MySQL. 打开DOS命令窗口:WIN + R 输入cmd,回车 然后输 ...
- kafka 命令行操作
1.创建主题(topic) bin/kafka-topics.sh --create --zookeeper m6:2181 --replication-factor 1 --partitions 1 ...
- ubuntu命令行操作mysql常用操作
登陆mysql harvey@harvey-Virtual-Machine:~/ruby/mydiary$ mysql -u root -p Enter password: Welcome to th ...
- kafka工作流程| 命令行操作
1. 概述 数据层:结构化数据+非结构化数据+日志信息(大部分为结构化) 传输层:flume(采集日志--->存储性框架(如HDFS.kafka.Hive.Hbase))+sqoop(关系型数 ...
- HDFS分布式文件系统的常用命令行操作
一.HDFS的客户端种类 1.网页形式 =>用于测试 网址为你的namenode节点的ip+50070的端口号,如: 192.168.50.128:50070 2.命令行形式 =>用于测 ...
- git 常用命令行操作
git常用命令行操作: 点击 git bash 进入到命令行: git clone https://github.com/wlz1244/qingoo.git //下载一个master分支代码 g ...
- ZooKeeper常用命令行操作
ZooKeeper常用命令行操作 通过./zkCli.sh 打开zk的客户端进入命令行后台 ls/ls2 列出当前节点下的子节点 ls2还会列出当前节点的状态 [zk: localhost:2181( ...
随机推荐
- 【进阶1-2期】JavaScript深入之执行上下文栈和变量对象(转)
这是我在公众号(高级前端进阶)看到的文章,现在做笔记 https://mp.weixin.qq.com/s/hZIpnkKqdQgQnK1BcrH6Nw 阅读笔记 JS是单线程的语言,执行顺序肯定是顺 ...
- LuoGu P1939 【模板】矩阵加速(数列)
板子传送门 矩阵快速幂学完当然要去搞一搞矩阵加速啦 (矩阵加速相对于矩阵快速幂来说就是多了一个构造矩阵的过程) 关于怎样来构造矩阵,这位大佬讲的很好呢 构造出矩阵之后,我们再去用矩阵快速幂乘出来,取[ ...
- Google开发者大会:你不得不知的Tensorflow小技巧
Google开发者大会:你不得不知的Tensorflow小技巧 同步滚动:开 Google Development Days China 2018近日在中国召开了.非常遗憾,小编因为不可抗性因素滞 ...
- easyui datagrid 隔行变色
easyui datagrid 隔行变色 一:实现样图 二:实现代码 $('#dataGrid').datagrid({ rowStyler:function(index,row){ if (row ...
- Confluence 6 使用 Velocity 宏
当编辑自定义 Decorator 模板文件的时候,有一些宏可被用来定义页面中复杂或者多变的内容,例如菜单,链接等.你可以插入这些宏到你的模板中.更多的信息,请参考Working With Decora ...
- linux 源码安装PHP
解压: 解压完: configure: configure成功: make: make完成: 安装完成!!! 测试: 需要./bin/php来运行php 想要任何目录输入PHP就能使用php 方法一: ...
- Linux编程学习笔记(一)
Linux的发展趋势势在必行,国内的服务器的操作系统Linux占到主导地位,不光是操作系统,还有嵌入式系统. 1. 今天就Linux的其中一个版本做一介绍,如下是Centos的版本之间的区别. ins ...
- 异常小结:上一张图搞清楚Java的异常机制
下面是Java异常类的组织结构,红色区域的异常类表示是程序需要显示捕捉或者抛出的. Throwable Throwable是Java异常的顶级类,所有的异常都继承于这个类. Error,Excepti ...
- 统计nginx日志里访问次数最多的前十个IP
awk '{print $1}' /var/log/nginx/access.log | sort | uniq -c | sort -nr -k1 | head -n 10
- 将眼底图片生成的txt文件进行格式化处理
# -*- coding: utf-8 -*- """ 将图片转换生成的txt文件进行格式化处理 """ import os import ...