Table of Contents
Site Load Times ¶
This page is to document the time the site takes to load.
2014-01-29 ¶
For reference, the following was run a few times on wiki:PuffinServer:
ab -v 4 -n 200 -c 10 -H "Accept-Encoding: gzip" http://www.transitionnetwork.org/
And the results were compared and this is a slow one:
Completed 200 requests Finished 200 requests Server Software: nginx Server Hostname: www.transitionnetwork.org Server Port: 80 Document Path: / Document Length: 13252 bytes Concurrency Level: 10 Time taken for tests: 0.859 seconds Complete requests: 200 Failed requests: 0 Write errors: 0 Total transferred: 2758044 bytes HTML transferred: 2650400 bytes Requests per second: 232.74 [#/sec] (mean) Time per request: 42.966 [ms] (mean) Time per request: 4.297 [ms] (mean, across all concurrent requests) Transfer rate: 3134.35 [Kbytes/sec] received Connection Times (ms) min mean[+/-sd] median max Connect: 1 1 1.5 1 8 Processing: 4 11 6.6 9 47 Waiting: 3 10 6.5 8 46 Total: 4 13 6.9 11 54 Percentage of the requests served within a certain time (ms) 50% 11 66% 15 75% 17 80% 17 90% 22 95% 24 98% 31 99% 36 100% 54 (longest request)
And this is a fast one:
Completed 200 requests Finished 200 requests Server Software: nginx Server Hostname: www.transitionnetwork.org Server Port: 80 Document Path: / Document Length: 13248 bytes Concurrency Level: 10 Time taken for tests: 0.200 seconds Complete requests: 200 Failed requests: 0 Write errors: 0 Total transferred: 2757424 bytes HTML transferred: 2649600 bytes Requests per second: 998.54 [#/sec] (mean) Time per request: 10.015 [ms] (mean) Time per request: 1.001 [ms] (mean, across all concurrent requests) Transfer rate: 13444.29 [Kbytes/sec] received Connection Times (ms) min mean[+/-sd] median max Connect: 0 0 0.2 0 2 Processing: 3 9 7.0 8 55 Waiting: 2 9 6.9 7 55 Total: 3 10 7.0 8 55 Percentage of the requests served within a certain time (ms) 50% 8 66% 10 75% 13 80% 14 90% 19 95% 23 98% 28 99% 38 100% 55 (longest request)
2013-10-20 ¶
See LoadTimesOctThirteen.
2013-05-29 ¶
The slowness documented yesterday, LoadTimes#a2013-05-28 was due to redis being unavailable due to the password missing from the /data/conf/global.inc file, this was fixed on ticket:554#comment:5, following the fix the speed of the site is back to normal:
ab -v 4 -n 200 -c 10 -H "Accept-Encoding: gzip" http://www.transitionnetwork.org/ LOG: Response code = 200 Completed 200 requests Finished 200 requests Server Software: nginx Server Hostname: www.transitionnetwork.org Server Port: 80 Document Path: / Document Length: 10049 bytes Concurrency Level: 10 Time taken for tests: 0.197 seconds Complete requests: 200 Failed requests: 128 (Connect: 0, Receive: 0, Length: 128, Exceptions: 0) Write errors: 0 Total transferred: 2143788 bytes HTML transferred: 2007624 bytes Requests per second: 1016.38 [#/sec] (mean) Time per request: 9.839 [ms] (mean) Time per request: 0.984 [ms] (mean, across all concurrent requests) Transfer rate: 10639.16 [Kbytes/sec] received Connection Times (ms) min mean[+/-sd] median max Connect: 0 0 0.2 0 1 Processing: 2 9 7.4 7 79 Waiting: 2 8 7.4 6 78 Total: 2 9 7.4 7 80 Percentage of the requests served within a certain time (ms) 50% 7 66% 9 75% 11 80% 12 90% 17 95% 22 98% 26 99% 28 100% 80 (longest request)
2013-05-28 ¶
The front page index.php now takes around 5 seconds to generate, for example, following is a test done from ParrotServer, see ticket:554 for more on this issue:
ab -n 1 -v 4 -H "Accept-Encoding: gzip" http://www.transitionnetwork.org/ This is ApacheBench, Version 2.3 <$Revision: 655654 $> Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/ Licensed to The Apache Software Foundation, http://www.apache.org/ Benchmarking www.transitionnetwork.org (be patient)...INFO: POST header == --- GET / HTTP/1.0 Accept-Encoding: gzip Host: www.transitionnetwork.org User-Agent: ApacheBench/2.3 Accept: */* --- LOG: header received: HTTP/1.1 200 OK Server: nginx Date: Tue, 28 May 2013 18:08:04 GMT Content-Type: text/html; charset=utf-8 Connection: close Vary: Accept-Encoding X-Backend: C X-Allow-Redis: YES X-Purge-Level: 6 X-Cookie-Domain: .transitionnetwork.org X-Redis-Prefix: www.transitionnetwork.org_ X-Accel-Expires: Cache-Control: public, max-age=0 Last-Modified: Tue, 28 May 2013 18:07:58 +0000 Expires: Sun, 11 Mar 1984 12:00:00 GMT Vary: Cookie X-Engine: Octopus 1.0 ET X-Device: normal X-Speed-Cache: EXPIRED X-Speed-Cache-Key: / X-NoCache: Cache X-GeoIP-Country-Code: GB X-GeoIP-Country-Name: United Kingdom X-Server-Name: www.transitionnetwork.org Content-Encoding: gzip � LOG: Response code = 200 ..done Server Software: nginx Server Hostname: www.transitionnetwork.org Server Port: 80 Document Path: / Document Length: 10052 bytes Concurrency Level: 1 Time taken for tests: 5.696 seconds Complete requests: 1 Failed requests: 0 Write errors: 0 Total transferred: 10735 bytes HTML transferred: 10052 bytes Requests per second: 0.18 [#/sec] (mean) Time per request: 5695.665 [ms] (mean) Time per request: 5695.665 [ms] (mean, across all concurrent requests) Transfer rate: 1.84 [Kbytes/sec] received Connection Times (ms) min mean[+/-sd] median max Connect: 0 0 0.0 0 0 Processing: 5695 5695 0.0 5695 5695 Waiting: 5695 5695 0.0 5695 5695 Total: 5696 5696 0.0 5696 5696
For comparison with older tests documented on this page:
ab -v 4 -n 200 -c 10 -H "Accept-Encoding: gzip" http://www.transitionnetwork.org/ Server Software: nginx Server Hostname: www.transitionnetwork.org Server Port: 80 Document Path: / Document Length: 9768 bytes Concurrency Level: 10 Time taken for tests: 5.539 seconds Complete requests: 200 Failed requests: 1 (Connect: 0, Receive: 0, Length: 1, Exceptions: 0) Write errors: 0 Total transferred: 2090586 bytes HTML transferred: 1953787 bytes Requests per second: 36.11 [#/sec] (mean) Time per request: 276.929 [ms] (mean) Time per request: 27.693 [ms] (mean, across all concurrent requests) Transfer rate: 368.61 [Kbytes/sec] received Connection Times (ms) min mean[+/-sd] median max Connect: 0 0 0.2 0 1 Processing: 2 35 391.0 6 5537 Waiting: 2 35 391.0 5 5537 Total: 2 36 391.1 6 5538 Percentage of the requests served within a certain time (ms) 50% 6 66% 9 75% 11 80% 13 90% 15 95% 21 98% 29 99% 44 100% 5538 (longest request)
Requesting the front page 200 times running 10 concurrent processes over time -- the site is now roughly back to the speed it had when it was running with apache without varnish, two years ago:
- LoadTimes#a2013-05-28 5.539 seconds wiki:PuffinServer
- LoadTimes#a2013-01-28 0.253 seconds wiki:NewLiveServer
- LoadTimes#a2013-01-28 0.262 seconds wiki:PuffinServer
- LoadTimes#a2011-07-13 3.417 seconds wiki:NewLiveServer without varnish
- LoadTimes#a2011-07-05 5.131 seconds wiki:NewLiveServer without varnish
2013-01-31 ¶
A script was written to test the nearby post code search, see ticket:466#comment:55
2013-01-28 ¶
Comparing the existing live server, wiki:NewLiveServer with the new wiki:PuffinServer.
apache bench ¶
ab -v 4 -n 200 -c 10 -H "Accept-Encoding: gzip" http://www.transitionnetwork.org/ Server Hostname: www.transitionnetwork.org Server Port: 80 Document Path: / Document Length: 10272 bytes Concurrency Level: 10 Time taken for tests: 0.253 seconds Complete requests: 200 Failed requests: 0 Write errors: 0 Total transferred: 2150344 bytes HTML transferred: 2058286 bytes Requests per second: 790.39 [#/sec] (mean) Time per request: 12.652 [ms] (mean) Time per request: 1.265 [ms] (mean, across all concurrent requests) Transfer rate: 8298.90 [Kbytes/sec] received Connection Times (ms) min mean[+/-sd] median max Connect: 1 3 1.0 3 5 Processing: 4 9 9.3 6 48 Waiting: 1 5 7.9 3 44 Total: 4 12 9.3 9 52 Percentage of the requests served within a certain time (ms) 50% 9 66% 10 75% 10 80% 11 90% 15 95% 38 98% 46 99% 47 100% 52 (longest request)
ab -v 4 -n 200 -c 10 -H "Accept-Encoding: gzip" http://newlive.puffin.webarch.net/ Server Hostname: newlive.puffin.webarch.net Server Port: 80 Document Path: / Document Length: 9248 bytes Concurrency Level: 10 Time taken for tests: 0.262 seconds Complete requests: 200 Failed requests: 0 Write errors: 0 Total transferred: 1973433 bytes HTML transferred: 1849600 bytes Requests per second: 762.21 [#/sec] (mean) Time per request: 13.120 [ms] (mean) Time per request: 1.312 [ms] (mean, across all concurrent requests) Transfer rate: 7344.61 [Kbytes/sec] received Connection Times (ms) min mean[+/-sd] median max Connect: 0 1 0.5 1 3 Processing: 4 12 13.2 8 144 Waiting: 2 10 13.3 6 143 Total: 5 13 13.1 9 145 Percentage of the requests served within a certain time (ms) 50% 9 66% 12 75% 15 80% 16 90% 24 95% 33 98% 40 99% 86 100% 145 (longest request)
Server Hostname: tn.i-jk.co.uk Server Port: 80 Document Path: / Document Length: 10881 bytes Concurrency Level: 10 Time taken for tests: 0.569 seconds Complete requests: 200 Failed requests: 0 Write errors: 0 Total transferred: 2319227 bytes HTML transferred: 2196972 bytes Requests per second: 351.57 [#/sec] (mean) Time per request: 28.444 [ms] (mean) Time per request: 2.844 [ms] (mean, across all concurrent requests) Transfer rate: 3981.31 [Kbytes/sec] received Connection Times (ms) min mean[+/-sd] median max Connect: 7 8 0.3 8 9 Processing: 18 20 3.1 19 50 Waiting: 10 11 3.2 10 42 Total: 26 28 3.2 27 58 Percentage of the requests served within a certain time (ms) 50% 27 66% 27 75% 27 80% 28 90% 28 95% 32 98% 40 99% 44 100% 58 (longest request)
2011-07-13 ¶
The varnish settings for the dev server and the live server are exactly the same. However the dev server is serving pages via varnish:
lynx -head -dump http://dev.transitionnetwork.org/ X-Varnish-Cache: HIT
And the live server is not:
lynx -head -dump http://www.transitionnetwork.org/ X-Drupal-Cache: HIT X-Varnish-Cache: MISS
Note the X-Varnish-Cache: HIT header from the dev server and the X-Drupal-Cache: HIT from the live server.
live server ¶
apache bench ¶
ab -v 4 -n 200 -c 10 -H "Accept-Encoding: gzip" http://www.transitionnetwork.org/ Time taken for tests: 3.417 seconds Requests per second: 58.53 [#/sec] (mean) Time per request: 170.863 [ms] (mean) Percentage of the requests served within a certain time (ms) 50% 135 66% 179 75% 214 80% 247 90% 325 95% 407 98% 638 99% 705 100% 795 (longest request)
curl ¶
curl -o /dev/null https://www.transitionnetwork.org/ % Total % Received % Xferd Average Speed Time Time Time Current Dload Upload Total Spent Left Speed 100 30668 0 30668 0 0 449k 0 --:--:-- --:--:-- --:--:-- 14.6M
2011-07-08 ¶
dev server ¶
HTTPS tests only.
pingdom ¶
Times out after loading just a few objects.
curl ¶
Varied between 1 and 7 seconds, for example:
curl -o /dev/null https://dev.transitionnetwork.org/ Dload Upload Total Spent Left Speed 100 30808 0 30808 0 0 16579 0 --:--:-- 0:00:01 --:--:-- 38413
2011-07-07 ¶
The following results were generated with https redirecting to http so they are invalid for https.
Dev Server ¶
Running Varnish on port 80 and apache on 443.
apache bench ¶
On port 80, this is with the first hit being passed to apache:
ab -v 4 -n 200 -c 10 -H "Accept-Encoding: gzip" http://dev.transitionnetwork.org/ Time taken for tests: 4.302 seconds Percentage of the requests served within a certain time (ms) 50% 7 66% 8 75% 9 80% 55 90% 753 95% 2988 98% 2991 99% 2991 100% 2993 (longest request)
This is for subsequent requests which don't hit apache:
Time taken for tests: 0.183 seconds Percentage of the requests served within a certain time (ms) 50% 7 66% 7 75% 8 80% 8 90% 9 95% 19 98% 40 99% 41 100% 41 (longest request)
pingdom ¶
- http://tools.pingdom.com/?url=http://dev.transitionnetwork.org/
- Total loading time: 2 seconds
Wow, compare this with the last test!
- http://tools.pingdom.com/?url=https://dev.transitionnetwork.org/
- Total loading time: 3.2 seconds
Load Impact ¶
HTTP: http://loadimpact.com/result/dev.transitionnetwork.org/-d25171ed06575a89080ba08b0ab371bc
Clients 10 20 30 40 50 Delay (ms) 449 495 443 433 465
It won't run the HTTPS test today without paying them.
curl ¶
For port 80 we consistently get around 30 mili seconds via Varnish:
curl -o /dev/null http://dev.transitionnetwork.org/ % Total % Received % Xferd Average Speed Time Time Time Current Dload Upload Total Spent Left Speed 100 30856 100 30856 0 0 2327k 0 --:--:-- --:--:-- --:--:-- 28.4M
On 3 different machines this ism't working, I don't understand why:
curl -o /dev/null https://dev.transitionnetwork.org/ % Total % Received % Xferd Average Speed Time Time Time Current Dload Upload Total Spent Left Speed 0 0 0 0 0 0 0 0 --:--:-- 0:00:01 --:--:-- 0
2011-07-05 ¶
Summary for the live server:
- The front page, HTML only of the live site, not running varnish takes around 0.1 seconds to load
- The front page of the live site, plus css / js / images etc takes over 30 seconds via pingdom
Issues for the live server:
- ETags and one CSS expression
Summary for the dev server:
- Very fast on port 80 via Varnish, less than two seconds for the page and all objects
- Very slow for port 443, 7 seconds just for the HTML
Issues for the dev server:
- Speed up port 443 accesses!
- Etag and gzipping of js files
Detailed info follows:
Live Server ¶
This is before Varnish has been deployed and also tests have only be done using http as https requests get a 302 redirect back to http.
apache bench ¶
Requests were done from another machine in the same rack, 200 requests for the front page, 10 at a time, using http, this was done several times and the results below are for an average result, some were faster and some were slower, the first request took about 4 seconds and almost all the rest were less that 0.1 second:
ab -v 4 -n 200 -c 10 -H "Accept-Encoding: gzip" http://www.transitionnetwork.org/ LOG: Response code = 200 LOG: header received: HTTP/1.1 200 OK Date: Tue, 05 Jul 2011 12:02:58 GMT Server: Apache X-Drupal-Cache: HIT Etag: "1309867375-0" Cache-Control: public, max-age=0 Last-Modified: Tue, 05 Jul 2011 12:02:55 +0000 Expires: Sun, 11 Mar 1984 12:00:00 GMT Vary: Cookie,Accept-Encoding Content-Encoding: gzip Content-Length: 7727 Connection: close Content-Type: text/html; charset=utf-8 Time taken for tests: 5.131 seconds Complete requests: 200 Percentage of the requests served within a certain time (ms) 50% 57 66% 66 75% 74 80% 77 90% 100 95% 4014 98% 4019 99% 4039 100% 4050 (longest request)
YSlow ¶
- The page has a total of 29 HTTP requests and a total weight of 421.8K bytes with empty cache
- This page has 3 external stylesheets. Try combining them into one.
- This page has 17 external background images. Try combining them with CSS sprites.
- There are a total of 1 CSS expression:
- http://www.transitionnetwork.org/sites/default/files/css/css_9bf5bdd80b33ef2e38c9b89845c474c9.css
- CSS expressions (supported in IE beginning with Version 5) are a powerful, and dangerous, way to dynamically set CSS properties. These expressions are evaluated frequently: when the page is rendered and resized, when the page is scrolled, and even when the user moves the mouse over the page. These frequent evaluations degrade the user experience.
- There are 27 components with misconfigured ETags (all css js and images)
pingdom ¶
The test here will run for 30 secs max and it generally takes longer than that to load the front page, in part because (as far as I can see) pingdom loads all images referenced in the CSS even if the pages doesn't use them. Some stats:
- Total objects: 76 (677.5 KB)
- (X)HTML: 1 (32.8KB)
- CSS: 3 (92.7KB)
- Scripts: 1 (150.7KB)
- Images: 71 (401.2KB)
Dev Server ¶
Running Varnish on port 80 and apache on 443.
apache bench ¶
On port 80, this is with the first hit being passed to apache:
ab -v 4 -n 200 -c 10 -H "Accept-Encoding: gzip" http://dev.transitionnetwork.org/ LOG: Response code = 200 LOG: header received: HTTP/1.1 200 OK Server: Apache Cache-Control: public, max-age=3600 Last-Modified: Tue, 05 Jul 2011 12:51:05 +0000 Expires: Sun, 11 Mar 1984 12:00:00 GMT Vary: Cookie,Accept-Encoding ETag: "1309870265" Content-Encoding: gzip Content-Type: text/html; charset=utf-8 Content-Length: 7353 Date: Tue, 05 Jul 2011 12:51:07 GMT X-Varnish: 1553439536 1553439337 Age: 0 Via: 1.1 varnish Connection: close X-Varnish-Cache: HIT Time taken for tests: 1.616 seconds Complete requests: 200 Percentage of the requests served within a certain time (ms) 50% 3 66% 3 75% 3 80% 3 90% 4 95% 4 98% 5 99% 1412 100% 1412 (longest request)
This is for subsequent requests which don't hit apache:
Time taken for tests: 0.149 seconds Complete requests: 200 Percentage of the requests served within a certain time (ms) 50% 7 66% 7 75% 8 80% 8 90% 9 95% 9 98% 10 99% 11 100% 12 (longest request)
YSlow ¶
- Make fewer HTTP requests
- This page has 3 external stylesheets. Try combining them into one.
- This page has 14 external background images. Try combining them with CSS sprites.
- There are 2 plain text components that should be sent compressed
- There is 1 component with misconfigured ETags
pingdom ¶
Load time between 1 and 1.5 seconds *total*!
- Total objects: 72 (809.7 KB)
- (X)HTML: 1 (31.4KB)
- CSS: 3 (95.8KB)
- Scripts: 1 (113.2KB)
- Images: 61 (364.7KB)
- Other: 6 (204.7KB)
However for HTTPS it times out before loading many objects:
curl ¶
For port 80 we consistently get around 30 mili seconds via Varnish:
curl -o /dev/null http://dev.transitionnetwork.org/ % Total % Received % Xferd Average Speed Time Time Time Current Dload Upload Total Spent Left Speed 100 32177 100 32177 0 0 2714k 0 --:--:-- --:--:-- --:--:-- 29.7M
Unlike ab we can use curl for port 443, just loading the front page HTML file takes around 7 seconds:
curl -o /dev/null https://dev.transitionnetwork.org/ % Total % Received % Xferd Average Speed Time Time Time Current Dload Upload Total Spent Left Speed 100 32076 0 32076 0 0 4545 0 --:--:-- 0:00:07 --:--:-- 8172