本文介绍使用 Kafka 的 SASL_PLAINTEXT 接入点,对 Kafka 进行生产和消费压力测试。
连接 ECS 实例。连接方式请参见连接 ECS 实例。
在 ECS 实例中下载 Kafka 2.2.2 版本工具包。
wget https://archive.apache.org/dist/kafka/2.2.2/kafka_2.11-2.2.2.tgz
解压开源 Kafka 2.2.2 版本工具包。
tar -zxvf kafka_2.11-2.2.2.tgz
配置鉴权。
./config
目录下。consumer.properties
和 producer.properties
文件,在文件中配置 SASL 用户类型、用户名称和密码。
使用 PLAIN 用户时:
sasl.jaas.config=org.apache.kafka.common.security.plain.PlainLoginModule required username="{PLAIN用户名称}" password="{用户密码}"; sasl.mechanism=PLAIN security.protocol=SASL_PLAINTEXT
使用 SCRAM 用户时:
sasl.jaas.config=org.apache.kafka.common.security.scram.ScramLoginModule required username="{SCRAM用户名称}" password="{用户密码}"; sasl.mechanism=SCRAM-SHA-256 security.protocol=SASL_PLAINTEXT
生产消息压力测试。
进入解压后文件的./bin
目录下。
执行以下命令,进行生产消息压力测试。
./kafka-producer-perf-test.sh --topic {Topic名称} --num-records 100000 --record-size 1000 --throughput 20000 --producer-props bootstrap.servers={SASL_PLAINTEXT接入点域名:端口} --producer.config ../config/producer.properties
参数 | 说明 |
---|---|
--topic | 指定目标 Topic 的名称,需要提前在 Kafka 控制台创建。 |
--num-records | 发送的消息数量。 |
--record-size | 消息的大小,单位为 Byte。 |
--throughput | 每秒的吞吐量,即每秒发送多少条消息。 |
--producer-props | Kafka 生产者相关的配置属性。
|
--producer.config | 指定生产者的配置文件,比如可以配置为 |
查看压力测试结果。
[root@iv-xxx5uo bin]# ./kafka-producer-perf-test.sh --topic topic-1 --num-records 100000 --record-size 1000 --throughput 20000 --producer-props bootstrap.servers=kafka-xxxc5y.kafka.ivolces.com:9093 --producer.config ../config/producer.properties 98838 records sent, 19759.7 records/sec (18.84 MB/sec), 54.8 ms avg latency, 201.0 ms max latency. 100000 records sent, 19323.671498 records/sec (18.43 MB/sec), 56.16 ms avg latency, 201.00 ms max latency, 1 ms 50th, 190 ms 95th, 193 ms 99th, 196 ms 99.9th.
分析:本例中一共写入 10w 条消息,每秒向 Kafka 写入了 18.43MB 的数据,平均是 19323.671498 条消息/秒,每次写入的平均延迟为 56.16 毫秒,最大的延迟为 201 毫秒。
消费消息压力测试。
进入解压后文件的./bin
目录下。
执行以下命令,进行消费消息压力测试。
./kafka-consumer-perf-test.sh --topic {Topic名称} --fetch-size 1048576 --messages 100000 --group {Group名称} --broker-list {SASL_PLAINTEXT接入点域名:端口} --consumer.config ../config/consumer.properties
参数 | 说明 |
---|---|
--topic | 指定需要订阅的目标 Topic 的名称。 |
--fetch-size | 一次请求提取的数据量 , 默认 1048576,单位为 Byte。 |
--messages | 消费的消息数量。 |
--group | 自定义设置 Group 的名称,无需提前在 kafka 控制台上创建。 |
--broker-list | Kafka 实例的接入点。请在控制台实例详情页面的服务访问区域中查看接入点信息。 |
--consumer.config | 指定消费者的配置文件,比如可以配置为 |
查看压力测试结果。
[root@iv-xxx5uo bin]# ./kafka-consumer-perf-test.sh --topic topic-1 --fetch-size 1048576 --messages 100000 --group group-1 --broker-list kafka-xxxc5y.kafka.ivolces.com:9093 --consumer.config ../config/consumer.properties start.time, end.time, data.consumed.in.MB, MB.sec, data.consumed.in.nMsg, nMsg.sec, rebalance.time.ms, fetch.time.ms, fetch.MB.sec, fetch.nMsg.sec 2024-08-05 15:35:00:361, 2024-08-05 15:35:09:561, 95.3674, 10.3660, 100000, 10869.5652, 3071, 6129, 15.5600, 16315.8753
执行命令后,返回如下类似结果,分析如下: