[erlang-questions] Cowboy (Erlang) VS Haskell (Warp)

Sergej Jurecko sergej.jurecko@REDACTED
Tue Jun 25 20:30:22 CEST 2013


On Jun 25, 2013, at 7:38 PM, BM Kim wrote:

> Damian Dobroczyński <qoocku <at> gmail.com> writes:
> 
>> 
>> W dniu 25.06.2013 13:51, BM Kim pisze:
>>> Hi folks,
>>> 
>>> First of all, I want to apologise for my poor english skills,
>>> since english is not my first language, but I'll try my best
>>> to formulate my quesions as clear as possible.
>>> 
>>> Second, I've just begun to learn erlang, so if I'm asking
>>> obvious "noob" questions I apologise for that too in advance...
>>> 
>>> Anywho, now to my actual question:
>>> 
>>> I am planning to write a high-performance server application in erlang,
>>> which will primarily handle HTTP requests. After some reseach with 
> google,
>>> I narrowed down my choices to cowboy, misultin and mochiweb and decided
>>> to go with the cowboy library first...
>>> 
>>> Looking at some tutorials, I've quickly built a small server capable of
>>> serving static files and was eager to see first benchmark-results...
>>> I've also built a small Haskell server using Warp library to compare it
>>> with erlang's cowboy...
>>> 
>>> But my first impression was, that my cowboy server is much much slower 
> than
>>> expected when serving static-files and after some research I found a 
> presentation
>>> of the cowboy's author claiming that cowboy shouldn't be used for 
> serving
>>> static-files. So I modified the server code, so that it replies to every
>>> request with in-memory 4Kb binary blob and compared it with my haskell 
> warp
>>> server serving 4kb static file...
>>> 
>>> this is my simple cowboy's http handler:
>>> 
>>> ----------------------------------------------------------------------
>>> 
>>> blob() ->
>>>    [<<0:8>> || _ <- lists:seq(1,4096)].
>> 
>> First, try to replace blob/0 function with this:
>> 
>>  blob() -> <<0:(4096*8)>>.
>> 
>> Then, restart the test and report ;)
>> 
> 
> 
> Hi,
> 
> Thank you very much for pointing out the obvious mistake...
> After correcting it, I got improvement from 5940 req/s to 8650 req/s...
> 
> But still much slower than the haskell warp-server, which has throughput
> of 38000 req/s...
> 
> But I have another question regarding blob/0. Is it going to be evaluated
> only once (like GHC would do) since it is a pure expression? I'm not
> so sure, since erlang is not pure and any function can have side-effects
> which you can't mark as with the IO monad in Haskell...
> 


If you only care about performance use Haskell or c. 


Sergej




More information about the erlang-questions mailing list