With the recent announcement of Facebook that their HHVM is now more and more compatible with most of the popular framework, I was intrigued to finally try it out. We're currently building a Symfony2 based application, which has pretty high performance requirements (but we can mostly achieve them with varnish), so I went and did some performance tests on that real-life app.
The application basically gets data from an ElasticSearch server and then transforms them to JSON. Nothing too fancy from the output perspective, but we use many features of Symfony2 and what was clear from the beginning is that the more data it gets from ElasticSearch the slower the requests get. Meaning that we loose a lot of time in the serialization part (we use JMSSerializer for that).
In short, the numbers were amazing. I also compared PHP 5.3 with APC against 5.5 with opcache, that alone gave some pretty decent improvements.
The setup I did the tests on was a QuadCore Intel i7-4770 CPU @ 3.40GHz server over at Hetzner with SSD disks and more than enough RAM. The actual application ran in a VirtualBox container with 4 CPUs and 2 GB of RAM. I used Apache Bench for the tests with the HHVM vagrant VM running Ubuntu 12.04, but I installed the pre-built HHVM from their repo in the end.
I made 3 different requests with different amount of data the script had to get from ElasticSearch. One was approx. 7kb in response, the other 80kb and the last 220kb. I didn't it with different concurrency settings (1-50) and ran Apache Bench with 500 requests per run. The figures below are averages over those 500 requests.
I didn't do performance measurements for PHP 5.3 with more than 6 concurrent requests, because I added 10,20,50 later and didn't repeat for 5.3, but the trend is clear nevertheless.
As you can see below, in general the longer the PHP request ran, the more we gained from HHVM, up to and sometimes more than 300% against PHP 5.3, and about 200% against PHP 5.5. Only switching from PHP 5.3 to PHP 5.5 can save you up to twice the time, as well. So it is very much worth upgrading to 5.5. I find both numbers pretty amazing.
If you really need every millisecond performance, considering HHVM is worth some investigation. These numbers are very promising. And I don't had to change one line of code in our application. As we don't use it yet in production, I can't say anything about stability. Obviously tools like New Relic are, at least for now, also out of the question with HHVM.
Requests per second, small response
The higher the better
Concurrency | PHP 5.3 | PHP 5.5 | HHVM | HHVM vs 5.3 | HHVM vs 5.5 | 5.5 vs 5.3 |
---|---|---|---|---|---|---|
1 | 52 | 84 | 81 | 157Â % | 96Â % | 163Â % |
2 | 120 | 163 | 207 | 173Â % | 127Â % | 136Â % |
3 | 154 | 219 | 285 | 185Â % | 130Â % | 142Â % |
4 | 172 | 247 | 317 | 185Â % | 129Â % | 144Â % |
5 | 186 | 256 | 342 | 184Â % | 134Â % | 138Â % |
6 | 203 | 259 | 340 | 168Â % | 132Â % | 128Â % |
10 | 253 | 443 | 175Â % | |||
20 | 247 | 441 | 179Â % | |||
50 | 258 | 380 | 147Â % |
Requests per second, middle response
The higher the better
Concurrency | PHP 5.3 | PHP 5.5 | HHVM | HHVM vs 5.3 | HHVM vs 5.5 | 5.5 vs 5.3 |
---|---|---|---|---|---|---|
1 | 10 | 14 | 26 | 269Â % | 184Â % | 146Â % |
2 | 19 | 29 | 56 | 295Â % | 193Â % | 153Â % |
3 | 28 | 42 | 79 | 286Â % | 186Â % | 154Â % |
4 | 34 | 51 | 92 | 271Â % | 179Â % | 151Â % |
5 | 35 | 53 | 98 | 279Â % | 186Â % | 150Â % |
6 | 35 | 50 | 101 | 285Â % | 203Â % | 140Â % |
10 | 56 | 113 | 202Â % | |||
20 | 53 | 105 | 197Â % | |||
50 | 56 | 108 | 193Â % |
Requests per second, large response
The higher the better
Concurrency | PHP 5.3 | PHP 5.5 | HHVM | HHVM vs 5.3 | HHVM vs 5.5 | 5.5 vs 5.3 |
---|---|---|---|---|---|---|
1 | 4 | 6 | 12 | 283Â % | 179Â % | 158Â % |
2 | 8 | 12 | 25 | 333Â % | 207Â % | 161Â % |
3 | 11 | 18 | 37 | 324Â % | 208Â % | 155Â % |
4 | 15 | 22 | 46 | 307Â % | 207Â % | 148Â % |
5 | 15 | 23 | 48 | 318Â % | 208Â % | 153Â % |
6 | 15 | 24 | 51 | 339Â % | 215Â % | 158Â % |
10 | 24 | 51 | 218Â % | |||
20 | 24 | 49 | 208Â % | |||
50 | 24 | 50 | 212Â % |
Median response time in ms, short response
The lower the better
Concurrency | PHP 5.3 | PHP 5.5 | HHVM | HHVM vs 5.3 | HHVM vs 5.5 | 5.5 vs 5.3 |
---|---|---|---|---|---|---|
1 | 15 | 11 | 9 | 60Â % | 82Â % | 73Â % |
2 | 16 | 12 | 10 | 59Â % | 79Â % | 75Â % |
3 | 19 | 13 | 11 | 55Â % | 81Â % | 68Â % |
4 | 23 | 16 | 13 | 54Â % | 78Â % | 70Â % |
5 | 26 | 18 | 14 | 54Â % | 78Â % | 69Â % |
6 | 29 | 22 | 17 | 57Â % | 75Â % | 76Â % |
10 | 38 | 21 | 55Â % | |||
20 | 78 | 43 | 55Â % | |||
50 | 191 | 105 | 55Â % |
Median response time in ms, middle response
The lower the better
Concurrency | PHP 5.3 | PHP 5.5 | HHVM | HHVM vs 5.3 | HHVM vs 5.5 | 5.5 vs 5.3 |
---|---|---|---|---|---|---|
1 | 98 | 61 | 32 | 33Â % | 53Â % | 62Â % |
2 | 103 | 66 | 34 | 33Â % | 52Â % | 64Â % |
3 | 107 | 66 | 36 | 34Â % | 55Â % | 62Â % |
4 | 112 | 71 | 40 | 36Â % | 56Â % | 63Â % |
5 | 138 | 89 | 49 | 36Â % | 55Â % | 64Â % |
6 | 171 | 112 | 57 | 33Â % | 51Â % | 65Â % |
10 | 174 | 83 | 48Â % | |||
20 | 366 | 185 | 51Â % | |||
50 | 872 | 451 | 52Â % |
Median response time in ms, large response
The lower the better
Concurrency | PHP 5.3 | PHP 5.5 | HHVM | HHVM vs 5.3 | HHVM vs 5.5 | 5.5 vs 5.3 |
---|---|---|---|---|---|---|
1 | 236 | 149 | 71 | 30Â % | 48Â % | 63Â % |
2 | 249 | 158 | 75 | 30Â % | 47Â % | 63Â % |
3 | 253 | 161 | 77 | 30Â % | 48Â % | 64Â % |
4 | 261 | 168 | 81 | 31Â % | 48Â % | 64Â % |
5 | 327 | 211 | 98 | 30Â % | 46Â % | 65Â % |
6 | 394 | 246 | 115 | 29Â % | 47Â % | 62Â % |
10 | 419 | 189 | 45Â % | |||
20 | 843 | 394 | 47Â % | |||
50 | 2069 | 968 | 47Â % |
I will have a look at memory consumption in a follow up post.