Cerrar menu
Tutoriales En Linea
  • Tutoriales
    • Aprendizaje
    • Video Tutorial
    • Manuales
    • Hagalo usted mismo
    • Explorar todo
  • Adobe
    • After Effects
    • Dreamweaver
    • Premiere Pro CC
    • Photoshop
    • Photoshop Mix
    • Lightroom
    • Illustrator
    • Adobe Muse
    • Creative Cloud
  • Android
    • Developer Android
    • Aplicaciones
    • Android Studio
    • Android Wear
    • Desarrolladores
    • SDK Platform-Tools
    • ADB...depuración Bridge
    • Fastboot
    • Root
    • Recovery
  • Apple
    • iPhone y iPad
    • iPhone
    • iPad
    • Mac OS
    • iCloud
    • iTunes
  • Cursos
    • Actívate
    • Autoempleo
    • Idiomas
    • Curso De HTML
    • Curso de C++
    • Javascript
    • jQuery
    • Matematicas
    • Programacion
    • Python
    • Udacity
    • Diseño Web adaptativo
  • Ciberseguridad
    • Malware
    • Ransomware
    • Virus
    • Troyano
    • Dorkbot
    • Filecoders
    • keylogger
    • Spyware
    • Jackware
    • DDoS
    • HackerOne
    • Interpol
  • Criptomonedas
    • Blockchain
    • Mineria de Criptomonedas
    • Bitcoin (BTC)
    • Bitcoin Cash (BCH)
    • DASH (Dash)
    • Dogecoin (Doge)
    • Ethereum (ETH)
    • Litecoin (LTC)
    • Monero (XMR)
    • Ripple (XRP)
    • Zcash (ZEC)
    • Forex
    • Trading
  • Desarrollo Web
    • Sistema de gestion de contenidos
    • AMP
    • Datalife Engine
    • Blogger
    • WordPress
    • Joomla
    • Bootstrap
    • Plantillas
    • @font-face
    • Schema
    • Website
    • Desarrolladores
    • Lenguaje Web
  • Diseño Web
    • Web Responsive
    • Lenguaje Web
    • Datos estructurados
    • HTML
    • CSS3
    • JavaScript
    • Ajax
    • jQuery
    • PHP
  • Entretenimiento
  • Encuestas
    • GlobalTestMarket
    • Centro de opinion
    • Ipsos i-Say
    • Triaba
    • opinea
    • Toluna
    • YouGov
    • ClixSense
    • ySense
    • Cint
    • Beruby
  • Electricidad
  • Electronica
  • Ganar dinero comprando
    • CashbackDeals
    • Cashback
    • Por ir de compras
    • Aklamio
    • Intercambio de tráfico
    • Justificante de pagos
    • Webs estafas
  • Google
    • Google Pay
    • Adsense
    • Gmail
    • Google Apps
    • Google Chrome
    • Google Cloud Platform
    • Google Consumer Surveys
    • Google Desarrolladores
    • Google Fit
    • Google Maps
    • Google Photos
    • Google Play
    • Google Translation
    • DoubleClick
    • YouTube
    • Chromebooks
  • Marketing
    • SEM
    • SEO
    • Posicionamiento
    • Contenido
    • Publisuites
    • Space Content
    • Coobis
    • Marketing
  • Computadora u ordenador
    • Sistemas operativos
      • Windows
      • Mac OS
      • Android
      • Linux
      • Ubuntu
      • Kali Linux
      • Wifislax
    • hardware
    • Software
    • BIOS
    • Unidad de disco duro
    • Programacion
    • Dispositivos
    • Internet
  • Ofimática
    • Microsoft
    • Suite Ofimatica
    • Access
    • Word
    • Excel
    • Powerpoint
    • Outlook
    • Microsoft Publisher
  • PTC
    • No pierdas tiempo con estas web
  • Redes Sociales
    • Delicious
    • Facebook
    • Instagram
    • linkedin
    • Snapchat
    • TikTok
    • Twitter
    • Pinterest
    • Spotify
    • Vkontakte - VK
    • WhatsApp
  • Smartphone
    • Telefonos
    • Telefonia movil y telecomunicaciones
    • Desbloquear
    • Códigos NCK
    • Liberar
    • Tarjeta SIM
    • Tablet
  • Sitio Web
    • Dominios
    • Hosting
    • Servidores
    • Demo DLE
    • Documentación sobre Datalife Engine
    • Modulos DLE
    • Hack
    • Optimizacion
    • Google Adsense
    • Plantillas
  • Tips
    • Cabello
    • Consejos
    • Cremas
    • Cosmético
    • Cuerpo
    • Dieta
    • Exfoliantes
    • Entrenamiento
    • Ejercicio
    • Estilo
    • Fitness
    • Habitos
    • Hidratante
    • Look
    • Maquillaje
    • Moda
    • Piel Radiante
    • Recetas
    • Ropa
    • Rutina
    • Salud
    • Tratamientos
  • Trabajos
    • Atencion al cliente
    • Asistente virtual
    • Transcripcíon
    • Transcripcíones medica
    • Entrada de datos
    • De edicion y correccion
    • Mystery Shopping
    • Micro trabajos
    • Contabilidad
    • Tutoria y aprendizaje
    • Mas ingresos extras
    • Git
    • GitHub
    • Criptografia
    • Deep Web
    • Hacker
    • FTP
    • Indexar
    • Newsletter
    • Redes y VPN
    • Herramientas online
  • Windows
    • Skype
    • Windows
    • Windows 11
    • Windows 10
    • Windows 8
    • Windows 7
    • Puerta trasera de Windows
    • Microsoft Edge
