Performance issues with `Mint` adapter
beligante opened this issue · 2 comments
Describe the bug
There are some issues with the current implementation for mint adapter from a performance standpoint.
To Reproduce
Easy way to see is In Interop tests script
If you wrap the runner with :timer.tc
and run mix run script/run.exs --rounds 1
it's possible to see that the amount of time that Gun adapter takes to run all test cases vs Mint is quite different. On my machine the avg for both was:
- 800ms for Gun
- 5.6s for Mint
With the numbers above it's possible to assume for sure that there are some performance improvements that needs to be done for Mint adapter.
Expected behavior
Similar times for both adapters
Versions:
- OS: Linux / Mint
- Elixir: 1.13.3-otp-25
- Erlang: 25.0.3
Additional context
A few things that I could observer from the current implementation that could be better:
- Accessing/Updating state using
Accesss
- According to this article this action is quite slow: https://medium.com/learn-elixir/speed-up-data-access-in-elixir-842617030514 - Storing and updating data on state that I'm not using.
I'm open for investigate and fix this issue and also I'm quite open for suggestions.
I'd look for a simpler script that benchmarks with Benchee so that things are more easily reproducible.
It could be the case that the Mint code is as fast as Gun when there's no concurrency. If this is the case, then it's a problem with process message serialization.
If even with minimal concurrency it's still much slower, then it's a matter of finding the bottleneck in the code.
Gotcha! I'll work on the script for Benchee (which - TIL about the lib) and see what are the results. Tks Paulo!