Webhelyének egyik legfontosabb szempontja a betöltési sebesség; A felhasználók azonnal, minden fék nélkül szeretnének képet kapni, és ha ezt nem tudja megadni, akkor sokáig nem fog habozni, hogy máshol keressen információt. Ebben a cikkben 5 olyan módszert tárgyalunk, amelyek lehetővé teszik webhelye betöltési idejének felgyorsítását.
1. Használja az YSlow-t az oldalbetöltési idők követésére
Ha ismeri az oldalak betöltéséhez szükséges időt, azonosíthatja a problémás területeket. Ez további ösztönzést ad arra, hogy belépjen a funkcióba, és megpróbálja megoldani a helyzetet.
Mielőtt elkezdené, telepítenie kell az YSlow-t, ha még nem tette meg. Az YSlow a következő kiterjesztése Mozilla Firefox amit ezen az oldalon találsz:
Most nyissunk egy oldalt. Tegyük fel, hogy Six Revisions, hogy megközelítőleg azonos adatokkal rendelkezzünk (csak nyissa meg ezt a webhelyet a böngésző új lapján).
A böngésző jobb alsó sarkában van egy speciális panel egy ikonnal (lásd az 1. ábrát). Kicsit távolabb ettől a paneltől, az oldal betöltése után a „YSlow” mellett egy szám jelenik meg. Ez a szám az az idő másodpercben, amíg az oldal betöltődik a böngészőben. Szeretnénk, ha ez a szám a lehető legkisebb lenne.
A leggyakoribb "fékek" a következő tárgyak vagy műveletek:
- Túl sok HTTP-kérés
- Tömörítetlen JavaScript fájlok
- A grafikus fájlok fejlécének nincs lejárati ideje
Ezt néhány perc múlva közelebbről is megvizsgáljuk.
Annak érdekében, hogy kényelmesen érezze magát ezzel a rendszerrel, nézzen át több webhelyet, és nézze meg azok betöltési idejét. Kipróbálhatja a Google-t, a Facebookot és néhány kedvenc blogját/webhelyét, amelyeket a legtöbbször látogat. Vegye figyelembe, hogy a JavaScript-fájlok és képek azok, amelyek leginkább befolyásolják a sebességet.
A YSlow-t maximálisan használjuk
Amellett, hogy az YSlow kiszámítja az oldal betöltési idejét, adott hosszabbítást emellett átfogó tájékoztatást nyújt arról, hogy mit kell javítania webhelye betöltésének optimalizálása érdekében, hogy befoltozhassa a lyukakat.
Az ilyen információkért kattintson a Teljesítmény fülre. A webhely feltérképezése után az YSlow egy általános pontszámot ad, amely az oldal teljesítményét jellemzi.
Az információhoz való hozzáférés felgyorsítható a CDN (tartalomszolgáltató hálózat) segítségével. A CDN a legjobban nagy webhelyekhez használható. Arra használják őket, hogy információkat osztjanak el több szerver között Különböző részek béke. Így az információk a megfelelő (a felhasználóhoz legközelebbi) szerverről töltődnek le, hogy ne menjenek át személyes útválasztókon. Az YSlow a CDN-kéréseket is követi.
De az emberek általában nem használnak CDN-eket (ami elég drága).
A hibatípusok osztályozása
Most menjünk végig minden olyan elemen, amely a fent említett kiterjesztésben található. Az alábbiakban összefoglalót talál arról, hogyan ítélik meg oldalait, és hogyan kezeljék a problémákat a maximális teljesítmény elérése érdekében.
A lehető legkevesebb HTTP-kérés: HTTP-kérés akkor történik, amikor a böngésző kérést küld a szervernek. Ugyanez történhet szkriptek, CSS fájlok, képek csatlakoztatásakor, valamint aszinkron kérések esetén, mind kliens oldalról, mind szerver oldalról (Ajax és más hasonló technológiák). A rendszerteljesítménynél azonban érdemes végiggondolni, hogy mennyi hasonló kéréseket történik az oldalon. Az egyik megoldás a gyorsítótár használata, amellyel az ügyfélgépek gyorsabban tölthetik be a szkripteket, a CSS-t és a képeket.
Lejárati fejlécek hozzáadása: Az oldalbetöltés 80%-a szkriptek, fényképek és CSS-fájlok letöltésére irányul. A legtöbb esetben ezek a dolgok nem változnak a felhasználói gépeken. Ha hozzáad egy kódot a .htaccess fájlhoz, gyorsítótárba helyezheti a duplikált fájlokat a felhasználó helyi gépén (erről később beszélünk).
Gzip összetevők: Alkalmazza a Gzip fájlt vagy tömörítse a JS fájlokat, képeket, HTML dokumentumok, CSS-fájlok stb. lehetővé teszi a felhasználók számára, hogy csökkentett méretben töltsenek le információkat, ami jelentősen megnöveli az oldalbetöltés sebességét. Ezzel ráadásul helyet takaríthatunk meg a szerveren, azonban az adatok kicsomagolása lassíthatja a választ, és ez közvetlenül a felhasználó böngészőjétől függ.
Helyezze el a CSS-t az oldal tetejére: Ha a CSS-kapcsolatot az oldal tetejére helyezi, az azt jelenti, hogy először ezek töltődnek be, a képek és szkriptek pedig később.
Helyezze el a JS-t az oldal aljára: Most, hogy a CSS-fájlok a tetején töltődnek be, itt az ideje, hogy a JS-szkripteket közvetlenül a záró címke elé helyezze. Ez lehetővé teszi az oldal megjelenítését, majd tartalmazza a szükséges szkripteket.
Kerülje a CSS-kifejezéseket: Én személy szerint soha nem használtam CSS-kifejezéseket (ezeket dinamikus tulajdonságoknak is nevezik). Ezek a kifejezések natív IE programozási koncepciók (például feltételes kifejezések) a CSS-ben. Az IE8-ban és az összes többi verzióban használt technológia a továbbiakban nem lesz támogatott, így minden esetben kapcsolódni kell ehhez a CSS-kifejezések írásához. A PHP alkalmasabb ilyen célokra, például különböző CSS-stílusok betöltésére valamilyen feltételtől függően, például véletlen számtól, napszaktól vagy a felhasználó böngészőjétől.
JS-t és CSS-t írjon külön fájlba: ha a szkriptjeit JS-be és css stílusok külön fájlokban a böngésző könnyen gyorsítótárazhatja azokat, ezáltal lehetővé téve az oldal gyorsabb betöltését a jövőben.
Csökkentse a DNS-keresési időt: amikor a felhasználó beírja a webhely nevét a böngészősávba, azonnal megkezdődik annak az IP-címnek a DNS-keresése, ahol a webhely található. Minél több külső forrást tartalmaz a webhely, annál több időt vesz igénybe a DNS-keresés. Általában egy ilyen keresés 60-100 ezredmásodpercig tart.
A JS kicsinyítése: A gzip használatával történő tömörítés mellett a JavaScript-fájlok kicsinyítése lehetővé teszi a szkriptek könnyítését, mivel megszabadul a felesleges szóközöktől, tabulátoroktól és egyéb speciális karakterektől, amelyek nagy fájlméretet eredményeznek. Nyilvánvaló – minél kisebbek a fájlok, annál gyorsabban töltődnek be az oldalak. A JSMIN eszközzel kicsinyítheti a JavaScript-fájlokat.
Kerülje az átirányításokat: Nem mindegy, hogy hol végzi el az átirányítást, JS-ben, HTML-ben vagy PHP-ben. Akárhogy is, a böngészője üres oldalfejlécet kap, amelynek betöltése időbe telik. Tehát próbáljon meg ne használjon átirányítást ott, ahol ez elkerülhető.
Kerülje el a duplikált szkriptbetöltéseket: Ha a böngészője egynél többször tölt be egy szkriptet, az jelentősen befolyásolja az oldalak betöltését. A matematika itt nem nehéz. Minél több ugyanazon fájl letöltése, annál több hosszabb töltés oldalakat. Tekintse át a szkripteket, és győződjön meg arról, hogy ne hívja meg kétszer vagy háromszor a jQuery-t. Ugyanez vonatkozik a JS szkriptekre is.
Hát… azt hiszem, ez elég. Most térjünk át az YSlow következő lapjára, mielőtt megvizsgálnánk néhány egyéb technikát, amelyek növelik az oldal betöltési sebességét.
Az Összetevők lapon meghatározhatja, mennyi erőfeszítést kell tennie a letöltési sebesség javítása érdekében. Itt információkat talál az egyes fájlok súlyáról, valamint arról, hogy mennyi ideig tart a letöltés. Azt is láthatja, hogy mely fájlok kerülnek gzip-be, megtudhatja a válaszidőt és azt, hogy a fájlok gyorsítótárban vannak-e a felhasználó gépén, és mikor ér véget maga a gyorsítótár. Ezek az információk hasznosak lehetnek az Ön webhelyének problémáinak felmérése során, tudni fogja, mi a baj, és mit kell optimalizálni.
És végül lépjünk tovább utolsó lap Statisztika lap. Itt talál információkat az összes HTTP-kérésről, mind a normál, mind a gyorsítótárazott fájlokról. Az Empty cache érték azt jelzi, hogy ezeket a fájlokat be kell tölteni az oldal megjelenítéséhez. A Primed Cache viszont olyan fájlok, amelyeket a felhasználó böngészője már tárolt. Ez azt jelenti, hogy nem kell letölteni őket.
2. CSS Sprite használatával csökkentse a HTTP-kérések számát
A CSS sprite valószínűleg a legjelentősebb dolog, amivel az emberiség előállt, mióta a Tesla feltalálta az elektromosságot… Igazából ezt mondtam… hoppá, Edisonra gondoltam.
Nos, talán nem a legmenőbb, de akkor is.
A CSS sprite-ok nagymértékben javíthatják az oldalbetöltési sebességet azáltal, hogy csökkentik a képek letöltésére irányuló HTTP-kérések számát.
Számos oktatóanyagot találhat, amelyek arról beszélnek, hogy a CSS sprite-ok könnyen navigálhatók - általában véve, hogyan lehet őket felhasználói felületen használni.
Most pedig nézzük meg, hogyan használja a YouTube a CSS sprite-okat. Így néz ki az általuk használt sprite:
A YouTube meglehetősen eredeti módon használja ezt a fájlt. Háttérként betöltik a sprite osztályba. Amikor szükségessé válik egy elem kijelölése, a kezdeti pozíció kiválasztásra kerül, amikor CSS segítség háttérpozíció tulajdonságait, majd alkalmazza a magasságot és a szélességet.
Próbáljunk ki valami hasonlót. Kísérletezzünk ugyanazon a YouTube-on található képen.
Az alábbi példában a YouTube logót jelenítjük meg a képernyőn. Ugyanazt a sprite osztályt és ugyanazt a képet használva létrehozhatunk egy képet, amely az egeret mozgatva megváltozik.
Így ennek a képnek a használatával az összes kapcsolatot egyetlen HTTP-kérésre redukálhatjuk. Nos, mi a hatása?
Egy másik előny CSS sprite-ok az, hogy a :hover pszeudo osztály alkalmazásakor a kép nem tűnik el néhány pillanatra (ami egy új kép betöltéséhez szükséges), mivel ez megtörténik anélkül CSS használat sprite-ok.
3. Töltse be a CSS fájlokat az elején, a JavaScriptet a végén
Egyes webhelyek esetében a HTTP-kérelmek számának csökkentése tönkreteheti a funkcionalitást. Az oldalbetöltés felgyorsításának másik módja az, hogy az összes JavaScript fájlkapcsolatot a dokumentum végére helyezzük.
Érdemes még megjegyezni:
- Töltse be a CSS-fájlokat a közvetlenül a body címke kezdete előtti szakaszban.
- Szerelje be a JavaScriptet közvetlenül a záró body címke elé.
Ha követi tanácsunkat, lehetővé teszi a felhasználók számára, hogy megcsodálják webhelyeit, miközben a JavaScript betöltődik a háttérben.
Megjegyzés: Ha nem akar költözni JavaScript címkék, mert attól tart, hogy leesik a funkcionalitás, akkor javaslom a defer tulajdonság használatát. Alkalmazza így:
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, по-видимому, провели существенную работу для того, чтобы включить эту возможность по умолчанию. Почему так не могут поступить все остальные браузеры?)
Заключение
Указанный список содержит мои мысли по увеличению скорости связи между браузером и сервером и может быть применен, в общем случае, ко многим сайтам не зависимо от того, как используется веб-сервер или язык разработки для написания сайта. Однако, к сожалению, все эти вещи делают довольно редко.
Хотя все советы направлены на уменьшения времени загрузки страницы, положительными побочными эффектами могут стать уменьшения трафика от сайта и уменьшения нагрузки на серверный процессор на просмотр одной страницы. Уменьшения затрат на ваш вебсайт при улучшении пользовательского восприятия ресурса должно быть веской причиной, чтобы потратить некоторое время на оптимизацию такого рода.