What does SiteGround do to speed up my website?
Speed is essential when it comes to maintaining a website. Not only does it improve the experience of the site's visitors, but it also helps with search engine standings.SiteGround's servers are built with speed in mind, and hardware is handpicked by our head system administrators. We employ all the industry latest hardware and software means to boost a website's performance. These include:
Using SSD drives for our shared and Cloud hosting platforms.
The latest PHP releases with build in opcode cache.
Nginx used in conjunction with our web server software to cache and speed up the delivery of static content.
We partner with Cloudflare to provide a free CDN.
Our unique SuperCacher technology, designed to cache dynamic pages and compatible with popular CMS applications like WordPress and Joomla!. The SuperCacher also includes Memcached as means to optimize the performance of your website.
What are core.xxxxx files
In the document root of your website you may discover large files named core.xxxxx where xxxxx is a random number. These files are called core dumps and could be useful in investigating problems with your website application.
There are numerous reasons for the generation of these files but the most common ones are:
There are numerous reasons for the generation of these files but the most common ones are:
- A script a part of your website tried to access memory not assigned to it
- A script ended prematurely due to critical errors in its code
- Improper use of the PHP libraries
How to Leverage Browser Caching
The most important cache mechanism for page speed is browser caching. Most of the static files that are used on web pages can be saved on the computer of your visitor for future access.
You can add the following rules to the .htaccess file of your application, so you can reduce the load times of your website:
You can add the following rules to the .htaccess file of your application, so you can reduce the load times of your website:
<IfModule mod_expires.c>
ExpiresActive on
ExpiresByType text/css "access plus 14 days"
ExpiresByType text/xml "access plus 0 seconds"
ExpiresByType text/javascript "access plus 14 days"
ExpiresByType application/x-javascript "access plus 14 days"
ExpiresByType image/ico "access plus 14 days"
ExpiresByType image/jpg "access plus 14 days"
ExpiresByType image/jpeg "access plus 14 days"
ExpiresByType image/gif "access plus 14 days"
ExpiresByType image/png "access plus 14 days"
ExpiresByType image/svg+xml "access plus 1 month"
ExpiresByType text/html "access plus 14 days"
ExpiresByType video/ogg "access plus 1 month"
ExpiresByType audio/ogg "access plus 1 month"
ExpiresByType video/mp4 "access plus 1 month"
ExpiresByType video/webm "access plus 1 month"
ExpiresByType application/x-font-woff "access plus 1 month"
ExpiresByType application/vnd.ms-fontobject "access plus 1 month"
ExpiresByType application/xml "access plus 0 seconds"
ExpiresByType application/json "access plus 0 seconds"
ExpiresByType application/rss+xml "access plus 1 hour"
ExpiresByType application/atom+xml "access plus 1 hour"
</IfModule>
Leverage Browser Caching for Images, CSS and JS
To leverage your browser's caching generally means that you can specify how long web browsers should keep images, CSS and JS stored locally. That way the user's browser will download less data while navigating through your pages, which will improve the loading speed of your website.
To enable it, add those lines to your .htaccess file:
To enable it, add those lines to your .htaccess file:
## EXPIRES CACHING ##
<IfModule mod_expires.c>
ExpiresActive On
ExpiresByType image/jpg "access 1 year"
ExpiresByType image/jpeg "access 1 year"
ExpiresByType image/gif "access 1 year"
ExpiresByType image/png "access 1 year"
ExpiresByType text/css "access 1 month"
ExpiresByType application/pdf "access 1 month"
ExpiresByType application/javascript "access 1 month"
ExpiresByType application/x-javascript "access 1 month"
ExpiresByType application/x-shockwave-flash "access 1 month"
ExpiresByType image/x-icon "access 1 year"
ExpiresDefault "access 2 days"
</IfModule>
## EXPIRES CACHING ##
The .htaccess file can be modified via FTP, or the File Manager in cPanel.
How to enable gZIP compression for your pages?
GZIP compression improves the performance of your website and decreases its loading time. When a visitor makes a request for your website, the server compresses the requested page, significantly reducing its size, and transfers it to the customer's computer. On the visitor's end the file is being decompressed and visualized. The time needed for file compression is much less than the time to transfer a big file over the Internet, thus compression enhances the performance of a website.
To enable GZIP compression for your text, html, JavaScript, CSS and XML you can add these lines inside the your website's .htaccess file:
<IfModule mod_deflate.c>
AddOutputFilterByType DEFLATE text/plain
AddOutputFilterByType DEFLATE text/html
AddOutputFilterByType DEFLATE text/xml
AddOutputFilterByType DEFLATE text/css
AddOutputFilterByType DEFLATE application/xml
AddOutputFilterByType DEFLATE application/xhtml+xml
AddOutputFilterByType DEFLATE application/rss+xml
AddOutputFilterByType DEFLATE application/javascript
AddOutputFilterByType DEFLATE application/x-javascript
</IfModule>
Note that compression is disabled by default for SiteGround Staging instances. This means that the above .htaccess rules will have no effect and the compression will function as expected after the website is pushed live.
Note also that compression on server side will not work for remote resources that are loaded on the web page(such as remote CSS or Java Script inclusion for example). This is important as third party test tools(like GTMetrix) might not properly detect GZip compression as enabled.
Some applications also have internal support to compress their pages. For example, in Joomla you can turn on the Gzip compression from Global Configuration -> Server -> Gzip Page Compression set to Yes.
Common reasons for a site to load slowly
The time for loading a web site depends mostly on:
1. The number / size of external resources included in the site.
2. Properly resized images to their visible size.
3. The database queries executed while the site loads.
Examples:
- You have included RSS feeds on your page(s). In order to display the RSS feeds, your web site needs to retrieve them from remote servers. As each connection to a remote server takes some time, the more RSS feeds a page has, the slower it will load.
- You have a picture with dimensions of 1024x768, which is 1MB, and a small thumbnail that shows a preview of this picture. It is a common mistake to use the same un-resized large image as the thumbnail. The proper action would be to resize the large picture to a smaller image that matches exactly the size of the thumbnail in pixels.
- You use database-driven application for your website and have added many modules for additional functionality. Some of them are not even very popular and you are not sure how well optimized they are. Others you do not even use actively any more, but you have not removed them after testing them initially. The additional modules will generate database queries at each visit to your website. If these queries become too many or some of them need too much time to be executed, your website will load slowly.
In order to speed up your site we recommend:
- Decreasing the number of external resources on your site.
- Optimizing the size of the images used on your website.
- Decrease the number of additionally installed modules / components for your application.
- Decrease any additional / extra features in your site like searches, statistics and others.
- Check the internet for specific optimization instructions for the application you are using.
1 comments:
panu
EmoticonEmoticon