This repository has been archived by the owner on Jun 16, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 1.8k
Performance Testing
longdafeng edited this page Oct 13, 2014
·
5 revisions
- Server Number: 7, nimbus/web ui/zookeeper run in one node, supervisor run in the left 6 nodes
- Hardware:
CPU: 24 Core(Intel(R) Xeon(R) CPU E5-2430 0 @ 2.20GHz)
Memory: 96G
Disk: 2T[sata,7200rpm]
Network Adapter: 1Ge*2
- Software:
OS: Redhat Enterprise Linux 5.7 x86_64
Java: java version "1.6.0_32" 64bits
Storm: Storm-0.9.2-netty-p297
JStorm: jstorm-0.9.4.1
- JStorm testing source code
- Storm testing source code, JStorm testing source code is same as Storm's except the code read Zookeeper node, so there are two set of testing code.
- JStorm is faster than Storm
- The ratio of task_num/worker_number is critical, the performance isn't linearly growing as ratio growing. The ratio had better no bigger than 12 in JStorm, no bigger than 18 in Storm. Otherwise performance will drop down due to thread switch .
- The bigger message size, the higher throughput, when CPU and network-throughput is enough
- The simpler the topology, the higher throughput.
- Strongly suggest setting "topology.max.spout.pending", otherwise tuple is likely to occur failure.
Don't change executor/task parallelism, just set different worker number
Spout number: 18
Bolt number: 18
Acker number: 18
Message Size: 10 bytes
Max.spout.pending: 10000
topology.performance.metrics: false
topology.alimonitor.metrics.post: false
disruptor.use.sleep: false
Topology Level: one kind of spout, one kind of bolt, shuffle grouping
Throughput VS Workers Remarks: The horizontal axis is the number of worker number, Y-coordinate is the emit speed of Spout every 10 seconds
Cpu Usage VS Workers
- JStorm performance is higher than storm's when task/worker number ratio is lower than 12.
- JStorm save more cpu usage
- When worker number is 12, both JStorm throughput and Storm throughput is best, if worker number is bigger than 12, but the throughput reduce, so normally The root cause is as following:
- The ratio of task number/worker number is bigger, the more data will be past in one JVM, no network cost, don't need do serialize/deserialize worker.
- When the ratio of task number/worker number is too high, thread context switch will cost much CPU, so the throughput isn't simply increase when enlarge the ratio of task/worker.
- When server number is fixed, enlarge the worker's number, it will increase worker's common threads such as total dispatch thread, total sending thread, netty client thread, these thread will cost more cpu, so increasing worker's number doesn't simply improve the performance.
Set different message size, check the throughput changing.
Spout number: 18
Bolt number: 18
Acker number: 18
Worker number:
Max.spout.pending: 10000
topology.performance.metrics: false
topology.alimonitor.metrics.post: false
disruptor.use.sleep: false
Topology Level: one kind of spout, one kind of bolt, shuffle grouping
- Increasing message size will improve both JStorm and Storm performance when CPU and network is enough
- Normally JStorm throughput is higher than Storm's
Set different topology bolt layer, check the throughput changing.
Spout number: 18
Bolt number: 18
Acker number: 18
Worker number:
Max.spout.pending: 10000
message-size=10 byte
topology.performance.metrics: false
topology.alimonitor.metrics.post: false
disruptor.use.sleep: false
Topology Level: one kind of spout, one kind of bolt, shuffle grouping
- Increasing bolt level will reduce the throughput normally, increase cpu usage.