Facebook X (Twitter) Instagram
  • Sobre nosotros
  • Últimos artículos
  • Herramientas SEO
  • Ver mas temas
  • Más sitios que te gustarán
Facebook X (Twitter) Instagram Pinterest Youtube
  • Secciones
    1. Android
    2. Adobe
    3. Bricolaje
    4. Bachillerato
    5. Cursos
    6. Criptomonedas
    7. Criptografia
    1. Diseño Web
    2. Encuestas
    3. Empleo
    4. Electricidad
    5. Electronica
    6. Forex
    7. Fisica
    1. Google
    2. Hardware
    3. Herramientas Ofimaticas
    4. Herramientas
    5. Internet
    6. Idiomas
    7. IPTV
    1. Programacion
    2. Libros
    3. Microsoft
    4. Manuales
    5. Matematica
    6. Newsletter
    7. Optimizacion
    1. Redes Sociales
    2. Software
    3. Seguridad
    4. Telefonia
    5. WebSite
    6. Ver todas las categorias
    7. Post promocionado
  • Smartphone

    Comprendre les Différences entre les Chargeurs USB et les Chargeurs USB-C : Un Guide Complet

    Huawei Smartphones: Las Mejores Ofertas del Black Friday para Aprovechar

    Gadgets imprescindibles para tu configuración de oficina en casa

    ¡Descubre las tendencias más emocionantes en el mundo de los videojuegos!

    Tendencias en sistemas operativos en smartphone

  • Tecnología
    1. Móviles
    2. Ordenadores
    3. Software
    4. Hardware
    5. Seguridad
    6. Ver todo

    Comprendre les Différences entre les Chargeurs USB et les Chargeurs USB-C : Un Guide Complet

    Huawei Smartphones: Las Mejores Ofertas del Black Friday para Aprovechar

    Gadgets imprescindibles para tu configuración de oficina en casa

    ¡Descubre las tendencias más emocionantes en el mundo de los videojuegos!

    Cómo limpiar la unidad C de archivos innecesarios

    Descubre el misterioso mundo del hash de archivos: ¡todo lo que necesitas saber!

    Los componentes fundamentales que todo PC debería tener

    Que es la tecla TAB

    Cifrado | Seguridad Local

    Maximiza tu productividad: Descubre el sistema interactivo que revolucionará la gestión de proyectos en tu empresa

    Cómo limpiar la unidad C de archivos innecesarios

    Como jugar online y resolver un sudoku

    Que es la tecla TAB

    Cómo deshabilitar la desfragmentación de SSD y HDD en Windows 10 y 11

    Benefits Of Vertical Dual Monitors For Coding And Programming

    AMD ha identificado la causa de la quema de los procesadores Ryzen 7000 y ha lanzado un nuevo AGESA para corregir el problema

    Cifrado | Seguridad Local

    Descubre el misterioso mundo del hash de archivos: ¡todo lo que necesitas saber!

    Virus en el sistema DataLife Engine (DLE) y cómo tratarlos

    La ciberseguridad: Vital Para Las Apuestas Online en España

    ¡Descubre las tendencias más emocionantes en el mundo de los videojuegos!

    ¿Aburrido de tu viejo televisor? Descubre las últimas tendencias en televisores

    Generador de Video IA: La Revolución en la Creación Audiovisual

    Los últimos celulares para que estés a la última

  • Estilo de vida
    1. Entrenamiento
    2. Maquillaje
    3. Dieta
    4. Moda
    5. Trucos y tips
    6. Ver todo

    Desarrolla un cuerpo fuerte y saludable

    ¿Qué es la forma física?

    Mejora los resultados de tu entrenamiento de estabilidad y fuerza

    Consejos para maximizar las caminatas diarias

    ¿Por qué es importante preparar la piel antes de maquillarla?

    Consejos para aplicar pestañas postizas

    Consejos para una piel perfecta este invierno

    La nutrición y un cabello saludable

    Cosas que le pasan a tu cuerpo cuando comes salmón todos los días

    Batidos de proteínas pueden ayudar a mejorar sus hábitos alimenticios

    Batidos de proteinas - Una guía para principiantes

    Snacks nutritivos para cada antojo

    Inspiración de traje de otoño

    La dura verdad sobre las modelos de talla grande

    Razones por las que las marcas de moda de lujo son tan caras

    Cuales son las mejores frutas para adelgazar

    Como enseñar a leer y a escribir

    Como generar cuentas Disneyplus

    Calcular porcentajes con la Calculadora de Windows 10

    Bricolaje para la decoración del hogar

    Top 10 de posturas de yoga

    ¿Por qué es importante preparar la piel antes de maquillarla?

    Inspiración de traje de otoño

    Consejos de belleza para lucir fresca en el verano

  • Marketing

    ¿Sirven de algo los diseñadores Web?… ¿y los redactores de contenido?

    ¿Qué es un Link Dofollow?

    ¿Qué es Nofollow?

    ¿Qué es el remarketing?

    ¿Qué es el posicionamiento web (SEO) y lo necesito para mi sitio web?

  • Juegos

    Para qué se pueden usar las Gafas VR PS4

    La nueva generación de realidad virtual de PlayStation®VR2 y PlayStation®5

    Colaboración entre Sony INZONE y EXCEL Esports

    Sony prohíbe cuatro juegos de terceros en Xbox

    Prepárate para el futuro: Project Trinity llega a finales de 2024

  • Herramientas
