返回到文章

采纳

编辑于 3年前

配置Kafka内外网访问后,Kafka manager不能使用了,如何走内网获取jmxtrans的信息,或者帮忙推荐个别的监控工具

kafka

配置Kafka内外网访问后,Kafka manager不能使用了,如下为配置

listener.security.protocol.map=INTERNAL:PLAINTEXT,EXTERNAL:PLAINTEXT
listeners=EXTERNAL://192.168.0.213:19092,INTERNAL://192.168.0.213:9092
advertised.listeners=EXTERNAL://101.89.163.9:19092,INTERNAL://192.168.0.213:9092
inter.broker.listener.name=INTERNAL

zookeeper中存储的信息

[zk: localhost:2181(CONNECTED) 1] get /brokers/ids/10
{"listener_security_protocol_map":{"EXTERNAL":"PLAINTEXT","INTERNAL":"PLAINTEXT"},"endpoints":["EXTERNAL://101.89.163.9:19092","INTERNAL://192.168.0.213:9093"],"jmx_port":9999,"host":"101.89.163.9","timestamp":"1639470932314","port":9094,"version":4}

jmxtrans获取的外网地址,而外网地址是不通的,想要走内网获取jmxtrans地址

Kafka manager中的报错信息

[error] k.m.a.c.BrokerViewCacheActor - Failed to get broker metrics for BrokerIdentity(30,101.89.163.9,9999,false,true,Map(PLAINTEXT -> 9096))
java.io.IOException: Failed to retrieve RMIServer stub: javax.naming.ServiceUnavailableException [Root exception is java.rmi.ConnectException: Connection refused to host: 101.89.163.9; nes
ted exception is: 
java.net.ConnectException: Connection timed out (Connection timed out)]
at javax.management.remote.rmi.RMIConnector.connect(RMIConnector.java:369) ~[na:1.8.0_151]
at javax.management.remote.JMXConnectorFactory.connect(JMXConnectorFactory.java:270) ~[na:1.8.0_151]
at kafka.manager.jmx.KafkaJMX$.doWithConnection(KafkaJMX.scala:57) ~[kafka-manager.kafka-manager-
at

配置信息:

  • 外网地址:EXTERNAL://101.89.163.9:19092
  • 内网地址:INTERNAL://192.168.0.213:9092

这边由于权限配置,在部署kafka manager机器上受到限制访问不了外网。

kafka manager的连接配置:

kafka-manager.zkhosts="192.168.0.213:2181,192.168.0.214:2181,192.168.0.215:2181"
kafka-manager.zkhosts=${?ZK_HOSTS}

连接zookeeper获取的是外网的jmxtrans信息,如何能够走内网通信?

或者推荐下别的监控运维工具