I want to make my angular-cli application faster!
Right, so I have spent a number of days updating my NG2 application to work with angular-cli. At first it was quite a frustrating experience, however, I am really seeing the light and enjoying the development process. Clearly, hard work and thought have been put into the framework.
But my application is slow:
According to Pingdom, my application is faster than 21% of all other sites on the internet. To be fair, this is an out of the box ng build and I am sure I can speed this up significantly.
My final question is: How to radically reduce the size of an angular website?
As it stands, the application: fairplay.poker, takes 7 seconds to load (if you live in New York) so I am sure most people will have moved on before it has had a chance to load.
Clearly, I need to embark on a journey to radically increase the speed of the application but I need your help! (because I don't know what I am doing :)
What is standard practice and where do I even start sorting this out?
PROGRESS:
As suggestions are made I will update them here.
1. @cyrix Suggested production ready build: ng build -prod
The Zip file dropped by over a a meg and the new stats from Pingdom are quite an improvement from the original stats:
2. Suggested image size reduction.
Some of the images were a bit bigger than they should have been so these have been reduced in size. Not a major improvement, however, the stats have elevated the site into the top 73% of sites with a slightly faster load time.
3. @yurzui suggested gzip compression, so I have enabled this. Apparently, it is working and total file sizes have been reduced by over half (609 bytes) however, this is not showing on Pingdom. I note that the grade has somewhat improved, though.
I used this site to check compression and this site showed me how to do it since Cpanel seemed not to work when enabled from the administration. This site also appears to be a good gzip compression resource.
4 @Yuruzi suggested implementing a browser cache. So I did it!
What's really interesting is the performance grade improvement, that rocks! Load time a little faster and the site is now in the top 74%. As suggested by Yuruzi I used this post for guidance.
5 Thanks to @wafflej0ck on the #angularjs channel. Appears I needed to improve GZip which I have done by changing to "AddOutputFilterByType DEFLATE *" type of compression as outlined here.
This appears to have supercharged the site:
6 It was suggested to use AOT so I have taken a page out of this post.
I went through most of the documentation, however, I was getting a world of errors and decided to leave this for a later date, hopefully when AOT is a little more stable.
I read on GitHub that the Angular-Cli comes with AOT pre-intalled and the above article is not relevant. I am not sure how true this is however I am running the following command when compiling the code: ng build --prod --aot
7. Tweaked the mod_expires.c in the htaccess file.
Performance grade has improved significantly to 98%, Load time is now under a second and the site is faster than 91% of websites tested.
The file currently looks like this:
ExpiresActive On ExpiresDefault "access plus 2 days" ExpiresByType image/x-icon "access plus 1 year" ExpiresByType image/jpeg "access plus 1 year" ExpiresByType image/jpg "access plus 1 year" ExpiresByType image/png "access plus 1 year" ExpiresByType image/gif "access plus 1 year" ExpiresByType application/x-shockwave-flash "access plus 1 month" ExpiresByType text/css "access plus 1 month" ExpiresByType text/javascript "access plus 1 month" ExpiresByType application/pdf "access plus 1 month" ExpiresByType application/javascript "access plus 1 week" ExpiresByType application/x-javascript "access plus 1 week" ExpiresByType text/javascript "access plus 1 week" ExpiresByType text/html "access plus 600 seconds" ExpiresByType application/xhtml+xml "access plus 600 seconds"
At this point in time I can't help but think that I am now dealing with diminishing returns.
- Removed Unwanted fonts and unused images that were inclided in the css.
Load time has dropped and the site performance is now at 100%
- Slow DNS and SSL
I noticed that a good deal of load time was due to DNS and SSL. To fix this I signed up with a free CloudFlare account since they have nodes pretty much everywhere, this was bound to speed a few things up...
And indeed it has. Sadly, the New York host from PingDom has been removed, but the stats from Dallas look quite promising dropping load time to well under a second!
OTHER GOOD ARTICLES
This guy has a good article on optimizing angular sites as well