我需要设置两个参数min.insync.replicas
和acks
. 官方文档说参数min.insync.replicas
是broker的参数。我是否正确理解应该在 server.properties 文件中指定所有主题?其中之一 - 使用命令 kafka.config.sh。Acks
参数只能在配置生产者时设置,例如从应用程序?对文件 producer.properties 的更改不会有帮助吗?
问问题
1709 次
1 回答
5
中定义的主题相关属性server.properties
对所有主题都有效(假设您在创建主题时不修改任何配置)。
现在,如果出于某种原因您想修改特定主题的一个属性,您可以通过为该主题提供新配置来覆盖全局配置。例如,
bin/kafka-configs.sh \
--zookeeper localhost:2181 \
--alter \
--entity-type topics \
--entity-name yourTopicName \
--add-config min.insync.replicas=2
或者,如果您想创建一个与您定义的配置不同的主题,server.properties
您可以使用:
bin/kafka-topics.sh \
--zookeeper localhost:2181 \
--create \
--topic yourTopicName \
--partitions 1 \
--replication-factor 3 \
--config min.insync.replicas=2
最后,如果要验证配置是否有效,可以简单描述一下主题,添加的配置会显示在(Configs
右上角)的输出中:
bin/kafka-topics \
--zookeeper localhost:2181 \
--describe \
--topic yourTopicName
于 2020-05-06T16:58:52.110 回答