栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 前沿技术 > 大数据 > 大数据系统

【Kafka】编译 Kafka 源码并搭建源码环

【Kafka】编译 Kafka 源码并搭建源码环

《Kafka运维管控平台LogiKM》
✏️更强大的管控能力✏️
更高效的问题定位能力
更便捷的集群运维能力
更专业的资源治理
更友好的运维生态

搭建源码环境可以看这篇文章:
编译 Kafka 源码并搭建源码环境

上面有个地方注意,启动的时候,可以传入VM参数来指定 kafka.log.dir 路径(存放各种日志的路径)

-Dkafka.logs.dir=/Users/shirenchuang/work/IdeaPj/open_source/kafka/logs

按照上面的方法搭建并成功启动了Kafka, 那么当我们想要启动集群怎么办呢?

IDEA同时启动多个Kafka

    配置多个server.properties, 例如server1.properties、server2.properties、server3.properties

    修改不同server.properties的配置
    注意以下几个配置不要重复了
    ##不同的id
    broker.id=0

    ##不同的端口
    listeners=PLAINTEXT://xxxx:9090

    ##不同的日志存放路径
    log.dirs=k0

    创建多个Application 启动配置

    -Dkafka.logs.dir=运行日志路径 这个也要注意放到不同路径。 这里的kafka.logs.dir参数就是log4j.properties中的${kafka.logs.dir}参数。

    然后就可以同时启动多个在IDEA中的Broker了,并且都可以本地调试。

IDEA开启JMX端口

-Djava.rmi.server.hostname=127.0.0.1
-Dcom.sun.management.jmxremote
-Dcom.sun.management.jmxremote.port=9191
-Dcom.sun.management.jmxremote.ssl=false
-Dcom.sun.management.jmxremote.authenticate=false

注意不要端口冲突了,不同broker设置不同的端口。

kafka中添加日志

你在调试代码的时候,可能想加一点日志观察。

   info(s"打一个启动日志..集群id = $clusterId")
   

日志打印到控制台

默认的log4j.properties文件是没有将日志打印到控制台的,既然我们是调试,那么让日志打印到控制台会更加直观。这个时候改下log4j.properties配置文件就行

将原来的配置
log4j.logger.kafka=INFO
改成
log4j.logger.kafka=INFO, kafkaAppender,stdout

调试常用脚本命令

可能你想执行kafka的一些脚本,并且进行debug调试.

那我们可以通过sh脚本内容太找到最终是调用了哪个类,比如 增删改查 Topic

最终调用的类是 kafka.admin.TopicCommand, 那我们调用这个类的main方法就行了。

当然,这个类的调用需要有入参,在idea配置传入就行了。
比如,创建一个3分区1副本的Topic。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/742433.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号