Don't scale images in the browser (avoidScalingImages) | The page has 9 images that are scaled more than 100 pixels. It would be better if those images are sent so the browser don't need to scale them. | 10 |
Description: It's easy to scale images in the browser and make sure they look good in different devices, however that is bad for performance! Scaling images in the browser takes extra CPU time and will hurt performance on mobile. And the user will download extra kilobytes (sometimes megabytes) of data that could be avoided. Don't do that, make sure you create multiple version of the same image server-side and serve the appropriate one. |
Offenders: https://stage.sokolov.ru/upload/content/area/296be3890379f130b6aba56d318ab2e2.jpg https://stage.sokolov.ru/upload/content/area/29692ce29bea0ed9fc48a32b78e96577.jpg https://stage.sokolov.ru/upload/content/area/599381a89a12f2135e4cc41d907c53af.jpg https://stage.sokolov.ru/upload/content/area/7b737af32bfdf0a9756be23dad1122fa.jpg https://stage.sokolov.ru/upload/content/area/aacd8376c5eeab8dec4904e69f2fa2d7.jpg https://stage.sokolov.ru/upload/content/area/d50e7d97286724aca1441de191909703.jpg https://stage.sokolov.ru/upload/content/area/4a175e582f4323dd74687852cf297369.jpg https://stage.sokolov.ru/upload/content/area/4754f43eedc890535a35cd5d5da5b413.jpg https://stage.sokolov.ru/upload/content/area/7730846614634f1e713444e0c80a2198.jpg |
Have a fast first contentful paint (firstContentfulPaint) | First contentful paint can be improved (2.058 s). It is in the Google Web Vitals needs improvement range, slower than 1.8 seconds. | 50 |
Description: The First Contentful Paint (FCP) metric measures the time from when the page starts loading to when any part of the page content is rendered on the screen. For this metric, "content" refers to text, images (including background images), <svg> elements, or non-white <canvas> elements. |
Avoid using Google Tag Manager. (googleTagManager) | The page is using Google Tag Manager, this is a performance risk since non-tech users can add JavaScript to your page. | 0 |
Description: Google Tag Manager makes it possible for non tech users to add scripts to your page that will downgrade performance. |
Inline CSS for faster first render (inlineCss) | The page has both inline styles as well as it is requesting 14 CSS files inside of the head. Let's only inline CSS for really fast render. | 90 |
Description: In the early days of the Internet, inlining CSS was one of the ugliest things you can do. That has changed if you want your page to start rendering fast for your user. Always inline the critical CSS when you use HTTP/1 and HTTP/2 (avoid doing CSS requests that block rendering) and lazy load and cache the rest of the CSS. It is a little more complicated when using HTTP/2. Does your server support HTTP push? Then maybe that can help. Do you have a lot of users on a slow connection and are serving large chunks of HTML? Then it could be better to use the inline technique, becasue some servers always prioritize HTML content over CSS so the user needs to download the HTML first, before the CSS is downloaded. |
Offenders: https://frontend-stage-static.k8s.dev.sokolov.io/_next/static/css/3f6ad93839fbb9c1.css https://frontend-stage-static.k8s.dev.sokolov.io/_next/static/css/a75fe8ded042cbfd.css https://frontend-stage-static.k8s.dev.sokolov.io/_next/static/css/7e6914a619aaaccf.css https://frontend-stage-static.k8s.dev.sokolov.io/_next/static/css/9fc324d068f8ae82.css https://frontend-stage-static.k8s.dev.sokolov.io/_next/static/css/f2f640d30117f472.css https://frontend-stage-static.k8s.dev.sokolov.io/_next/static/css/923538a4e5a3c925.css https://frontend-stage-static.k8s.dev.sokolov.io/_next/static/css/b03e009bf1bbe802.css https://frontend-stage-static.k8s.dev.sokolov.io/_next/static/css/7d06de3534181a6c.css https://frontend-stage-static.k8s.dev.sokolov.io/_next/static/css/949e73f2837930ee.css https://frontend-stage-static.k8s.dev.sokolov.io/_next/static/css/d32410ee3fa1a458.css https://frontend-stage-static.k8s.dev.sokolov.io/_next/static/css/9511f7f8ba2ecf22.css https://code.jivo.ru/css/0828a0d/widget.css https://code.jivo.ru/css/0828a0d/omnichannelMenu.widget.css https://personalization-web-stable.mindbox.ru/js/service/styles.css?v=4.48.36 |
Have a fast largest contentful paint (largestContentfulPaint) | Largest contentful paint can be improved 2.881 s. It is in the Google Web Vitals needs improvement range, slower than 2.5 seconds. | 80 |
Description: Largest contentful paint is one of Google Web Vitals and reports the render time of the largest image or text block visible within the viewport, relative to when the page first started loading. To be fast according to Google, it needs to render before 2.5 seconds and results over 4 seconds is poor performance. |
Offenders: https://stage.sokolov.ru/upload/content/area/a3dc19ce3bd09bc9ea19d73be968b611.jpg |
Avoid CPU Long Tasks (longTasks) | The page has 16 CPU long tasks with the total of 2.092 s. The total blocking time is 807 ms and 3 long tasks before first contentful paint with total time of 635 ms. However the CPU Long Task is depending on the computer/phones actual CPU speed, so you should measure this on the same type of the device that your user is using. Use Geckoprofiler for Firefox or Chromes tracelog to debug your long tasks. | 0 |
Description: Long CPU tasks locks the thread. To the user this is commonly visible as a "locked up" page where the browser is unable to respond to user input; this is a major source of bad user experience on the web today. However the CPU Long Task is depending on the computer/phones actual CPU speed, so you should measure this on the same type of the device that your user is using. To debug you should use the Chrome timeline log and drag/drop it into devtools or use Firefox Geckoprofiler. |
Offenders: selfselfselfselfselfselfselfmultiple-contextsselfselfselfselfselfselfselfself |
Avoid Frontend single point of failures (spof) | The page has 14 requests inside of the head that can cause a SPOF (single point of failure). Load them asynchronously or move them outside of the document head. | 70 |
Description: A page can be stopped from loading in the browser if a single JavaScript, CSS, and in some cases a font, couldn't be fetched or is loading really slowly (the white screen of death). That is a scenario you really want to avoid. Never load 3rd-party components synchronously inside of the head tag. |
Offenders: https://frontend-stage-static.k8s.dev.sokolov.io/_next/static/css/3f6ad93839fbb9c1.css https://frontend-stage-static.k8s.dev.sokolov.io/_next/static/css/a75fe8ded042cbfd.css https://frontend-stage-static.k8s.dev.sokolov.io/_next/static/css/7e6914a619aaaccf.css https://frontend-stage-static.k8s.dev.sokolov.io/_next/static/css/9fc324d068f8ae82.css https://frontend-stage-static.k8s.dev.sokolov.io/_next/static/css/f2f640d30117f472.css https://frontend-stage-static.k8s.dev.sokolov.io/_next/static/css/923538a4e5a3c925.css https://frontend-stage-static.k8s.dev.sokolov.io/_next/static/css/b03e009bf1bbe802.css https://frontend-stage-static.k8s.dev.sokolov.io/_next/static/css/7d06de3534181a6c.css https://frontend-stage-static.k8s.dev.sokolov.io/_next/static/css/949e73f2837930ee.css https://frontend-stage-static.k8s.dev.sokolov.io/_next/static/css/d32410ee3fa1a458.css https://frontend-stage-static.k8s.dev.sokolov.io/_next/static/css/9511f7f8ba2ecf22.css https://code.jivo.ru/css/0828a0d/widget.css https://code.jivo.ru/css/0828a0d/omnichannelMenu.widget.css https://personalization-web-stable.mindbox.ru/js/service/styles.css?v=4.48.36 |
Avoid doing redirects (assetsRedirects) | The page has 14 redirects. 14 of the redirects are from the base domain, please fix them! | 0 |
Description: A redirect is one extra step for the user to download the asset. Avoid that if you want to be fast. Redirects are even more of a showstopper on mobile. |
Offenders: https://stage.sokolov.ru/upload/content/area/a3dc19ce3bd09bc9ea19d73be968b611.jpg https://stage.sokolov.ru/upload/content/area/6970a909d08d8083e9e0a9192c24269b.jpg?w=1920&h=844 https://stage.sokolov.ru/upload/content/area/674b26ff2af51fa439877badd0553224.mp4 https://stage.sokolov.ru/upload/content/area/296be3890379f130b6aba56d318ab2e2.jpg https://stage.sokolov.ru/upload/content/area/29692ce29bea0ed9fc48a32b78e96577.jpg https://stage.sokolov.ru/upload/content/area/dfd375aa4e2f3c311213d48422039027.jpg https://stage.sokolov.ru/upload/content/area/599381a89a12f2135e4cc41d907c53af.jpg https://stage.sokolov.ru/upload/content/area/7b737af32bfdf0a9756be23dad1122fa.jpg https://stage.sokolov.ru/upload/content/area/aacd8376c5eeab8dec4904e69f2fa2d7.jpg https://stage.sokolov.ru/upload/content/area/d50e7d97286724aca1441de191909703.jpg https://stage.sokolov.ru/upload/content/area/4a175e582f4323dd74687852cf297369.jpg https://stage.sokolov.ru/upload/content/area/4754f43eedc890535a35cd5d5da5b413.jpg https://stage.sokolov.ru/upload/content/area/7730846614634f1e713444e0c80a2198.jpg https://stage.sokolov.ru/upload/content/area/de6daf5ac89f1e0522d9cf7a2728609a.png |
Avoid extra requests by setting cache headers (cacheHeaders) | The page has 52 requests that are missing a cache time. Configure a cache time so the browser doesn't need to download them every time. It will save 3.4 MB the next access. | 0 |
Description: The easiest way to make your page fast is to avoid doing requests to the server. Setting a cache header on your server response will tell the browser that it doesn't need to download the asset again during the configured cache time! Always try to set a cache time if the content doesn't change for every request. |
Offenders: https://stage.sokolov.ru/api/v4/content/area/main-banner-004/ https://stage.sokolov.ru/api/v4/content/area/main-stories/ https://stage.sokolov.ru/api/v4/content/area/navigation-block-008/ https://stage.sokolov.ru/api/v5/profile/ https://stage.sokolov.ru/api/v5/profile/products/ https://stage.sokolov.ru/api/v5/handbooks/currency-rates/ https://stage.sokolov.ru/api/v5/location/check/ https://stage.sokolov.ru/api/v4/content/area/nav-buttons/ https://sokolov-b2c-seo.k8s.dev.sokolov.io/api/v1/meta/ip/ https://frontend-stage-static.k8s.dev.sokolov.io/meta/manifest.json https://stage.sokolov.ru/api/v4/content/area/main-page-topline/ https://stage.sokolov.ru/api/v4/content/area/feedback-channels/ https://stage.sokolov.ru/api/v4/content/area/download-app-banner/ https://frontend-stage-static.k8s.dev.sokolov.io/meta/favicon.ico https://stage.sokolov.ru/upload/content/area/68e58dc20cbd461fd14fc683592fca9b.svg https://stage.sokolov.ru/upload/content/area/1f1f79322c6d27b1dbbf009d9094f0b1.svg https://stage.sokolov.ru/upload/content/area/26ad66b0f0bb1efbb0aea1b0aeac800a.svg https://stage.sokolov.ru/upload/content/area/a3dc19ce3bd09bc9ea19d73be968b611.jpg https://stage.sokolov.ru/upload/content/area/6970a909d08d8083e9e0a9192c24269b.jpg?w=1920&h=844 https://stage.sokolov.ru/upload/content/area/b832960c3f0c40480c9293e5b3b5f089.svg https://stage.sokolov.ru/upload/content/area/062aa6f7bd9925ab496599d8f10203d0.svg https://stage.sokolov.ru/upload/content/area/f4d1232004ddb92acb6e26f924872b61.svg https://stage.sokolov.ru/upload/content/area/2025c736f68b3ec222a8edf16fdca38f.svg https://cdn.sokolov.ru/upload/content/area/a3dc19ce3bd09bc9ea19d73be968b611.jpg https://cdn.sokolov.ru/upload/content/area/6970a909d08d8083e9e0a9192c24269b.jpg?w=1920&h=844 https://stage.sokolov.ru/upload/content/area/ed05b31c2846fae9c5fa8f5e313560fc.svg https://stage.sokolov.ru/upload/content/area/674b26ff2af51fa439877badd0553224.mp4 https://stage.sokolov.ru/upload/content/area/296be3890379f130b6aba56d318ab2e2.jpg https://stage.sokolov.ru/upload/content/area/29692ce29bea0ed9fc48a32b78e96577.jpg https://stage.sokolov.ru/upload/content/area/dfd375aa4e2f3c311213d48422039027.jpg https://stage.sokolov.ru/upload/content/area/599381a89a12f2135e4cc41d907c53af.jpg https://stage.sokolov.ru/upload/content/area/7b737af32bfdf0a9756be23dad1122fa.jpg https://stage.sokolov.ru/upload/content/area/674b26ff2af51fa439877badd0553224.mp4/ https://cdn.sokolov.ru/upload/content/area/296be3890379f130b6aba56d318ab2e2.jpg https://cdn.sokolov.ru/upload/content/area/29692ce29bea0ed9fc48a32b78e96577.jpg https://stage.sokolov.ru/upload/content/area/aacd8376c5eeab8dec4904e69f2fa2d7.jpg https://stage.sokolov.ru/upload/content/area/d50e7d97286724aca1441de191909703.jpg https://cdn.sokolov.ru/upload/content/area/599381a89a12f2135e4cc41d907c53af.jpg https://cdn.sokolov.ru/upload/content/area/dfd375aa4e2f3c311213d48422039027.jpg https://cdn.sokolov.ru/upload/content/area/7b737af32bfdf0a9756be23dad1122fa.jpg https://stage.sokolov.ru/upload/content/area/4a175e582f4323dd74687852cf297369.jpg https://stage.sokolov.ru/upload/content/area/4754f43eedc890535a35cd5d5da5b413.jpg https://stage.sokolov.ru/upload/content/area/7730846614634f1e713444e0c80a2198.jpg https://cdn.sokolov.ru/upload/content/area/aacd8376c5eeab8dec4904e69f2fa2d7.jpg https://cdn.sokolov.ru/upload/content/area/d50e7d97286724aca1441de191909703.jpg https://stage.sokolov.ru/upload/content/area/de6daf5ac89f1e0522d9cf7a2728609a.png https://tracking.diginetica.net/csc-event...ica.net/csc-event https://cdn.sokolov.ru/upload/content/area/4a175e582f4323dd74687852cf297369.jpg https://cdn.sokolov.ru/upload/content/area/4754f43eedc890535a35cd5d5da5b413.jpg https://cdn.sokolov.ru/upload/content/area/7730846614634f1e713444e0c80a2198.jpg https://cdn.sokolov.ru/upload/content/area/de6daf5ac89f1e0522d9cf7a2728609a.png https://tracking.diginetica.net/csc-event...ica.net/csc-event |
Long cache headers is good (cacheHeadersLong) | The page has 1 request that have a shorter cache time than 30 days (but still a cache time). | 99 |
Description: Setting a cache header is good. Setting a long cache header (at least 30 days) is even better beacause then it will stay long in the browser cache. But what do you do if that asset change? Rename it and the browser will pick up the new version. |
Offenders: https://cdn.diginetica.net/300/client-lite.js |
Always compress text content (compressAssets) | The page has 1 request that are served uncompressed. You could save a lot of bytes by sending them compressed instead. | 90 |
Description: In the early days of the Internet there were browsers that didn't support compressing (gzipping) text content. They do now. Make sure you compress HTML, JSON, JavaScript, CSS and SVG. It will save bytes for the user; making the page load faster and use less bandwith. |
Offenders: |
Total CSS size shouldn't be too big (cssSize) | The total CSS transfer size is 84.7 kB and uncompressed size is 565.4 kB. That is big and the CSS could most probably be smaller. | 50 |
Description: Delivering a massive amount of CSS to the browser is not the best thing you can do, because it means more work for the browser when parsing the CSS against the HTML and that makes the rendering slower. Try to send only the CSS that is used on that page. And make sure to remove CSS rules when they aren't used anymore. |
Offenders: |
The favicon should be small and cacheable (favicon) | The favicon has no cache time. | 50 |
Description: It is easy to make the favicon big but please avoid doing that, because every browser will then perform an unnecessarily large download. And make sure the cache headers are set for a long time for the favicon. It is easy to miss since it's another content type. |
Offenders: https://frontend-stage-static.k8s.dev.sokolov.io/meta/favicon.ico |
Avoid too many fonts (fewFonts) | The page has 4 font requests. Do you really need them? What value does the fonts give the user? | 60 |
Description: How many fonts do you need on a page for the user to get the message? Fonts can slow down the rendering of content, try to avoid loading too many of them because worst case it can make the text invisible until they are loaded (FOIT—flash of invisible text), best case they will flicker the text content when they arrive. |
Offenders: https://cdn.sokolov.ru/fonts/montserrat/bold.woff2 https://cdn.sokolov.ru/fonts/montserrat/regular.woff2 https://cdn.sokolov.ru/fonts/montserrat/medium.woff2 https://cdn.sokolov.ru/fonts/montserrat/semibold.woff2 |
Avoid too many requests per domain [HTTP/1] (fewRequestsPerDomain) | The page has 1 domain that serves more than 30 requests. frontend-stage-static.k8s.dev.sokolov.io got 51 requests. Improve performance by sharding those or move to HTTP/2. | 90 |
Description: Browsers have a limit on how many concurrent requests they can do per domain when using HTTP/1. When you hit the limit, the browser will wait before it can download more assets on that domain. So avoid having too many requests per domain. |
Offenders: frontend-stage-static.k8s.dev.sokolov.io |
Total image size shouldn't be too big (imageSize) | The page total image size is 1.6 MB. It's really big. Is the page using the right format for the images? Can they be lazy loaded? Are they compressed as good as they can be? Make them smaller by using https://imageoptim.com/. | 50 |
Description: Avoid having too many large images on the page. The images will not affect the first paint of the page, but it will eat bandwidth for the user. |
Total JavaScript size shouldn't be too big (javascriptSize) | The total JavaScript transfer size is 578 kB and the uncompressed size is 1.9 MB. This is totally crazy! There is really room for improvement here. | 0 |
Description: A lot of JavaScript often means you are downloading more than you need. How complex is the page and what can the user do on the page? Do you use multiple JavaScript frameworks? |
Offenders: |
Avoid using incorrect mime types (mimeTypes) | The page has 2 misconfigured mime types. | 98 |
Description: It's not a great idea to let browsers guess content types (content sniffing), in some cases it can actually be a security risk. |
Offenders: https://sokolov-b2c-seo.k8s.dev.sokolov.io/api/v1/meta/ip/ https://mltp.sokolov.io/collect |
Make each CSS response small (optimalCssSize) | https://frontend-stage-static.k8s.dev.sokolov.io/_next/static/css/3f6ad93839fbb9c1.css size is 50.2 kB (50180) and that is bigger than the limit of 14.5 kB. https://frontend-stage-static.k8s.dev.sokolov.io/_next/static/css/9fc324d068f8ae82.css size is 15.2 kB (15164) and that is bigger than the limit of 14.5 kB. Try to make the CSS files fit into 14.5 KB. | 80 |
Description: Make CSS responses small to fit into the magic number TCP window size of 14.5 KB. The browser can then download the CSS faster and that will make the page start rendering earlier. |
Offenders: |
Total page size shouldn't be too big (pageSize) | The page total transfer size is 4.3 MB, which is more than the coach limit of 2 MB. That is really big and you need to make it smaller. | 0 |
Description: Avoid having pages that have a transfer size over the wire of more than 2 MB (desktop) and 1 MB (mobile) because that is really big and will hurt performance and will make the page expensive for the user if she/he pays for the bandwidth. |
Offenders: |
Don't use private headers on static content (privateAssets) | The page has 3 requests with private headers. Make sure that the assets really should be private and only used by one user. Otherwise, make it cacheable for everyone. | 70 |
Description: If you set private headers on content, that means that the content are specific for that user. Static content should be able to be cached and used by everyone. Avoid setting the cache header to private. |
Offenders: https://stage.sokolov.ru/ https://tracking.diginetica.net/csc-event...ica.net/csc-event https://tracking.diginetica.net/csc-event...ica.net/csc-event |
Avoid missing and error requests (responseOk) | The page has 2 error responses. The page has 2 responses with code 404. | 80 |
Description: Your page should never request assets that return a 400 or 500 error. These requests are never cached. If that happens something is broken. Please fix it. |
Offenders: https://stage.sokolov.ru/api/v5/profile/ https://stage.sokolov.ru/upload/content/area/674b26ff2af51fa439877badd0553224.mp4/ |