一个物联网应用的典型场景,接收遥测数据然后解析并做业务处理。吞吐量不固定,但是要求稳定。
我的测试环境:
操作系统:Mac OS; 2.7 GHz Intel Core i5; 内存 8g
Kafka:2.x 版本
Spring boot:2.0.3
Kafka 配置:1 个 topic,4 个 partition
Producer 模拟发送 1000 条消息,耗时 500 毫秒左右。
Consumer 批量接收( MAX_POLL_RECORDS_CONFIG = 50 )后,进入一个注解为 @Async 的方法并处理业务逻辑,每次业务逻辑耗时 80 ~ 100 毫秒,
我想测试一下线程池的最优配置,正规测试流程是什么?想知道大家是怎么玩的。
注:
以下是我的部分测试结果(感觉有出入):
corePoolSize:80
maxPoolSize:100
queueCapacity:1500
消费 1000 条耗时:11s
corePoolSize:8
maxPoolSize:10
queueCapacity:1500
消费 1000 条耗时:15s
corePoolSize:8
maxPoolSize:20
queueCapacity:1500
消费 1000 条耗时:13s
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.