Jedním z nejdůležitějších aspektů vašeho webu je jeho rychlost načítání; uživatelé chtějí okamžitě získat obraz bez jakýchkoliv brzd, a pokud jim to nejste schopni poskytnout, nebudou dlouho váhat a hledat informace jinde. V tomto článku probereme 5 způsobů, které vám umožní zrychlit načítání vašeho webu.
1. Použijte YSlow ke sledování doby načítání stránky
Znáte-li dobu, kterou trvá načítání stránek, můžete identifikovat problémové oblasti. Také vám to dá další podnět k tomu, abyste se dostali do funkce a pokusili se situaci napravit.
Než začneme, musíte nainstalovat YSlow, pokud jste to ještě neudělali. YSlow je rozšíření pro Mozilla Firefox kterou najdete na této stránce:
Nyní otevřeme nějaké stránky. Řekněme Šest revizí, abychom měli přibližně stejná data (stačí otevřít tyto stránky v nové záložce vašeho prohlížeče).
V pravé dolní části prohlížeče máte speciální panel s ikonou (viz obrázek 1). O něco dále od tohoto panelu, po načtení stránky, vedle „YSlow“ uvidíte číslo. Toto číslo je doba v sekundách, po kterou se tato stránka načte ve vašem prohlížeči. Chceme, aby toto číslo bylo co nejmenší.
Nejběžnější „brzdy“ jsou následující předměty nebo operace:
- Příliš mnoho požadavků HTTP
- Nekomprimované soubory JavaScript
- Žádná doba vypršení platnosti záhlaví pro grafické soubory
Za pár minut se na to podíváme blíže.
Abyste se s tímto systémem seznámili, projděte si několik stránek a podívejte se na jejich doby načítání. Můžete otestovat Google, Facebook a několik svých oblíbených blogů/webů, které nejčastěji navštěvujete. Všimněte si, že soubory a obrázky JavaScriptu jsou ty, které nejvíce ovlivňují rychlost.
YSlow využíváme naplno
Kromě YSlow výpočtu doby načítání stránky, dané rozšíření také vám poskytuje rozsáhlé informace o tom, co musíte opravit, abyste optimalizovali načítání webu, abyste mohli zalepit díry.
Pro takové informace klikněte na kartu Výkon. Po procházení webu vám YSlow poskytne celkové skóre, které bude charakterizovat výkon vaší stránky.
Přístup k informacím lze urychlit pomocí sítě CDN (content delivery network). CDN se nejlépe používá pro velké weby. Používají se k distribuci informací na více serverech různé části mír. Tímto způsobem budou informace staženy z příslušného serveru (který je uživateli nejblíže), aby neprocházely osobními routery. YSlow také sleduje požadavky CDN.
Ale lidé obecně nepoužívají CDN (což je docela drahé).
Klasifikace typů chyb
Nyní si projdeme každou položku, která je ve výše zmíněném rozšíření. Níže naleznete souhrn toho, jak jsou vaše stránky posuzovány a jak se vypořádat s problémy, abyste dosáhli maximálního výkonu.
Vytvářejte co nejméně požadavků HTTP: Požadavek HTTP nastane, když prohlížeč odešle požadavek na server. Totéž se může stát při připojování skriptů, CSS souborů, obrázků, stejně jako u asynchronních požadavků, jak ze strany klienta, tak ze strany serveru (Ajax a další podobné technologie). Pokud však jde o výkon systému, stojí za zvážení, jak moc podobné žádosti se stane na vaší stránce. Jedním z řešení je použití ukládání do mezipaměti, které pomůže klientským počítačům načíst skripty, CSS a obrázky rychleji.
Přidání záhlaví s vypršením platnosti: 80 % načítání stránky je zaměřeno na stahování skriptů, fotografií a souborů CSS. Ve většině případů se tyto věci na uživatelských počítačích nemění. Přidáním kódu do souboru .htaccess můžete duplicitní soubory uložit do mezipaměti na místním počítači uživatele (jak to udělat, si povíme později).
Komponenty Gzip: Použijte Gzip nebo komprimujte soubory JS, obrázky, HTML dokumenty, CSS soubory atd. umožňuje uživatelům stahovat informace ve zmenšené velikosti, což výrazně zvyšuje rychlost načítání stránky. Kromě toho se tím ušetří místo na serveru, ale rozbalení dat může zpomalit odezvu a přímo závisí na prohlížeči uživatele.
Umístěte CSS na začátek stránky: Pokud umístíte připojení CSS na začátek stránky, znamená to, že budou načteny jako první a obrázky a skripty později.
Umístěte svůj JS na konec stránky: Nyní, když se vaše soubory CSS načítají nahoře, je čas umístit skripty JS přímo před uzavírací značku. To umožní vaší stránce vykreslit a poté zahrnout potřebné skripty.
Vyhněte se CSS výrazům: Osobně jsem nikdy nepoužíval CSS výrazy (nazývané také dynamické vlastnosti). Tyto výrazy jsou nativní koncepty programování IE (jako jsou podmíněné výrazy) v CSS. Technologie, která se používá v IE8 a ve všech ostatních verzích, již nebude podporována, takže v každém případě budete muset s tímto psaním výrazů CSS navázat. PHP je pro takové účely vhodnější, například pro načítání různých stylů CSS v závislosti na nějaké podmínce, jako je náhodné číslo, denní doba nebo prohlížeč uživatele.
Napište JS a CSS do samostatných souborů: pokud vložíte své skripty do JS a css styly v samostatných souborech je může prohlížeč snadno uložit do mezipaměti, a tím umožnit rychlejší načítání vaší stránky v budoucnu.
Zkraťte dobu vyhledávání DNS: když uživatel zadá název vašeho webu do lišty prohlížeče, okamžitě začne DNS vyhledávání IP adresy, kde se váš web nachází. Čím více váš web obsahuje externí zdroje, tím déle bude vyhledávání DNS trvat. Zpravidla jedno takové vyhledávání trvá 60-100 milisekund.
Minifikujte JS: Kromě komprimace pomocí gzip vám minifikace souborů JavaScriptu umožní odlehčit vaše skripty tím, že se zbavíte zbytečných mezer, tabulátorů a dalších speciálních znaků, které zvyšují velikost souborů. Je to zřejmé – čím menší soubory, tím rychlejší načítání stránek. K minifikaci souborů JavaScript můžete použít nástroj JSMIN.
Vyhněte se přesměrování: Nezáleží na tom, kde provedete přesměrování, v JS, HTML nebo PHP. V každém případě váš prohlížeč obdrží prázdnou hlavičku stránky, jejíž načtení bude chvíli trvat. Zkuste tedy přesměrování nepoužívat tam, kde se tomu lze vyhnout.
Vyhněte se duplicitnímu načítání skriptů: Pokud váš prohlížeč načte skript více než jednou, výrazně to ovlivní načítání stránky. Matematika zde není obtížná. Čím více stažení stejných souborů, tím více delší načítání stránky. Zkontrolujte své skripty a ujistěte se, že nevoláte jQuery dvakrát nebo třikrát. Totéž platí pro JS skripty.
No... myslím, že to stačí. Nyní přejdeme na další kartu YSlow, než se podíváme na některé další techniky, které zvýší rychlost načítání vaší stránky.
Karta Komponenty vám umožní určit, kolik úsilí musíte vynaložit na zlepšení rychlosti stahování. Zde najdete informace o tom, kolik jednotlivé soubory váží a jak dlouho trvá jejich stažení. Budete také moci vidět, které soubory jsou gzipovány, zjistit dobu odezvy a zda jsou soubory uloženy v mezipaměti na počítači uživatele a kdy samotná mezipaměť končí. Tyto informace se vám mohou hodit při posuzování problémů vašeho webu, budete vědět, co vám je a co je potřeba optimalizovat.
A konečně přejděme k poslední záložka Karta Statistiky. Zde najdete informace o všech HTTP požadavcích, a to jak pro běžné soubory, tak pro ty uložené v mezipaměti. Hodnota Empty cache označuje, že tyto soubory je třeba načíst, aby se stránka vykreslila. Primed Cache jsou zase soubory, které již byly uloženy do mezipaměti prohlížečem uživatele. To znamená, že je není třeba stahovat.
2. Použijte CSS Sprites ke snížení požadavků HTTP
CSS skřítci jsou pravděpodobně to nejdůležitější, co lidstvo vymyslelo od doby, kdy Tesla vynalezl elektřinu... Vlastně jsem to řekl... jejda, myslel jsem Edisona.
No, možná ne úplně nejlepší, ale stejně.
Sprite CSS mohou výrazně zlepšit rychlost načítání stránky tím, že sníží počet požadavků HTTP, které se odehrávají při stahování obrázků.
Můžete najít mnoho výukových programů, které hovoří o tom, jak se skřítci CSS snadno orientují – obecně o jejich použití v uživatelském rozhraní.
Nyní se pojďme rychle podívat na to, jak YouTube používá sprity CSS. Takto vypadá sprite, který používají:
YouTube používá tento soubor poměrně originálním způsobem. Načtou to jako pozadí do třídy sprite. Když je nutné vybrat prvek, výchozí pozice se vybere, když Nápověda CSS vlastnosti background-position a poté použití výšky a šířky.
Zkusme něco podobného. Pojďme experimentovat na stejném obrázku z YouTube.
V níže uvedeném příkladu zobrazujeme na obrazovce logo YouTube. Pomocí stejné třídy sprite a stejného obrázku můžeme vytvořit obrázek, který se změní při přejetí myší.
Pomocí tohoto obrázku tedy můžeme zredukovat všechna připojení na jeden HTTP požadavek. No, jaký to má efekt?
Další výhoda CSS skřítci spočívá v tom, že při použití pseudotřídy :hover obrázek na několik okamžiků nezmizí (které trvá načtení nového obrázku), jak se to stane bez Použití CSS skřítci.
3. Načtěte CSS soubory na začátku, JavaScript na konci
U některých webů může snížení počtu požadavků HTTP narušit funkčnost. Dalším způsobem, jak urychlit načítání stránky, je umístit všechna připojení souborů JavaScript na konec dokumentu.
Za zmínku také stojí:
- Načtěte soubory CSS v sekci těsně před začátkem značky body.
- Zahrňte JavaScript těsně před koncovou značku těla.
Pokud se budete řídit našimi radami, umožníte svým uživatelům obdivovat vaše stránky, zatímco se váš JavaScript načítá na pozadí.
Poznámka: Pokud se nechcete stěhovat JavaScript tagy, protože se bojíte, že funkčnost spadne, pak doporučuji použít vlastnost odložit. Aplikujte to takto:
4. Используйте поддомены для параллельного скачивания
Параллельная загрузка означает увеличение параллельных загрузок одних и тех же файлов. Пройдясь по множеству сайтов, вы можете заметить, что на многих из них запросы посылаются на static.domain.com и c1.domain.com. Это можно увидеть в нижней панели браузера.
Это отличный способ увеличить производительность сайта. При использовании поддоменов, по сути, информация будет находиться на одном и том же сервере, однако для браузера они будут разными.
Настройка процесса:
- Создайте 3 поддомена на вашем сервере
- Расположите ваши изображения в папках на разных поддоменах
- Замените пути в ваших файлах
5. Добавление заголовков Expires
Некоторые сайты остаются нагруженными даже после применения всех методов, описанных выше. Но есть ещё пару методов.
Пользователь может зайти на ваш сайт и совершить все необходимые HTTP запросы для отображения страницы, изображений, скриптов и т.д.
Когда вы используете заголовки Expires, вы можете закэшировать все эти элементы на пользовательской машине, тем самым не только увеличив скорость загрузки страницы, а ещё и сократив трафик. Заголовки Expires могут быть применены ко всем вашим скриптам, CSS и изображениям.
Данного эффекта можно добиться посредством нескольких строк, которые вам нужно добавить в файл.htaccess, который находится в корневом каталоге вашего сайта.
Следующий пример.htaccess файла устанавливает заголовки expires на какое-то число в 2010 году для таких типов файлов как.ico, .pfd, .flv (файлы Flash), .jpg, .png, etc.
Будьте бдительны: если вы произведёте какое-либо изменение в данных файлах (в случае, если срок ещё не прошёл), то вам необходимо переименовать их (или добавить в название версию), иначе в кэше они не обновятся.
К примеру, если у вас есть файл JavaScript, в котором вы что-то изменили, просто добавьте в название номер версии (что-то типа javascriptfile-1.0.js, javascriptfile-1.1.js и т.д.)
Вывод
Сегодня мы прошлись по многим способам. Надеюсь, вы отметили для себя несколько методов, которые будете активно применять в ваших проектах! Удачи!
Иногда при работе с Почтой перестают работать кнопки, не прикрепляется вложение или браузер сообщает об ошибке.
Выберите проблему:
Иероглифы или непонятные символы появляются из-за неправильной кодировки страницы. Кодировку могут изменить вирусы или вредоносные программы.
CureIt! от Dr.Web и Virus Removal Tool
Если страница не загружается или загружается очень долго, вы видите сообщения:
«Произошла ошибка» .
«Попробуйте обновить вкладку браузера или повторите попытку через несколько минут» .
«Подождите, пожалуйста...» .
«Попробуйте обновить страницу или воспользуйтесь лёгкой версией Почты» .
Почему страница не загружается и как это исправить:
Расширения блокируют Яндекс.Почту Вы используете устаревший браузер
Устаревший браузер может не поддерживать технологии, которые используются для быстрой и удобной загрузки страниц. Установите последнюю версию вашего браузера .
Закройте в браузере все вкладки, кроме Почты. Отключите приложения, использующие\\n интернет, и перезагрузите страницу.
\\n \\n \\n \\n Возникла проблема с сетевым подключением \\n \\n
Чтобы это проверить, зайдите в Почту через мобильный интернет. Если ошибки не\\n возникают, обратитесь в службу поддержки вашего провайдера. Если вы пользуетесь\\n рабочей почтой, сообщите о проблеме своему системному администратору.
\\n \\n \\n \\n В Internet Explorer 8 и выше выбран не тот режим совместимости \\n \\n
Если в браузере Internet Explorer 8 и выше вы используете режим совместимости с\\n более старой версией, это может приводить к ошибкам.
Режим\\n документов
\\n \\n \\n \\n \\n\\n "}]}}\">
Снизилась скорость интернета
Закройте в браузере все вкладки, кроме Почты. Отключите приложения, использующие интернет, и перезагрузите страницу.
Возникла проблема с сетевым подключением
Чтобы это проверить, зайдите в Почту через мобильный интернет. Если ошибки не возникают, обратитесь в службу поддержки вашего провайдера. Если вы пользуетесь рабочей почтой, сообщите о проблеме своему системному администратору.
В Internet Explorer 8 и выше выбран не тот режим совместимости
Если в браузере Internet Explorer 8 и выше вы используете режим совместимости с более старой версией, это может приводить к ошибкам.
Установите параметры Режим браузера и Режим документов в соответствии с версией вашего браузера.
Сообщение об ошибке сертификата безопасности начинается с фразы:
«Ваше подключение не защищено» .
«Сайт угрожает безопасности вашего компьютера» .
«Ошибочный сертификат» .
«Ошибка в сертификате безопасности» .
«Это соединение является недоверенным» .
Почему появляются ошибки сертификата безопасности и как их исправить:
Ошибки ненадежного соединения или некорректного сертификата безопасности могут возникнуть из-за конфликта между настройками браузера и компьютера. Также ошибки может вызвать работа антивируса. Чтобы понять причину ошибки сертификата, найдите ее код в конце сообщения.
Код ошибки | Решение |
---|---|
| / |
| дата и время . Если они настроены неправильно, система ошибочно определяет, что срок сертификата еще не наступил или уже закончился. |
| Убедитесь, что в настройках вашего антивируса отключена проверка HTTPS-соединений. О том, как это сделать в Kaspersky Internet Security и в ESET NOD32 Smart Security, см. под таблицей. Если на вашем компьютере нет антивирусной программы, злоумышленники могли подменить сертификат безопасности при помощи вредоносного кода или атаки MITM . Проверьте ваш компьютер на вирусы с помощью бесплатных антивирусных программ: CureIt! от Dr.Web и Virus Removal Tool от «Лаборатории Касперского». |
Код ошибки | Решение |
---|---|
| Проверьте, что в адресную строку браузера введен правильный адрес - mail.yandex.ua или passport.yandex.ua , а после ua стоит символ / , а не точка или другой символ. |
| Убедитесь, что на компьютере корректно установлены |
При создании клиентоориентированного сайта вам необходимо учесть и продумать множество вещей, начиная от творческих (дизайн, наполнение) и заканчивая техническими (верстка, размещение в сети Интернет). Для клиентов важна каждая мелочь, поэтому важно смотреть не только на внешнюю сторону вашего проекта - то, что увидит пользователь - но и на внутреннюю, а именно, как быстро пользователь это увидит. Исследования показывают, что примерно половина пользователей ожидает, что сайт загрузиться менее чем за две секунды, а 40% пользователей закроют сайт, если на его загрузку уйдет более трех секунд. Поэтому крайне важно, чтобы ваш сайт загружался быстро, иначе вы рискуете потерять значительную часть своих клиентов. Что же вы можете сделать, чтобы уменьшить время загрузки вашего сайта?
1. Сократите код
Чем объемнее код вашего проекта, тем больше он весит, а значит, тем большее время требуется для его загрузки. Поэтому в первую очередь вам нужно убедиться, что код оптимизирован. Особенно это касается первой, посадочной страницы, на которую попадает пользователь - будет лучше отказаться от тяжелых скриптов JavaScript и Ajax либо убрать их в нижнюю часть страницы. Придерживайтесь известного принципа KISS - Keep it short and simple - пусть код будет коротким и простым.
Сервис PageSpeed Insights от Google советует убрать внешний файл JavaScript из верхней части страницы, так как цикл операций, который требуется выполнить для его загрузки, значительно тормозит загрузку страницы. В этом случае рекомендуется либо сделать код JavaScript встроенным, либо загружать этот код после загрузки верхней части страницы.
Если вы хотите узнать, все ли в порядке с JavaScript на странице вашего сайта, воспользуйтесь этим сервисом: https://varvy.com/tools/js/
Этот совет также касается HTML и CSS-кода. Как и в случае с JavaScript, особое внимание уделите внешним файлам - к примеру, внешним таблицам стилей, которые по возможности лучше вставить в HTML.
2. Используйте компрессию сайта
Существует несколько технологий, при помощи которых вы можете сжать данные, благодаря чему можно уменьшить размер текстовых ресурсов, а значит, и время загрузки страниц вашего ресурса. К примеру, воспользуйтесь gzip: эта утилита минимизирует запросы к серверу со стороны браузера. Воспользоваться ею можно в протоколе HTTP.
Проверить, используется ли на вашем сайте gzip для сжатия данных, можно на этом ресурсе: http://www.gidnetwork.com/tools/gzip-test.php
А пройдя по следующей ссылке, вы сможете выяснить, применяется ли в целом какая-либо технология сжатия на вашем сайте: http://www.whatsmyip.org/http-compression-test/
3. Сократите количество переадресаций
Переадресация 301 часто используется для того, чтобы провести перенаправление с одного адреса на другой. Однако это чревато тем, что будут задействованы дополнительные сетевые циклы, из-за которых время загрузки сайта может увеличиваться, особенно если речь идет о мобильных устройствах. Поэтому лучше уменьшить количество переадресаций или вообще отказаться от них.
Проверить свой сайт на наличие переадресаций вы можете при помощи этой программы (есть бесплатная версия): https://www.screamingfrog.co.uk/seo-spider/
4. Уменьшите число плагинов
Данный пункт касается тех, кто пользуется CMS: Wordpress, Joomla или какой-либо другой. Регулярно проверяйте список плагинов, которые вы используете, на предмет ненужных или уже неиспользуемых. Уменьшение количества плагинов положительно скажется на загрузке вашего сайта и его работе в целом. Если вы используете Wordpress в качестве системы управления контентом, то оптимизировать число плагинов вы также можете при помощи специального плагина P3 (Plugin Performance Profiler): https://wordpress.org/plugins/p3-profiler/ Этот плагин покажет вам данные, касающиеся производительности других плагинов, и того, как каждый из них влияет на работу сайта. Это поможет вам определить, от каких плагинов следует отказаться в первую очередь.
5. Оптимизируйте изображения
Размер картинок на сайте напрямую влияет на время загрузки ресурса. Все изображения обязательно нужно оптимизировать: ставить правильный размер, формат и сжимать. Также будет полезно избавиться от так называемого цифрового мусора: различных данных, которые попадают в изображение при его обработке.
6. Пользуйтесь кэшем браузера
Используя кэширование, вы можете значительно выиграть в скорости загрузки вашего сайта: когда пользователь первый раз заходит на ваш сайт, в кэше его браузера сохранятся некоторые JavaScript и CSS-файлы, которые затем будут автоматически показываться при его следующих визитах, а браузеру не придется тратить время на их загрузку. Для кэширования необходимо правильно настроить HTTP-заголовок Expires. Вы можете сделать это, прописав в файле.htaccess, который находится в корневой папке, следующие строки:
В данном случае у всех типов установлен срок в 1 месяц, но вы можете изменить время на то, которое вам нужно: кэш может храниться определенное количество лет (years), месяцев (months), недель (weeks) или дней (days).
Если вы пользуетесь какой-то определенной CMS, то можете установить для этого специальный плагин. В случае с Wordpress подойдет W3 Total Cache: кэширование включается в настройках (выберите Settings у данного плагина в списке всех установленных плагинов, затем General - поставьте галочку у “Toggle all caching types on or off (at once)”).
7. Следите за производительностью сайта
Очень важно постоянно мониторить производительность вашего сайта - даже тогда, когда, как вам кажется, вы оптимизировали все, что было можно. Для этого существуют специальные бесплатные ресурсы, самые известные из которых будут перечислены ниже:
- уже упомянутый выше Page Speed Insights:
https://developers.google.com/speed/pagespeed/insights/?hl=ru
Этот инструмент от Google замеряет скорость загрузки вашего веб-ресурса (от 0 до 100 баллов; чем выше балл, тем лучше). Сервис даст вам рекомендации по улучшению производительности, а также покажет, какие пункты оптимизации вы выполнили. Имейте в виду, что так как в Page Speed Insights вносятся правки и корректировки, то количество баллов, которые получил ваш сайт, также может меняться. - Pingdom Website Speed Test:
http://tools.pingdom.com/fpt/
Хороший англоязычный сервис для проверки скорости загрузки вашего ресурса. Будет особенно полезен тем, кто администрирует международные ресурсы, так как позволяет выбрать место, из которого будет производиться тестирование: США, Австралия или Швеция (результат будет отличаться). Выводит множество разных данных и дает рекомендации. - Loadimpact:
https://loadimpact.com/
Этот сервис позволяет сгенерировать несколько запросов на ваш сайт, путем чего можно выяснить, во-первых, среднюю скорость загрузки вашего сайта, во-вторых, понять, как ваш сайт поведет себя при определенном количестве запросов (выдержит ли он нагрузку). - LoadStorm:
http://loadstorm.com/
При помощи этого сервиса вы можете запустить достаточно серьезное тестирование своего сайта. Бесплатная версия сервиса позволит вам протестировать свой ресурс при помощи 10 пользователей, а вот платная версия дает больше возможностей, в частности вы сможете самостоятельно прописать сценарий, который будут выполнять пользователи (к примеру, нажать на определенную кнопку или перейти в нужный раздел). При этом вы обязаны верифицировать то, что являетесь владельцем сайта.
Заключение
Если вы выполните каждый из предложенных в этой статье пунктов, вы сможете значительно уменьшить время загрузки вашего сайта. Но при этом не забывайте, что оптимизация должна происходит не во вред пользователям: картинки должны оставаться привлекательными, навигация удобной, а информация понятной и доступной.
Делитесь в комментариях своими идеями, как можно ускорить загрузку веб-ресурса.
В Google Chrome, аналогично с иными браузерами ОС Windows, существует проблема, которая связана с тем, что после загрузки страницы на компьютере сохраняются некоторые скачанные файлы.
Со временем они начинают занимать слишком много места на жестком диске.
Производить отчистку куки нужно регулярно, несмотря на то, что все может быть в порядке. Сама процедура не занимает много времени, ведь в Гугл Хроме её осуществить очень просто.
Что это такое
Перед тем, как почистить кэш в Google Chrome на ОС Windows стоит разобрать, что он вообще собой представляют. Сам термин, кеш был взят из английского слова cashe. Оно обозначает тайник или место хранения. Также его часто называют «куки» из-за того, что это текстовые данные сайта, хранящийся на компьютере пользователя. Если отбросить технические детали, можно сказать, что такие своеобразные хранилища информации позволяют обеспечить быстрое открытие и отображение тех сайтов, на которых пользователь ранее уже заходил через хром.
По большому счету, такие хранилища являются прекрасным вариантом, позволяющим экономить ваш интернет-трафик. Так, например, после того, как вы посмотрели какой-либо ролик на определенном сайте, при повторном его просмотре не будет нужды еще раз его полностью загружать из сети. Дело в том, что алгоритмы браузера автоматически создают копию того видео и размещают его в память компьютера, создавая тем самым куки и кэш. Это также обеспечивает более оперативную загрузку.
Однако в этом случае есть и свои негативные стороны. К примеру:
- Если в сайт были внесены изменения, после того, как его посещали с браузера и информация о нем сохранилась в куки, далеко не всего он будет отображаться в новом виде. Причиной является то, что в памяти уже находится образ старой версии вебсайта, который загрузили алгоритмы браузера и он может быть отображен пользователю. Чтобы этого избежать, нужно своевременно почистить хранилища информации;
- Еще одной негативной стороной является то, что такая информация, если её долгое время не чистить, будет занимать очень большое количество места на жестком диске, уменьшая его свободное пространство.
Как проводить очистку
Сама процедура является максимально простой. Прежде всего нужно запустить сам браузер через систему Windows. Теперь необходимо нажать сочетание клавиш Shift + Ctrl + Delete. Это является наиболее быстрым способом открыть куки браузера. Это можно сделать и иным путем. Для этого нужно найти в хроме кнопку входа в меню (она в последних версиях обозначается тремя точками, расположенные в столбик), она называется «Настройка и управление» и нажать.
В появившемся контекстном меню необходимо выбрать пункт «Настройки», после чего откроется вкладка со всеми доступными к изменениям параметрами. Опускаемся в самый низ страницы, где находится кнопка «Показать дополнительные настройки» и нажимаем её. Находим там раздел «личные данные», где будет нужно нажать на кнопку «Очистить историю».
Далее появиться окно, где можно будет почистить кроме необходимых хранилищ файлов, сохраненные данные истории загрузок, какие сайты посещались, а также информацию о паролях. Чтобы выбрать, что именно будет удалено нужно поставить рядом с конкретным пунктом галочку. После этого можно будет просто нажать кнопку «Очистить историю» и подождать, пока процедура завершится.
На этом процедура очистки файловых хранилищ информации браузера гугл хром через Windows заканчивается. Однако, стоит также сказать о том, что находясь в разделе настроек «Личные данные» можно указать периодичность удаления определенного типа сохраняемых данных в гугл хром. Это позволит сделать так, чтобы удалялись не все файлы, а только устаревшие и уже не актуальные. Также, стоит сказать, что куки и кеш имеют значительные отличия:
- Первые являются своеобразными следами, остающимися после посещения сайта в виде информации, которой обмениваются вебсайты и сам хром;
- Вторые представляют собой хранилищем загруженных с разных вебсайтов видео, музыки и фотографий.
Также произвести удаление всех сохраненных файлов можно даже не заходя в хром. Для этого нужно будет открыть в Windows саму папку, где они храниться. Обычно, это можно сделать перейдя по адресу C:\Documents and Settings\Admin\Local Settings\Application Data\Google\Chrome\User Data\Default\Cache\ где «Admin» — это имя пользователя Windows.
После того, как вы соберете некоторую статистику по времени загрузки страницы и эффективной ширине канала для реальных пользователей, вы можете поэкспериментировать с изменениями, которые могут улучшить эти показатели. В случае значительных достижений в улучшении этого показателя стоит закрепить внесенные изменения.
Нижеприведенные советы частично уже фигурировали в других статьях: советы от Yahoo , объединение CSS-файлов , оптимизация времени загрузки страницы и многих других . Однако, повторение — учения, к тому же, в следующих советах есть несколько свежих моментов.
Можно попробовать следующие вещи:
Если пользователи регулярно загружают десяток или больше некеширующихся или некешируемых объектов, стоит распределить их загрузку по 4 хостам. В этом случае обычно пользователь сможет установить в 4 раза больше соединений. Без HTTP-конвейера это выльется в уменьшение потерь на пересылку запроса примерно в 4 раза.
При генерации страницы перед вами встанет задача распределения картинок по 4 разным хостам. Это легче всего сделать с помощью любой хеш-функции, например, MD5. Вместо того чтобы загружать все с одного http://static.example.com/ , создайте 4 хоста (например, static0.example.com , static1.example.com , static2.example.com , static3.example.com) и используйте 2 бита из MD5-суммы для каждой картинки, чтобы выбрать, на какой именно хост ставить ссылку на ее загрузку. Убедитесь, что все страницы используют один и тот же алгоритм соответствия (указывают на один и тот же хост для каждой картинки), иначе вы будете безрезультатно бороться против кеширования .
Стоит, однако, заметить, что добавление еще одного хоста увеличивает расходы на дополнительные DNS-поиск и установку HTTP-соединения. Если у пользователей включена конвейерная обработка запросов или страница подгружает менее десяти объектов (лично я бы рекомендовал ориентироваться на 5-6 на хост, т.е. при 10 объектах можно вводить второй хост, при 16 — третий, а при 25 - четвертый ), то пользователи не ощутят выигрыша от увеличения числа параллельных запросов и вместо ускорения загрузки сайта заметят ее замедление. Преимущества данного подхода появятся только для страниц с большим числом внешних объектов. Стоит каким-либо образом измерить разницу во времени загрузки для ваших пользователей прежде, чем полностью внедрять данную методику.
Возможно, лучшим выходом для ускорения загрузки ваших страниц для вернувшихся посетителей будет безусловное кеширование браузером статических картинок, файлов стилей и скриптов. Это никак не поможет при загрузке страницы для нового посетителя, но существенно уменьшит время загрузки страницы при повторных посещениях.
Рассмотрите возможность расположить небольшие объекты (или зеркало, или их кеш) максимально близко от пользователей в терминах сетевых задержек. Для больших сайтов с международной аудиторией можно использовать как платные сети доставки содержания (Content Delivery Network ), так и отдельные виртуальные машины в пределах 50мс для 80% ваших пользователей вместе с множеством доступных методов для распределения запросов пользователей на ближайшую к ним виртуальную машину (к слову сказать, как раз так работают сайты многих международных компаний, в том числе, и Acronis , распределяющие пользователей по локальным версиям в зависимости от географического признака ).
Регулярно проверяйте ваш сайт, заходя с помощью «рядовых» соединений. В моем случае использование «медленного прокси-сервера», который эмулировал плохое DSL-соединение из Новой Зеландии (768Кбит входящий, 128Кбит исходящий, 250мс задержка, 1% потери пакетов) вместо гигабайтного канала с несколькими миллисекундами от серверов в штатах, оказалось весьма полезным. Мы очень оперативно обнаружили и устранили ряд функциональных ошибок и проблем удобства использования.
Для моделирования такого медленного соединения, я использовал модули ядра Linux netem и HTB , которые доступны с версии 2.6. Оба этих модуля устанавливаются с командой . Это позволяет добиться наиболее точной эмуляции, которую мне удалось найти, но я бы не назвал ее идеальной. Лично я не пользовался, но, по общему мнению, по скрытой возможности в их браузере, которая позволяет получить также некоторую дополнительную информацию по поводу загрузки.
Если же вы хорошо знакомы с HTTP-протоколом и TCP/IP на пакетном уровне, то можно попробовать посмотреть, что происходит, используя tcpdump , или . Эти инструменты являются просто обязательными для сетевых отладок любого рода.
Попробуйте протестировать часто загружаемые страницы вашего сайта на производительность из локальной сети, используя , который поставляется вместе с веб-сервером Apache . Если сервер отвечает дольше, чем 5-10 миллисекунд при генерации страницы, значит, стоит хорошо разобраться, на что же уходит серверное время.
Если в результате таких тестов задержки оказались весьма высокими, и процесс веб-сервера (или CGI, если вы используете его) «отъедал» слишком много CPU, то причиной этого зачастую может оказаться необходимость в компиляции скриптов в процессе выполнения при каждом запросе. Такое программное обеспечение, как eAccelerator для PHP, mod_perl для perl, mod_python для python и т. д. могут кешировать серверные скрипты в скомпилированном состоянии, существенно ускоряя загрузку вашего сайта. Кроме этого, стоит найти профилирующий инструмент для вашего языка программирования, чтобы установить, на что же тратятся ресурсы CPU. Если вам удастся устранить причину больших нагрузок на процессор, то страницы будут отдаваться быстрее, и вы сможете выдавать больше трафика при меньшем числе машин.
Если на сайте при создании страницы выполняется много запросов к базе данных или какие-либо другие тяжелые вычисления, стоит рассмотреть добавление кеширования на стороне сервера для медленных операций. Большинство людей начинают с записи кеша в локальную память или локальный диск, однако, эта логика перестает работать, если ваша система расширяется до кластера веб-серверов (каждый со своим локальным диском и локальной памятью ). Стоит взглянуть в сторону использования memcached , который создает очень быстрый общий кеш, который объединяет свободную оперативную память всех имеющихся машин. Клиенты к нему портированы на большинство распространенных языков.
(Опционально) Подать петиция производителям браузеров с целью включить конвейерную обработку HTTP-запросов по умолчанию в новых браузерах. Если это будет сделано, то нам не придется исполнять эти «танцы с бубнами» (these tricks ), и большая часть веба будет загружаться быстрее для среднего пользователя. (В Firefox"е это отключено, предположительно, из-за некоторых прокси, некоторых балансировщиков нагрузок и некоторых версий IIS (привет, Microsoft! ), которые впадают в шок при конвейерных запросах. Но в Opera, по-видимому, провели существенную работу для того, чтобы включить эту возможность по умолчанию. Почему так не могут поступить все остальные браузеры?)
Заключение
Указанный список содержит мои мысли по увеличению скорости связи между браузером и сервером и может быть применен, в общем случае, ко многим сайтам не зависимо от того, как используется веб-сервер или язык разработки для написания сайта. Однако, к сожалению, все эти вещи делают довольно редко.
Хотя все советы направлены на уменьшения времени загрузки страницы, положительными побочными эффектами могут стать уменьшения трафика от сайта и уменьшения нагрузки на серверный процессор на просмотр одной страницы. Уменьшения затрат на ваш вебсайт при улучшении пользовательского восприятия ресурса должно быть веской причиной, чтобы потратить некоторое время на оптимизацию такого рода.