Búsqueda extendida

Escriba arriba y presione Enter para buscar.

¡Bienvenido de nuevo!

Inicie sesión o Regístrate ahora

VK

o con Email

¿Has olvidado tu contraseña?

Diseño Web » no-cache y ETags, la mejor caché de navegador para HTML

no-cache y ETags, la mejor caché de navegador para HTML


0 Agosto 08, 2019
Compartir

Compartir
Twitter Pinterest LinkedIn Tumblr WhatsApp Email
no-cache y ETags, la mejor caché de navegador para HTMLCuándo se habla de velocidad de carga y rendimiento web, es muy común que se recomiende dejar que el cliente almacene en caché tanto como pueda y durante el máximo tiempo posible.

La cosa tiene su lógica: un recurso en caché estará disponible de forma instantánea, no hay nada que solicitar al servidor ni nada que descargar. El lo quiere y lo tiene.

La caché client-side es controlada mediante cabeceras HTTP incluidas en la respuesta del servidor. Las cabeceras relacionadas con la caché se pueden dividir en dos grupos:

  1. Cabeceras de caché propiamente dichas: expires y cache-control. Con cualquiera de ellas se dice al navegador durante cuánto tiempo un recurso descargado será válido. No es sólo que no lo tenga que descargar durante ese tiempo, es que ni siquiera tiene por qué solicitarlo de nuevo al servidor durante ese período.
  2. Cabeceras de validación de respuesta: Last-modified y ETags. Con estas cabeceras, el cliente puede determinar, aún cuándo un recurso en caché haya caducado, si es necesario volver a descargarlo.
Imagina que a un archivo CSS le ponemos una caché válida de un año. Durante ese año, cada vez que el navegador se encuentre una referencia a ese archivo, va a utilizar la copia en local. Después de ese año, volverá a solicitarlo al servidor y, si las cabeceras de validación le dicen que el recurso sigue siendo el mismo que tiene, no lo descargará, utilizará la copia en local y volverá a renovar el período de caché. Si el recurso ha cambiado, descargará la nueva versión y a esta nueva descarga le aplicará el período de caché.


