首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

如何在CentOS 7上使用Nginx模块实现浏览器缓存

本教程,我们将了解如何使用Nginx模块来实现浏览器缓存。 准备 要学习本教程,您需要: 一台已经设置好可以使用sudo命令的非root账号的CentOS服务器,并且已开启防火墙。...通过适当地命名文件,我们可以欺骗Nginx,例如,一个完全空的文件是一个图像而另一个是样式表。 使用truncate创建test.html默认Nginx目录命名的文件。...使用Web浏览器,如果浏览器想要再次请求相同的文件(例如,刷新页面),则会将ETag值存储并发送回带有If-None-Match请求的服务器。 我们可以使用以下命令命令行上模拟它。...确保更改此命令ETag值以匹配先前输出ETag值。...模块是核心Nginx模块,这意味着它不需要单独安装即可使用。 要添加标题模块,请在vi或您喜欢的文本编辑器打开默认服务器块Nginx配置文件。

1.4K00

如何在Ubuntu 16.04上使用Nginx模块实现浏览器缓存

本教程,我们将了解如何使用Nginx模块来实现浏览器缓存。 准备 要学习本教程,您需要: 一台已经设置好可以使用sudo权限的非root账号的Ubuntu 16.04服务器,并且已开启防火墙。...没有服务器的同学可以在这里购买,不过我个人更推荐您使用免费的腾讯云开发者实验室进行试验,学会安装后再购买服务器。 服务器上安装Nginx。 除了模块,我们还将在本文中使用Nginx的地图模块。...使用Web浏览器,如果浏览器想要再次请求相同的文件(例如,刷新页面),ETag则会将值存储并发送回带有If-None-Match请求的服务器。 我们可以使用以下命令命令行上模拟它。...确保更改ETag命令的值以匹配先前输出的值ETag。...模块是核心Nginx模块,这意味着它不需要单独安装即可使用。 要添加标题模块,请用您喜欢的文本编辑器打开在nano的默认的Nginx配置文件。

1.4K30
您找到你想要的搜索结果了吗?
是的
没有找到

网页性能优化浅谈与实践

[TOC] 0x00 前言简述 0x01 网页性能优化关键点 数据缓存 描述: 当我们访问某一个网页浏览器第一次加载网页,会将页面资源存储 HTTP缓存。...通常 cache-control 被认为是一种比 expires(到期) 更现代,更灵活的方法,但是两个可以同时使用。 Q: 如何进行缓存?...答: 通过标识资源或资源类型(例如图像或CSS文件),然后使用所需的缓存选项指定资源的,来启用缓存。...---- (1) 缓存控制 Tips : Cache-Control除了响应中使用,在请求也可以使用 1.用开发者工具来模拟下请求带上Cache-Control:勾选Disable cache,刷新页面...使用更新且更灵活的高速缓存控制expires通常用作备用。 Tips : Pragma 是旧产物,已经逐步抛弃,有些网站为了向下兼容还保留了这两个字段。

57920

每天学一个 Linux 命令(73):curl

命令简介 curl 命令使用 HTTP、HTTPS、FTP、FTPS、SCP、SFTP、TFTP、DICT、TELNET、LDAP或FILE支持的协议之一,将数据传输到网络服务器或从网络服务器传输数据...它非常适合在 Shell 脚本中使用。 curl 命令提供代理支持,用户身份验证,FTP 上传,HTTP 发布,SSL 连接,cookie,文件传输恢复,metalink 和其他功能。...选项说明 -A #用户代理 -b #发送 Cookie 信息 -c #将 Cookie 写入文件 -d #发送 POST 请求的数据体 -e #设置 HTTP 的 Referer 字段 -...F #向服务器上传文件 -G #构造 URL 的查询字符串 -H #添加 HTTP 请求的 -i #打印服务器回应的 HTTP -I 打印服务器回应的 HEAD -k #跳过.../2.4.6 (CentOS) Last-Modified: Wed, 10 Mar 2021 17:03:20 GMT ETag: "17-5bd31a4e35769" Accept-Ranges:

