08、Kafka ------ 消息存储相关的配置-->消息过期时间设置、查看主题下的消息存活时间等配置

目录

消息存储相关的配置

★ 消息的存储介绍

Kafka的消息主题与JMS、AMQP的消息队列是不同:JMS、AMQP消息队列中的消息只能被消费一次,当消息被消费时,这条消息就会被移出队列;

但Kafka主题中的消息完全可以被多次重复消费,甚至可以从指定下标处开始读取消息。

从某种角度来看,Kafka主题中的消息,就像数据表中的记录,它会在一段时间内持久化保存,客户端(消费者)可根据需要反复地读取它们,

这正是一开始就介绍过的:Kafka并不是单纯的消息组件,而是"开源的分布式事件流平台(open-source distributed event streaming platform)"。

★ 消息过期时间及处理方式

Kafka主题中的消息默认保存期限为7天,这个默认保存时间可通过server.propeties文件中的 log.retention.hours 属性进行修改。

当数据过期之后,Kafka可以对数据进行两种处理:delete或compact,其中

 - delete 表示直接删除过期数据,
 - compact 则表示对数据进行压缩整理,更多是偏向整理。

演示:log.cleanup.policy 属性配置

对过期消息的处理设置:设置消息过期后就删除掉

通过server.propeties文件中的 log.cleanup.policy 属性进行配置。

★ 修改指定主题的消息保存时间

在 server.properties 文件中配置的参数,它们都是对整个Broker生效的。

有些时候,可能希望仅修改特定主题的某些配置,此时就需要对特定主题进行修改了。

修改指定主题的额外属性推荐使用 kafka-configs.bat(.sh)命令,该工具命令可指定如下常用选项:

 --alter:修改。
 --describe:显示。该选项与--alter选项只能选择其中之一。
 --delete-config:指定要删除的配置属性,该选项的值应该符合"k1,k2"的形式。
 --add-config:指定要添加的配置属性,
               该选项的值为应该符合"k1=v1,k2=[v1,v2,v2],k3=v3"的形式。
 --bootstrap-server:指定要连接的服务器。
 --entity-type:指定要配置的实体类型,
   该选项可支持topics(主题)、clients(客户端)、users(用户)、
              brokers(代理)和broker-loggers(代理日志)这些值。
 --entity-name:指定要配置的实体的名称,该选项与--entity-type结合使用,
                用于指定主题名,客户端ID、用户名、Broker ID。

修改指定主题的保存时间,用 "retention.ms" 属性。

演示:将 test2 主题下的消息的保存时间设为10个小时

--alter ^ 表示要修改

--entity-name test2 ^ 表示修改的是 test2

--entity-type topics ^ 表示修改的类型是 topics 主题类型

 kafka-configs --bootstrap-server localhost:9092 ^
 --alter ^
 --entity-name test2 ^
 --entity-type topics ^
 --add-config retention.ms=36000000
1、先查看test2主题下的配置

没设置保存时间之前,查看下配置:发现什么都没有

查询的命令在下面【查看指定主题的配置】那里有介绍:就是这个查寻命令

 kafka-configs --bootstrap-server localhost:9092 ^
 --describe ^
 --entity-name test2 ^
 --entity-type topics

cmak 界面也没有时间显示:配置里面默认消息存放是7天,这里没有显示

2、然后设置消息的保存时间

然后设置test2主题下的消息保存时间为10小时:

3、然后再查一遍test2的配置,看是否修改成功

CMAK 界面查看也有了消息的存活时间:

★ 查看指定主题的配置

查看指定主题的配置可用两条命令:

命令1:查看所有对象的信息

1、使用 kafka-configs.bat 命令的 --describe 子命令

------该命令可查看所有对象的信息

--bootstrap-server localhost:9092 ^ 这个就是指定连接哪个kafka服务器地址

 kafka-configs --bootstrap-server localhost:9092 ^
 --describe ^
 --entity-name test2 ^
 --entity-type topics

直接查9092节点的kafka下的test2主题的所有对象详细,所以描述的比较少。

可以看到test2主题的配置中,该主题消息的存活时间是10小时。

命令2:查看特定主题的信息

2、使用 kafka-topics.bat 命令的 --describe子 命令

------该命令只能查看特定主题的信息

kafka-topics --bootstrap-server localhost:9092 ^
 --topic test2 ^
 --describe

因为是专门查看主题的,所以不仅有主题的配置信息,还有该主题的分区信息。

可以在CMAK界面查看这个主题的配置:

不仅可以用命令修改主题配置,在这个CMAK界面也可以直接修改和查看:

相关推荐
WX187021128737 小时前
在分布式光伏电站如何进行电能质量的治理?
分布式
Stringzhua8 小时前
【SpringCloud】Kafka消息中间件
spring·spring cloud·kafka
不能再留遗憾了10 小时前
RabbitMQ 高级特性——消息分发
分布式·rabbitmq·ruby
茶馆大橘10 小时前
微服务系列六:分布式事务与seata
分布式·docker·微服务·nacos·seata·springcloud
材料苦逼不会梦到计算机白富美13 小时前
golang分布式缓存项目 Day 1
分布式·缓存·golang
想进大厂的小王13 小时前
项目架构介绍以及Spring cloud、redis、mq 等组件的基本认识
redis·分布式·后端·spring cloud·微服务·架构
Java 第一深情13 小时前
高性能分布式缓存Redis-数据管理与性能提升之道
redis·分布式·缓存
杨荧14 小时前
【JAVA毕业设计】基于Vue和SpringBoot的服装商城系统学科竞赛管理系统
java·开发语言·vue.js·spring boot·spring cloud·java-ee·kafka
ZHOU西口15 小时前
微服务实战系列之玩转Docker(十八)
分布式·docker·云原生·架构·数据安全·etcd·rbac
zmd-zk15 小时前
kafka+zookeeper的搭建
大数据·分布式·zookeeper·中间件·kafka