Hay que elegir una cabecera de cada grupo, una de tiempo de caché y una de validación, elegir dos de un mismo grupo es redundante e innecesario. Yo utilizo cache-control y ETags. Y cache-control lo establezco en no-cache, el por qué es lo que voy a intentar explicar en este post.

¿Cómo controlar que el recibe los recursos actualizados?


Todo esto está muy bien para recursos estáticos: CSS, JS, imágenes y cualquier recurso de similar naturaleza estática que se os ocurra. Hay que tener muy claro que significa estático en este contexto, y significa sencillamente que son recursos que NUNCA cambian.

Pero no es del todo verdad. Estos recursos estáticos cambian. Pero tras el cambio, estrictamente hablando, ya son recursos diferentes y la URL de su localización debería igualmente cambiar. Por ejemplo, una imagen actualizada debe cambiar el nombre de su archivo, por ejemplo de imagen.webp a imagen-v2.webp, o un archivo CSS puede solicitarse con strings de versión (si trabajas con WordPress, acuérdate siempre de utilizar el parámetro de versión en wp_enqueue_script() y wp_enqueue_style()).

Si cambia la URL de solicitud, el navegador ya lo toma como lo qué es, algo nuevo. El ciclo de caché – validación comienza otra vez. Así que, a través del nombre y/o URL de los recursos estáticos, es fácil asegurarse que el recibe lo último en todo momento.

¿Es estático un documento HTML?


Al contrario de lo que muchos puedan pensar, un documento HTML no es un recurso estático.

Pongamos un ejemplo muy sencillo para que se entienda. Puedes tener un artículo en un documento HTML que tenga insertada la imagen de nombre imagen.webp. Es necesario actualizar el artículo, la información que proporciona la imagen está desactualizada, así que insertas imagen-v2.webp. Puede incluso que elimines el antiguo archivo imagen.webp del servidor.

Si el HTML está en la caché del navegador, seguirá conteniendo la referencia al antiguo imagen.webp. Así de mal.

Es un ejemplo muy básico pero espero que se entienda por qué un documento HTML debe considerarse como un recurso dinámico no apto para almacenarse en caché. (Por supuesto hablando en un contexto general, puede que en contextos muy concretos un documento HTML se comporte de forma verdaderamente estática, pero eso, casos muy concretos).

A los que os veáis tentados a pensar que una caché corta, por ejemplo de 5 minutos, otorgaría algo de mejora para el y que el mal sería menor, al menos de corta duración, olvidadlo. Yo no lo recomiendo en absoluto. ¿Qué parte de que un documento HTML es dinámico no habéis entendido?

Además, existen situaciones en las que, aún habiendo caducado la caché, el cliente puede mostrar una versión antigua del HTML al . Lo sufrí en primera persona y fue muy frustrante leer como todo el mundo en Internet recomendaba cachear el HTML client-side y a la vez saber que algunos s podrían estar viendo documentos caducados.

Trabajo en una web sobre ciencia dónde nos gusta ser muy exactos. Las actualizaciones de los artículos están a la orden del día y ser veraces es una prioridad. Que un pueda perderse actualizaciones no es una opción viable. Motivo que vuelve a reforzar la idea: un documento HTML tiene naturaleza dinámica.

no-cache y ETags, una combinación perfecta


Si la posibilidad de que un vea un HTML caducado no es viable, debemos asegurar que su cliente de navegación no lo guarda en caché:
<meta http-equiv="Cache-control" content="no-cache" />
Cache-Control: no-cache
Sin embargo, todavía hay espacio para optimizar la experiencia del con los sistemas de validación, como los ETags, y evitar que tenga que descargar repetidamente un documento que sigue siendo el mismo y que no ha cambiado nada.

Con los ETags, la primera vez que el cliente solicita el HTML, el servidor se lo da, junto con un token de validación, un número único asociado al documento servido. Este token es el Entity Tag. Si cambia el documento, ese token cambia.

La segunda y siguientes veces que se solicite el mismo documento, como no hay nada de caché, el cliente vuelve a hacer la solicitud pero ahora envía el token de identificación que recibió antes. El servidor lo comprueba y, si es el mismo, responderá con un status 304 Not Modified. El cliente puede cerrar la conexión sin descargar de nuevo el HTML.