64920

ETag使用效果对比及经验分享

如果页面没有发生变化时,信息应该如下: ? 我们与技术沟通配置ETag,需要通过此种方式进行验证。...一、Apache Apache根据配置文件的配置来设置Etag值,默认的Apache的FileEtag设置为: FileEtagINode Mtime Size 也就是根据这三个属性来生成Etag...以覆盖默认的Innode MTime Size的ETag,因为默认的ETag使用到的Innode会导致相同的文件分布式服务器上产生的ETag不同。...确认没有使用ngx_headers_more清除ETag:同样配置文件不能出现如下语句的任意一句,如果出现请将其删除。 ? 重新启动Nginx,就启用ETag功能了。...步骤4 请关闭gzip,即将上一步的gzipon;改为gzip off;然后去步骤2。 若不想关闭gzip,并要开启ETag,同时仍要坚持使用当前的Nginx版本,只能修改源码并重新编译。

2.1K90

反向代理的攻击面 (下)

ApacheProxyPass“解析”提取主机值,因此我们可以发送类似GET @evil.com HTTP/1.1的请求,Apache将其视为http://backend_server@evil.com...滥用修改功能 对于反向代理服务器来说,增添,删除和修改后端请求是一项基本功能。有些情况,这比修改后端本身简单的多。有时,反向代理会添加一些重要的安全。...一般来说,反向代理服务器会使用缓存标志,该标志与请求的主机头值和路径相关联。 反向代理对某个响应缓存与否,它会先检查请求的Cache-Control和Set-Cookie。...Nginx发现请求存在/image,于是直接转发该请求值Tomcat,然后缓存响应(Tomcat->Nginx,此时Cache-Control无效)。...Tomcat处理将甄别出/index.jsp,因此攻击者可以强制Nginx缓存任何页面,攻击者仅需更改路径/images/..

1.6K40

使用ETag和Expires调优web服务器性能

2、Web Server发送完Last-Modified/Etag给客户端后,客户端会缓存这些; 3、客户端再次发起相同页面的请求,将分别发送与Last-Modified/Etag对应的Http...A、Expires A.1、Apache Etag 使用Apache的mod_expires 模块来设置,这包括控制应答的Expires内容和Cache-Control的max-age指令 ExpiresActive...其他请参考NginxExpires B.1、ApacheEtag设置 Apache设置Etag的支持比较简单,只用在含有静态文件的目录建立一个文件.htaccess, 里面加入: FileETag...MTime Size 这样就行了,详细的可以参考Apache的FileEtag文档页 B.2、Lighttpd Etag Lighttpd设置Etag支持: etag.use-inode: 是否使用...的功能 第四个参数肯定是要enable的, 前面三个就看实际的需要来选吧,推荐使用修改时间 B.3、 Nginx Etag Nginx默认没有添加对Etag标识.Igor Sysoev的观点”在对静态文件处理上看不出如何

89220

ajax跨域问题

