【Java Web】Kafka,构建TB级异步消息系统

1. 阻塞队列

  • BlockingQueue
    • 解决线程通信的问题;
    • 阻塞方法:put从队列中存一个 , take 从队列中拿出一个
  • 生产者消费者模式
    • 生产者:产生数据的线程;
    • 消费者:使用数据的线程。
  • 实现类
    • ArrayBlockingQueue
    • LinkedBlockingQueue
    • ProrityBlockingQueueSynchronousQueueDelayQueue
  • 阻塞队列充当了生产者(Thread-1)和消费者(Thread-2)之间的桥梁;
  • 若Blocking Queue满了,将阻塞生产者,线程1陷入等待;
  • 若Blocking Queue空了,将阻塞消费者,线程2陷入等待;
  • 因此,可以防止系统资源被浪费。

2. Kafka入门

  • Kafka简介
    • kafka 是一个分布式的流媒体平台;
    • 应用:消息系统、日志收集、用户行为追踪、流式处理。
  • Kafka特点
    • 高吞吐量、消息持久化、高可靠性、高扩展性
  • Kafka术语
    • Broker(一个服务器)、Zookeeper(集群)
    • Topic(文件夹)、Partition(分区,提高容错率)、Offset(在分区中的位置)
    • Leader Replica(主副本,如果需要从分区获取数据,主副本可以响应)、Follower Replica(随从副本,备份)

-卡夫卡能处理海量数据(高吞吐量 ),因为卡夫卡将数据存在硬盘此类的介质里,而硬盘比内存的价格低廉,所以它可以持久化 。卡夫卡的分布式保证了高可靠性 。如果想要加入新服务器,只需简单的配置,因此具有高扩展性

【1】Mac 启动Zookeeper:

java 复制代码
./zookeeper-server-start.sh ../config/zookeeper.properties &

【2】启动Kafka:

java 复制代码
./kafka-server-start.sh ../config/server.properties &

【3】创建Topic

java 复制代码
./kafka-topics.sh --bootstrap-server localhost:9092 --create --topic javaTopic --partitions 2 --replication-factor 1

replication-factor:指定副本数量

partitions:指定分区

【4】查看Topic

java 复制代码
./kafka-topics.sh --bootstrap-server localhost:9092 --list

【5】删除Topic

java 复制代码
./kafka-topics.sh --bootstrap-server localhost:9092 --delete -topic javaTopic

【6】生产消费数据

【6-1】生产者

java 复制代码
./kafka-console-producer.sh --broker-list localhost:9092 --topic javaTopic

【6-2】消费者

java 复制代码
./kafka-console-consumer.sh --bootstrap-server localhost:9092 --topic javaTopic --from-beginning
相关推荐
miss1 分钟前
Vue2 → Vue3 深度对比:8 大核心优化,性能提升 2 倍
前端·vue.js·架构
殷紫川4 分钟前
线上故障零扩散:全链路监控、智能告警与应急响应 SOP 完整落地指南
java·架构·监控
前端小雪的博客.10 分钟前
Java的面向对象:封装详解(0基础入门版)
java·java入门·java面向对象·封装详解·java封装·0基础学java·getter和setter
左左右右左右摇晃13 分钟前
Java并发——死锁
java·开发语言·spring
ShayneLee819 分钟前
jar-替换依赖包
java·jar
standovon25 分钟前
Spring Boot+Vue项目从零入手
java
爱丽_26 分钟前
ThreadLocal 机制:弱引用 Entry、内存泄漏、线程池复用与线上排查
java·jvm·算法
前端小雪的博客.26 分钟前
Java的面向对象:方法重写(0基础入门版)
java·java基础·java入门·override·方法重写·java面向对象·方法重写与重载的区别
殷紫川28 分钟前
Java 工程化体系:代码规范与团队协作全链路标准
java·架构·代码规范
半瓶榴莲奶^_^31 分钟前
java模式
java·开发语言