Se trata, por tanto, de la mejor forma de asegurarnos que nuestros s siempre reciben el HTML actualizado, sin retrasos ni posibles versiones antiguas, a la vez que ofrecemos la mejor experiencia al durante su sesión de navegación.

Esto mismo es aplicable a otros documentos de naturaleza similar; por ejemplo, archivos txt, XML, etc.

Esta sería la configuración de cabeceras, para mí y por ahora, idónea para este tipo de recursos (ejemplo para .htaccess):
<FilesMatch ".(html|htm|rtf|rtx|svg|svgz|txt|xsd|xsl|xml|HTML|HTM|RTF|RTX|SVG|SVGZ|TXT|XSD|XSL|XML)$">
    FileETag MTime Size
    <IfModule mod_headers.c>
        Header set Cache-Control "no-cache"
        Header unset Last-Modified
    </IfModule>
</FilesMatch>
Para documentos HTML que puedan contener información privada, sin embargo, se debería bloquear completamente el almacenamiento local aunque se pierda la capacidad de respuesta 304 Not Modified:
Header set Cache-Control "max-age=0, private, no-store, no-cache, must-revalidate"

Por último, os dejo con este documento de Google Developers dónde explican todo esto y otras muchas cosas interesantes: Mas información sobre cache...
Síguenos en
Google News Flipboard
  • 100
  • 1
  • 2
  • 3
  • 4
  • 5
Cómo y cuándo utilizar el atributo title
Cómo citar en HTML: blockquote, q y cite
Tutoriales En Linea
Tutoriales En Linea
  • Website
  • Facebook
  • Twitter
  • LinkedIn
  • Pinterest
  • Instagram

Sobre mi: CEO de Tutoriales En Linea:
https://tutorialesenlinea.futbolgratis.org
Fundador y CEO de Tutoriales En Linea...Leer mas...

Artículos Relacionados


El elemento header

El elemento header

Cómo y cuándo utilizar el atributo title

Cómo y cuándo utilizar el atributo title

Cómo citar en HTML: blockquote, q y cite

Cómo citar en HTML: blockquote, q y cite


Comentarios



Información
s que no esten registrados no pueden dejar comentarios, te invitamos a que te registre!

Destacados

Lista IPTV con canales para colombia

Mayo 23 43 996

Como instalar SS IPTV en una Smart Tv Samsung

Ene 22 10 390

Como podemos conseguir proxies

Jun 21 11 622

Historia de los sistemas operativos

Mayo 16 31 069

Lo mas leidos

Herramientas SEO para posicionamiento de nuestra web 2024

Por 17-06-24

Herramienta online de generador de datos estructurados

Por Tutoriales En Linea 17-06-24

Las 7 mejores páginas para descargar películas en .torrent en español

Por 26-09-24

Etiquetas





Sobre nosotros

Tutoriales En Linea

¡Bienvenidos a Tutoriales En Línea, el sitio web perfecto para encontrar todas las herramientas necesarias para mejorar tus habilidades de forma gratuita! En Tutoriales En Linea se encuentran tutoriales, cursos online y aprendizaje de calidad, muy útiles para desarrollar tus capacidades... Leer mas...

Tiene una pregunta? ar...

Enlaces

  • Sobre nosotros
  • Ultimos tutoriales
  • Publicar tutorial
  • Ver mas temas
  • Ultimos comentarios
  • ¿Preguntas Frecuentes?
  • Derechos de autor
  • Politica de cookies
  • Nuestro equipo
  • Normas

Herramientas online

  • Buscador de recetas
  • Prueba de diseño web
  • Codificar en binarios, hexadecimales...
  • Cual es mi IP
  • Test de velocidad
  • Editor HTML
  • Test de escritura
  • Test de nutricion
  • Descargar Videos
  • Generador de datos estructurados

Recursos

  • Analisis de tus problemas de SEO
  • Herramientas SEO
  • Generar palabras claves
  • Referencia de CSS3
  • Convertir HTML a XML
  • Acortador de URL
  • Selector de colores
  • Contador de palabras
  • Comprimir imagenes
  • Conversor a URI de datos
  • Suscribirse
Facebook Twitter Instagram Pinterest Linkedin Youtube
  • Anunciarse
  • Socios externos
  • Política de privacidad
  • Términos y Condiciones
  • Sobre nosotros
  • ar
© Tutoriales En Linea. Reservados todos los derechos, queda prohibida la reproducción parcial o total sin previa autorización.