由此可知,跨域仅限于浏览器,是由于浏览器对不同源数据的拦截产生的,跨域有时候是不可避免的,我们需要采取措施实现跨域请求。 ? ?...3.1 被调用方解决 被调用方支持跨域解决思路:基于http协议关于跨域方面的要求而做的修改,从a域名调用b域名b域名返回的信息里加些字段,告诉浏览器b允许a调用。...然后配置虚拟主机,打开nginx的目录,打开conf文件下的nginx.conf文件, 最后添加 include vhost/*.conf; ?...最后输入 nginx -s stop 停止 nginx 3.1.3 apache解决方案 首先打开 apache目下的 conf/httpd.conf 文件,...3.1.4 spring框架解决方案 类或者方法上添加注解 @CrossOrigin 3.2 调用方解决 调用方隐藏跨域解决思路:当域名不是自己公司的,可以用此方法解决。

1.3K20

深入了解加快网站加载时间的 JavaScript 优化技术

Nginx Nginx 配置文件中使用 gzip 或 brotli 指令启用压缩并指定设置。...02)、缓存控制和 ETag 用于控制浏览器缓存的两个重要是 Cache-Control 和 ETag。...例如,可以使用 Cache-Control:public, max-age=3600 表示资源可以缓存一小ETag 为特定版本的资源提供唯一标识符(通常是哈希)。...当浏览器请求资源,它会发送缓存ETag 值。如果服务器的 ETag 值与浏览器发送的值匹配,则服务器响应 304 Not Modified 状态,浏览器使用缓存的版本。...例如, Apache 服务器,您可以使用 .htaccess 文件来设置缓存: 此配置为 CSS、JS、JPG 和 PNG 文件设置 Cache-Control ,允许它们缓存 24 小时。

21930

聊一聊关于加快网站加载时间相关的 JS 优化技术

Nginx Nginx 配置文件中使用 gzip 或 brotli 指令启用压缩并指定设置。...02)、缓存控制和 ETag 用于控制浏览器缓存的两个重要是 Cache-Control 和 ETag。...例如,可以使用 Cache-Control:public, max-age=3600 表示资源可以缓存一小ETag 为特定版本的资源提供唯一标识符(通常是哈希)。...当浏览器请求资源,它会发送缓存ETag 值。如果服务器的 ETag 值与浏览器发送的值匹配,则服务器响应 304 Not Modified 状态,浏览器使用缓存的版本。...例如, Apache 服务器,您可以使用 .htaccess 文件来设置缓存: 此配置为 CSS、JS、JPG 和 PNG 文件设置 Cache-Control ,允许它们缓存 24 小时。

28120

震惊 | HTTP 疫情期间把我吓得不敢出门了

如果 Etag 是资源响应的一部分,则客户端可以未来请求的头中发出 If-None-Match,以验证缓存的资源。...Wiki 页面(发布数据),POST 请求将包含 If-Match ,其中包含 Etag 值以检查有效性。...,这个用来响应预检请求,它发出实际请求可以使用哪些HTTP。...浏览器发出预检请求使用 Access-Control-Request-Headers 请求,使服务器知道发出实际请求客户端可能发送的 HTTP 。...比较两个资源是否相同的版本有些复杂,根据上下文,有两种相等性检查 当期望的是字节对字节进行比较,例如在恢复下载使用Etag进行验证 当用户代理需要比较两个资源是否具有相同的内容使用Etag

5.2K20

HTTP信息的参数Etag

如果是图片是程序生成的,我们可以用 no-cache 这些 header 来控制,但如果这些图片是 apachenginx 等呢?...下面开始介绍 Etag:        EtagHTTP1.1有介绍,主要的作用就是(css file, image, javascript file)文件后面添加一个唯一的参数(相当于查询参数字符串...:max-age和Expires,会同时使用,也就是说完全匹配If-Modified-Since和If-None-Match即检查完修改时间和Etag之后,服务器才能返回304....下面是ApacheEtag的配置 Apache设置Etag的支持比较简单,只需要在apache的配置中加入下面的内容就可以了: FileETag MTime Size 注解:FileETag指令配置了当文档是基于一个文件用以创建...ETag 大型多WEB集群,使用ETag时有问题,所以有人建议使用WEB集群不要使用ETag,其实很好解决, 因为多服务器,INode不一样,所以不同的服务器生成的ETag不一样,所以用户有可能重复下载

2K40

对不起,看完这篇HTTP,真的可以吊打面试官

什么是新鲜的数据 一旦资源存储缓存,理论上就可以永远被缓存使用。...如果 Etag 是资源响应的一部分,则客户端可以未来请求的头中发出 If-None-Match,以验证缓存的资源。...,这个用来响应预检请求,它发出实际请求可以使用哪些HTTP。...浏览器发出预检请求使用 Access-Control-Request-Headers 请求,使服务器知道发出实际请求客户端可能发送的 HTTP 。...比较两个资源是否相同的版本有些复杂,根据上下文,有两种相等性检查 当期望的是字节对字节进行比较,例如在恢复下载使用Etag进行验证 当用户代理需要比较两个资源是否具有相同的内容使用Etag

6.3K21

跟我一起探索 HTTP-HTTP缓存

Expires 或 max-age HTTP/1.0 ,新鲜度过去由 Expires 指定。 Expires 使用明确的时间而不是通过指定经过的时间来指定缓存的生命周期。...为了解决这些问题,ETag 响应被标准化作为替代方案。 ETag/If-None-Match ETag 响应的值是服务器生成的任意值。...备注: 评估如何使用 ETag 和 Last-Modified ,请考虑以下几点:缓存重新验证期间,如果 ETag 和 Last-Modified 都存在,则 ETag 优先。...public 值具有使响应可存储的效果,即使存在 Authorization 。 备注: 只有设置了 Authorization 需要存储响应时才应使用 public 指令。...,以便在重新加载不必重新传输资源。

22451

你还在为 HTTP 的这些概念头疼吗?

尽管通用不会限定于是请求还是响应报文,但是某些通用头大部分或全部用于一种特定类型的请求。也就是说,如果某个通用出现在请求报文中,那么大部分通用都会显示该请求报文中。...这个头中可以出现许多单独的指令,其详细信息可以 RFC 2616 中找到,即使这是常规,某些指令也只能出现在请求或响应。...下表提供了一个 Cache-Control 选项的总结并告诉你如何去使用 “请注意, Cache-Control 头中只能出现一个指令,但是消息可以出现多个这样的。 ?...,使用bytes 来指定 当服务器不能处理客户端发来的请求使用 none 来指定 Accept-Ranges: bytes Accept-Ranges: none Age Age HTTP 响应告诉客户端源服务器多久之前创建了响应...例如下面这种写法 Server: Apache/2.4.1 (Unix) Vary Vary HTTP 响应确定如何匹配请求,以决定是否可以使用缓存的响应,而不是从原始服务器请求一个新的响应。

2.3K30

「HTTP」都给你整理好了

尽管通用不会限定于是请求还是响应报文,但是某些通用头大部分或全部用于一种特定类型的请求。也就是说,如果某个通用出现在请求报文中,那么大部分通用都会显示该请求报文中。...这个头中可以出现许多单独的指令,其详细信息可以 RFC 2616 中找到,即使这是常规,某些指令也只能出现在请求或响应。...下表提供了一个 Cache-Control 选项的总结并告诉你如何去使用 “请注意, Cache-Control 头中只能出现一个指令,但是消息可以出现多个这样的。 ?...,使用bytes 来指定 当服务器不能处理客户端发来的请求使用 none 来指定 Accept-Ranges: bytes Accept-Ranges: none Age Age HTTP 响应告诉客户端源服务器多久之前创建了响应...例如下面这种写法 Server: Apache/2.4.1 (Unix) Vary Vary HTTP 响应确定如何匹配请求,以决定是否可以使用缓存的响应,而不是从原始服务器请求一个新的响应。

5.1K41

【进阶系列】HTTP缓存机制专题

策略         Expires是Web服务器响应消息字段,响应http请求告诉浏览器在过期时间前浏览器可以直接从浏览器缓存取数据,而无需再次请求。...web服务器响应请求,告诉浏览器资源的最后修改时间。     ...• Etag:web服务器响应请求,告诉浏览器当前资源服务器的唯一标识(生成规则由服务器决定)。...ApacheETag的值,默认是对文件的索引节(INode),大小(Size)和最后修改时间(MTime)进行Hash后得到的。     ...HTTP1.1Etag的出现主要是为了解决几个Last-Modified比较难解决的问题:     • Last-Modified标注的最后修改只能精确到秒级,如果某些文件1秒钟以内,被修改多次的话

24940
领券