IXWebSocket/benchmarks
Benjamin Sergeant c992cb4e42 Squashed 'test/compatibility/C/uWebSockets/' content from commit 03681cc
git-subtree-dir: test/compatibility/C/uWebSockets
git-subtree-split: 03681ccbe630eb4db6322557e6bfe8cda8f41526
2020-01-04 15:41:03 -08:00
..
broadcast_test.c Squashed 'test/compatibility/C/uWebSockets/' content from commit 03681cc 2020-01-04 15:41:03 -08:00
load_test.c Squashed 'test/compatibility/C/uWebSockets/' content from commit 03681cc 2020-01-04 15:41:03 -08:00
Makefile Squashed 'test/compatibility/C/uWebSockets/' content from commit 03681cc 2020-01-04 15:41:03 -08:00
README.md Squashed 'test/compatibility/C/uWebSockets/' content from commit 03681cc 2020-01-04 15:41:03 -08:00
scale_test.c Squashed 'test/compatibility/C/uWebSockets/' content from commit 03681cc 2020-01-04 15:41:03 -08:00

Benchmark-driven development

Just like testing code for correctness and stability, testing for performance is just as important if performance is a goal. You cannot really argue or reason about performance without having tests for it.

  • Do not trust anyone who claims performance of any kind unless they provide benchmarks. Do not listen to people who talk about performance without having actual scientific data to back their claims up.
  • Never accept absolute numbers without a direct comparison with an alternative solution. Many projects can give you a number, X, which can be "50 billion messages per second". How much is this? What kind of worth does this number have? Impossible to know without a comparison. Absolute numbers mean nothing, relative comparisons are what you should look for.
  • Make sure to benchmark the correct thing. This is an extremely common mistake, done by many of the most well-known developers out there. If you measure for CPU-time efficiency (which you do) then normalizing for spent CPU-time is the difference between a completely invalid, botched and bogus test and something that might be valid.

Here are the current relative comparisons:

Http WebSockets

Over the period of a few years I have never come across any web server which can score as high as µWebSockets do. This is not to say that µWebSockets is fastest, as "fastest" is a silly superlative nobody should ever use.

Never trust anyone using superlatives to describe their work; they are more often wrong than right.