Loading... <blockquote><em>事情的起因是因为有些网站访问速度很慢,所以准备给家里网络环境提提速。说到网络提速,我想很多人会第一时间想到bbr,不过这次主要不是讨论bbr,而是历史悠久又有活力的Squid!那Squid功能有哪些,又是怎么实现提速的呢,首先得有个这样的问题概念,再往下看。</em></blockquote> <h2>Squid简介</h2> <p class="p1">Squid是一种流行的代理服务器软件,它可以被用来缓存和过滤网络流量。Squid可以用于提高网络性能,减少网络带宽的使用,并提供更好的安全性和隐私保护。Squid可以运行在各种操作系统上,包括Linux、Unix、Windows等。它也支持各种协议,如HTTP、HTTPS、FTP等。Squid的配置和管理相对简单,可以通过文本文件进行配置。许多大型组织和企业使用Squid作为他们的代理服务器,以提供更快速和可靠的网络连接。</p> 如上简介内容是由ChatGPT提供,我插播一下,“Squid的配置和管理相对简单” 这个只是对于强大的ChatGPT而言,真实配置情况还是比较复杂的。 <h2>目的及实现方式</h2> <strong>目的:</strong>能够在笔记本中,无感访问web网站,包括http和https,访问速度能够尽可能的得到提升。 <strong>实现方式: </strong>dns分流+dns缓存+squid缓存静态文件,后面实现本篇只讲Squid代理缓存,需要了解dns分流+dns缓存,请搜索关注我微信公众号“凯峰的日志”。 <h2>Squid缓存原理介绍</h2> 在介绍后续实现之前,先介绍下实现原理,只有了解了原理,才能更好的进行配置,已达目的。 首先是最基本的web浏览器访问页面时候会经过哪些环节,原理也比较简单。先DNS解析网站ip,再访问网站地址,正常一般也会涉及CDN进行缓存一些静态文件。应用接口一般都先经过负载均衡再到APP服务器,APP服务器在调其他中间件。(大致如下图) <span class="external-link"><a class="no-external-link" href="https://storage.bbcking5.com/%E6%96%87%E7%AB%A0%E5%86%85%E9%83%A8%E5%9B%BE/Squid%E9%80%8F%E6%98%8E%E4%BB%A3%E7%90%86%E7%BC%93%E5%AD%982/web%E8%AE%BF%E9%97%AE%E5%8E%9F%E7%90%86.jpg-wuxingyuwordpresspic" target="_blank"><i data-feather="external-link"></i><img class="aligncenter" src="https://storage.bbcking5.com/%E6%96%87%E7%AB%A0%E5%86%85%E9%83%A8%E5%9B%BE/Squid%E9%80%8F%E6%98%8E%E4%BB%A3%E7%90%86%E7%BC%93%E5%AD%982/web%E8%AE%BF%E9%97%AE%E5%8E%9F%E7%90%86.jpg-wuxingyuwordpresspic" alt="web访问原理.jpg" style=""></a></span> Squid实现透明代理缓存,其实就是在浏览器之前加了一层代理用于缓存静态文件,有点类似于放在家中的CDN的感觉。区别在于CDN一般都会有单独的域名TLS加持,CDN的SSL配置和app的TLS配置都可以由自己掌控。相对还是不用考虑太多,实现起来也容易很多。 放在家中的Squid代理缓存,对于http无需进行TLS握手,实现起来也相对于简单。这里主要针对需要TLS握手的https代理缓存的原理进行讲解。一共分为三端,分别为客户端,代理端,服务端。总的来说是客户端和代理端单独建立tcp和tls连接,代理端和服务端再单独建立tcp和tls连接。数据的交互也是由代理端为界两头单独建立交互。这里可能有人疑惑,代理端到服务端的TLS连接好理解,无非就是代理端正常访问呗,但是请求的内容是客户端发起的,而且TLS交互可是加密的,代理端是如何知道的呢?这是因为代理端会使用自己的CA机构,每当客户端开始建立TLS交互时候,会进行拦截,然后给客户端伪造一个https证书进行TLS连接,和服务端建立真正的TLS连接。这样就实现了,客户端发过来的数据,代理端可以解密,获取请求,再发给服务端,服务端发送数据到代理端,代理端再使用自己的证书进行加密发送给客户端。 (下图使用Charles,原理一致) <span class="external-link"><a class="no-external-link" href="https://storage.bbcking5.com/%E6%96%87%E7%AB%A0%E5%86%85%E9%83%A8%E5%9B%BE/Squid%E9%80%8F%E6%98%8E%E4%BB%A3%E7%90%86%E7%BC%93%E5%AD%982/charles.jpg-wuxingyuwordpresspic" target="_blank"><i data-feather="external-link"></i><img class="aligncenter" src="https://storage.bbcking5.com/%E6%96%87%E7%AB%A0%E5%86%85%E9%83%A8%E5%9B%BE/Squid%E9%80%8F%E6%98%8E%E4%BB%A3%E7%90%86%E7%BC%93%E5%AD%982/charles.jpg-wuxingyuwordpresspic" alt="charles.jpg" style=""></a></span> <h2>Squid代理实现</h2> <blockquote><em>这里使用OPNsense纯粹图省事,很多Squid自定义配置,在这个系统里看不到。建议第一次入门可以直接在OPNsense系统上测试使用。了解完配置基础,框架结构再接触Squid配置文件。</em></blockquote> <ul> <li>安装操作系统OPNsense</li> </ul> 参考<a href="https://pfschina.org/wp/" rel="home">鐵血男兒的BLOG</a>。 <ul> <li>安装并配置Squid代理</li> </ul> 透明代理缓存主要配置分为三大块,CA,防火墙,缓存。最复杂的就是配置缓存了,放最后。 第一步:Squid安装,系统 --> 固件 --> 软件包搜索Squid --> 安装 <span class="external-link"><a class="no-external-link" href="https://storage.bbcking5.com/%E6%96%87%E7%AB%A0%E5%86%85%E9%83%A8%E5%9B%BE/Squid%E9%80%8F%E6%98%8E%E4%BB%A3%E7%90%86%E7%BC%93%E5%AD%982/Squid1-1.jpg-wuxingyuwordpresspic" target="_blank"><i data-feather="external-link"></i><img class="aligncenter" src="https://storage.bbcking5.com/%E6%96%87%E7%AB%A0%E5%86%85%E9%83%A8%E5%9B%BE/Squid%E9%80%8F%E6%98%8E%E4%BB%A3%E7%90%86%E7%BC%93%E5%AD%982/Squid1-1.jpg-wuxingyuwordpresspic" alt="Squid1-1.jpg" style=""></a></span> 第二步:创建CA证书颁发机构,系统 --> 证书 --> 颁发机构 --> 方法(创建一个内部证书颁发机构),内容默认,需要填写的随意填写。 创建中间证书颁发机构,再次创建,方法选择(创建中间证书颁发机构),签署证书颁发机构选择之前创建的机构。 为什么要创建中间机构?这是官方推荐做法,当然实测试下来,没有中间机构确实存在无法建立TLS连接的问题。参考官方配置https://wiki.squid-cache.org/ConfigExamples/Intercept/SslBumpWithIntermediateCA <span class="external-link"><a class="no-external-link" href="https://storage.bbcking5.com/%E6%96%87%E7%AB%A0%E5%86%85%E9%83%A8%E5%9B%BE/Squid%E9%80%8F%E6%98%8E%E4%BB%A3%E7%90%86%E7%BC%93%E5%AD%982/Squid1-2.jpg-wuxingyuwordpresspic" target="_blank"><i data-feather="external-link"></i><img class="aligncenter" src="https://storage.bbcking5.com/%E6%96%87%E7%AB%A0%E5%86%85%E9%83%A8%E5%9B%BE/Squid%E9%80%8F%E6%98%8E%E4%BB%A3%E7%90%86%E7%BC%93%E5%AD%982/Squid1-2.jpg-wuxingyuwordpresspic" alt="Squid1-2.jpg" style=""></a></span> 第三步:启动代理,添加防火墙 <span class="external-link"><a class="no-external-link" href="https://storage.bbcking5.com/%E6%96%87%E7%AB%A0%E5%86%85%E9%83%A8%E5%9B%BE/Squid%E9%80%8F%E6%98%8E%E4%BB%A3%E7%90%86%E7%BC%93%E5%AD%982/Squid1-3.jpg-wuxingyuwordpresspic" target="_blank"><i data-feather="external-link"></i><img class="aligncenter" src="https://storage.bbcking5.com/%E6%96%87%E7%AB%A0%E5%86%85%E9%83%A8%E5%9B%BE/Squid%E9%80%8F%E6%98%8E%E4%BB%A3%E7%90%86%E7%BC%93%E5%AD%982/Squid1-3.jpg-wuxingyuwordpresspic" alt="Squid1-3.jpg" style=""></a></span> <span class="external-link"><a class="no-external-link" href="https://storage.bbcking5.com/%E6%96%87%E7%AB%A0%E5%86%85%E9%83%A8%E5%9B%BE/Squid%E9%80%8F%E6%98%8E%E4%BB%A3%E7%90%86%E7%BC%93%E5%AD%982/Squid1-4.jpg-wuxingyuwordpresspic" target="_blank"><i data-feather="external-link"></i><img class="aligncenter" src="https://storage.bbcking5.com/%E6%96%87%E7%AB%A0%E5%86%85%E9%83%A8%E5%9B%BE/Squid%E9%80%8F%E6%98%8E%E4%BB%A3%E7%90%86%E7%BC%93%E5%AD%982/Squid1-4.jpg-wuxingyuwordpresspic" alt="Squid1-4.jpg" style=""></a></span> <h2>缓存配置</h2> <pre><span class="VIpgJd-yAWNEb-VIpgJd-fmcmS-sn54Q">usage: refresh_pattern [-i] regex min percent max [options]</span></pre> - i:不区分大小写 regex: 正则匹配<span class="long_text">URI</span> <blockquote>其中缓存时间是从`Cache-Control`头中的`max-age`的值或`Expires`头中和当前时间差。</blockquote> <p class="p1">min: 最小的缓存时间,单位为分钟。如果一个对象的缓存时间小于 `min`,则不会被缓存。</p> <p class="p1">max: 最大的缓存时间,单位为分钟。如果一个对象的缓存时间超过 `max`,则会被强制刷新。</p> <p class="p1">percent: 在 `max` 规则下允许对象的缓存时间超过 `max` 的比例。例如,如果 `max` 是 1440 分钟(24 小时),`percent` 是 25,则允许对象的缓存时间超过 24 小时的 25%(6 小时)</p> options: <p class="p1">- `override-expire`: 如果服务器返回的响应头中包含 `Expires` 字段,强制使用 `refresh_pattern` 中设置的时间来刷新缓存。如果未设置 `override-expire`,则 `Expires` 字段优先级高于 `refresh_pattern`。</p> <p class="p1">- `override-lastmod`: 如果服务器返回的响应头中包含 `Last-Modified` 字段,强制使用 `refresh_pattern` 中设置的时间来刷新缓存。如果未设置 `override-lastmod`,则 `Last-Modified` 字段优先级高于 `refresh_pattern`。</p> <p class="p1">- `reload-into-ims`: 通常,当客户端发送带有 `If-Modified-Since` 头部的请求时,Squid 会使用已有的缓存来响应请求。如果设置了 `reload-into-ims`,则 Squid 将从源服务器重新获取对象,并将 `If-Modified-Since` 头部添加到请求中,以使得下一次请求能够从缓存中响应。</p> <p class="p1">- `ignore-reload`: 忽略来自客户端的 `Cache-Control: no-cache`、`Pragma: no-cache` 等请求头部,强制使用缓存。</p> <p class="p1">- `ignore-no-store`: 忽略来自服务器的 `Cache-Control: no-store` 响应头部,缓存响应结果。这个选项只适用于那些不包含私有信息、不敏感的响应结果。</p> <p class="p1">- `ignore-private`: 忽略来自客户端的 `Cache-Control: private` 等头部,强制缓存私有对象。</p> <p class="p1">- `max-stale=NN`: 允许缓存的响应结果的最大过期时间为 NN 秒。如果缓存中的响应结果已过期但没有超过 NN 秒,Squid 将仍然使用它来响应客户端的请求。</p> <p class="p1">- `refresh-ims`: 在缓存过期之前,使用 `If-Modified-Since` 请求头部更新缓存的响应结果。</p> <p class="p1">- `store-stale`: 在源服务器不可用时,如果缓存中存在过期的响应结果,则使用它来响应客户端的请求,而不是向源服务器发出请求。</p> <p class="p1">这些选项可以组合使用,以实现更精细的缓存控制。需要注意的是,不当的设置可能会导致缓存不正确或不完全,因此应该根据具体情况谨慎使用。</p> <pre class="pure-highlightjs line-numbers"><code class="language-none">#如下是http协议响应头的一部分,都是和http自身缓存相关 cache-control: max-age=2592000 date: Tue, 28 Mar 2023 06:38:38 GMT etag: "61a48a78-11d0" expires: Fri, 21 Apr 2023 10:01:53 GMT last-modified: Mon, 29 Nov 2021 08:08:24 GMT </code></pre> <p class="p1">1. Cache-Control:用于控制缓存的行为。常见的指令有max-age(指定最大缓存时间)、no-cache(禁止缓存,需要向服务器发送请求获取最新内容)、no-store(禁止缓存,不允许缓存任何响应内容)、public(允许任何缓存节点缓存响应内容)等。</p> <p class="p1">2. Date:响应发送的日期和时间。</p> <p class="p1">3. ETag:实体标识符,用于标识响应内容的具体版本。当客户端请求相同资源时,可以将上次请求返回的ETag值与服务器端的进行比较,如果相同则表示资源未发生变化,可以直接使用缓存内容。</p> <p class="p1">4. Expires:指定缓存过期时间,即在该时间之前可以使用缓存内容,之后需要向服务器请求最新内容。</p> <p class="p1">5. Last-Modified:指定资源的最后修改时间。当客户端请求相同资源时,可以将上次请求返回的Last-Modified值与服务器端的进行比较,如果相同则表示资源未发生变化,可以直接使用缓存内容。</p> <h2>日志说明</h2> Squid的日志主要有三种,缓存日志,访问日志,储存日志。 <strong>缓存日志:</strong>这个日志主要是记录一些Squid自身的一些运行情况,TLS连接建立失败也会记录,一般不用太关注。 <strong>访问日志:</strong>记录客户端和代理端的访问情况。 <pre class="pure-highlightjs line-numbers"><code class="language-none">1 192.168.5.10 TCP_MEM_HIT/200 31408 GET https://blog.bbcking5.com/wp-includes/js/jquery/jquery.min.js - HIER_NONE/- application/javascript </code></pre> <ol data-spm-anchor-id="a2c6h.12873639.article-detail.i7.5f8d22a52ScBGs"> <li><span class="long_text"><span data-spm-anchor-id="a2c6h.12873639.article-detail.i15.5f8d22a52ScBGs">响应时间</span><span data-spm-anchor-id="a2c6h.12873639.article-detail.i9.5f8d22a52ScBGs">: 对HTTP响应来说,该域表明squid花了多少时间来处理请求。</span><span data-spm-anchor-id="a2c6h.12873639.article-detail.i11.5f8d22a52ScBGs">在squid接受到HTTP请求时开始计时,在响应完全送出后计时终止。</span>响应时间是毫秒级的。尽管时间值是毫秒级的,但是精度可能是10毫秒。在squid负载繁重时,计时变得没那么精确。</span></li> <li data-spm-anchor-id="a2c6h.12873639.article-detail.i10.5f8d22a52ScBGs"><span class="long_text" data-spm-anchor-id="a2c6h.12873639.article-detail.i13.5f8d22a52ScBGs">客户端地址<span data-spm-anchor-id="a2c6h.12873639.article-detail.i12.5f8d22a52ScBGs">: 该域包含客户端的IP地址,或者是主机名</span></span><span class="long_text">.</span></li> <li><span class="long_text">结果/状态码: 该域包含2个 token,以斜杠分隔。第一个token叫结果码,它把协议和响应结果(例如TCP_HIT或UDP_DENIED)进行归类。这些是squid专有的编码,以TCP_开头的编码指HTTP请求,以UDP_开头的编码指ICP查询。</span><span class="long_text"><span data-spm-anchor-id="a2c6h.12873639.article-detail.i14.5f8d22a52ScBGs">第2个token是HTTP响应状态码(例如200,304,404等)。</span>状态码通常来自原始服务器。在某些情形下,squid可能有义务自己选择状态码.</span></li> <li><span class="long_text">传输size: 该域指明传给客户端的字节数。严格的讲,它是squid告诉TCP/IP协议栈去发送给客户端的字节数。这就是说,它不包括TCP/IP头部的overhead。也请注意,传输size正常来说大于响应的Content-Length。传输size包括了HTTP响应头部,然而Content- Length不包括。</span></li> <li><span class="long_text">请求方式: 该域包含请求方式</span>.</li> <li><span class="long_text">URI: 该域包含来自客户端请求的URI。大多数记录下来的URI实际是URL(例如,它们有主机名)。</span><span class="long_text">在记日志时,squid删掉了在第一个问号(?)之后的所有URI字符,除非禁用了strip_query_terms指令。</span></li> <li><span class="long_text">客户端身份: 无</span></li> <li><span class="long_text">对端编码/对端主机: 对端信息包含了2个token,以斜杠分隔。它仅仅与cache 不命中的请求有关。第一个token指示如何选择下一跳,第二个token是下一跳的地址。当squid发送一个请求到邻居cache时,对端主机地址是邻居的主机名。假如请求是直接送到原始服务器的,则squid会写成原始服务器的IP地址或主机名–假如禁用了log_ip_on_direct。 NONE/-这个值指明squid不转发该请求到任何其他服务器。</span></li> <li><span class="long_text">内容类型: 原始access.log的默认的最后一个域,是HTTP响应的内容类型。 squid从响应的Content-Type头部获取内容类型值。假如该头部丢失了,squid使用一个横杠(-)代替。</span></li> </ol> 以下是对请求结果解释: <p data-spm-anchor-id="a2c6h.12873639.article-detail.i22.5f8d22a52ScBGs"><span data-spm-anchor-id="a2c6h.12873639.article-detail.i23.5f8d22a52ScBGs">TCP_HIT</span></p> Squid发现请求资源的貌似新鲜的拷贝,并将其立即发送到客户端. TCP_MISS Squid没有请求资源的cache拷贝. TCP_REFERSH_HIT Squid发现请求资源的貌似陈旧的拷贝,并发送确认请求到原始服务器.原始服务器返回304(未修改)响应,指示squid的拷贝仍旧是新鲜的. TCP_REF_FAIL_HIT Squid发现请求资源的貌似陈旧的拷贝,并发送确认请求到原始服务器.然而,原始服务器响应失败,或者返回的响应Squid不能理解.在此情形下,squid发送现有cache拷贝(很可能是陈旧的)到客户端. TCP_REFRESH_MISS Squid发现请求资源的貌似陈旧的拷贝,并发送确认请求到原始服务器.原始服务器响应新的内容,指示这个cache拷贝确实是陈旧的. TCP_CLIENT_REFRESH_MISS Squid发现了请求资源的拷贝,但客户端的请求包含了Cache-Control: no-cache指令.Squid转发客户端的请求到原始服务器,强迫cache确认. TCP_IMS_HIT 客户端发送确认请求,Squid发现更近来的、貌似新鲜的请求资源的拷贝.Squid发送更新的内容到客户端,而不联系原始服务器. TCP_SWAPFAIL_MISS Squid发现请求资源的有效拷贝,但从磁盘装载它失败.这时squid发送请求到原始服务器,就如同这是个cache丢失一样. TCP_NEGATIVE_HIT 在对原始服务器的请求导致HTTP错误时,Squid也会cache这个响应.在短时间内对这些资源的重复请求,导致了否命中. negative_ttl指令控制这些错误被cache的时间数量.请注意这些错误只在内存cache,不会写往磁盘.下列HTTP状态码可能导致否定 cache(也遵循于其他约束): 204, 305, 400, 403, 404, 405, 414, 500, 501, 502, 503, 504. TCP_MEM_HIT Squid在内存cache里发现请求资源的有效拷贝,并将其立即发送到客户端.注意这点并非精确的呈现了所有从内存服务的响应.例如,某些cache在内存里,但要求确认的响应,会以TCP_REFRESH_HIT, TCP_REFRESH_MISS等形式记录. TCP_DENIED 因为http_access或http_reply_access规则,客户端的请求被拒绝了.注意被http_access拒绝的请求在第9域的值是NONE/-,然而被http_reply_access拒绝的请求,在相应地方有一个有效值. TCP_OFFLINE_HIT 当offline_mode激活时,Squid对任何cache响应返回cache命中,而不用考虑它的新鲜程度. TCP_REDIRECT 重定向程序告诉Squid产生一个HTTP重定向到新的URI.正常的,Squid不会记录这些重定向.假如要这样做,必须在编译squid前,手工定义LOG_TCP_REDIRECTS预处理指令. NONE 无分类的结果用于特定错误,例如无效主机名. 相应于ICP查询,下列标签可能出现在access.log文件的第四域. UDP_HIT Squid在cache里发现请求资源的貌似新鲜的拷贝. UDP_MISS Squid没有在cache里发现请求资源的貌似新鲜的拷贝.假如同一目标通过HTTP请求,就可能是个cache丢失.请对比UDP_MISS_NOFETCH. UDP_MISS_NOFETCH 跟UDP_MISS类似,不同的是这里也指示了Squid不愿去处理相应的HTTP请求.假如使用了-Y命令行选项,Squid在启动并编译其内存索引时,会返回这个标签而不是UDP_MISS. UDP_DENIED 因为icp_access规则,ICP查询被拒绝.假如超过95%的到某客户端的ICP响应是UDP_DENIED,并且客户端数据库激活了,Squid在1小时内,停止发送任何ICP响应到该客户端.若这点发生,你也可在cache.log里见到一个警告. UDP_INVALID Squid接受到无效查询(例如截断的消息、无效协议版本、URI里的空格等).Squid发送UDP_INVALID响应到客户端. <strong>储存日志:</strong> <pre class="pure-highlightjs line-numbers"><code class="language-none">SWAPOUT 00 00001983 2152703843AA6D14F7C9CEC3F119A577 200 1681297692 1681126511 -1 application/javascript 317/317 GET https://blog.bbcking5.com/wp-content/plugins/tablepress/admin/js/build/quicktags-button.js </code></pre> <ol data-spm-anchor-id="a2c6h.12873639.article-detail.i18.5f8d22a52ScBGs"> <li data-spm-anchor-id="a2c6h.12873639.article-detail.i16.5f8d22a52ScBGs"><span class="long_text"><span data-spm-anchor-id="a2c6h.12873639.article-detail.i17.5f8d22a52ScBGs">动作</span>: cache目标发生的动作.该域有3个可能值:SWAPOUT,RELEASE,和SO_FAIL.</span><span class="long_text"> </span> <ul> <li>SWAPOUT在Squid成功的存储目标到磁盘时发生.某些目标例如那些消极cache的,仅保存在内存而不是磁盘,Squid不会在store.log裡记录它们.</li> <li>SO_FAIL表明Squid不能完整的存储目标到磁盘.多半意味着存储机制拒绝以写方式打开新的磁盘文件.</li> <li>RELEASE在Squid从cache裡删除目标,或首先就决定响应不可存储时发生.</li> </ul> </li> <li><span class="long_text">目录号: 目录号是十进制小数形式,它是个到cache目录的7位索引.对没有存储到磁盘的目标,该域包含-1值.</span></li> <li><span class="long_text">文件号: 文件号是25位的标识符,内在的被squid使用.它被写成8字符的十六进制号.对UFS基础的存储机制没有存储到磁盘的目标,没有有效的文件号.对这些目标,该域的值是FFFFFFFF.仅仅在RELEASE和SO_FAIL情况下才会出现这个值.</span></li> <li><span class="long_text">cache关键字: Squid使用MD5哈希值作为主要的索引来定位目标.该关键字基于请求方式、URI、和其他可能的信息计算得来.可以从cache关键字来查找store.log条目.</span></li> <li><span class="long_text">状态码: 该域显示响应的HTTP状态码,跟access.log一样.</span></li> <li><span class="long_text">日期: HTTP响应的Date头部值,表现为Unix纪元以来的秒数.值-1表示Date头部不可解析,-2意味着头部完缺.</span></li> <li><span class="long_text">最后修改时间: HTTP响应的Last-Modified头部值,表现为Unix纪元以来的秒数.值-1表示Last-Modified头部不可解析,-2意味着头部完缺.</span></li> <li><span class="long_text">过期时间: HTTP响应的Expires头部值,表现为Unix纪元以来的秒数.值-1表示Expires头部不可解析,-2意味着头部完缺.</span></li> <li><span class="long_text">内容类型: HTTP响应的Content-Type头部值,排除了任何media-type参数.假如Content-Type丢失了,Squid插入值unknown.</span></li> <li><span class="long_text">内容长度/大小: 该域包含2个数字,以斜杠分开.第一个是Content-Length头部值. -1表明Content-Length头部不存在.第二个是HTTP消息 body的实际大小.你可使用这2个数字来部分的验证接受到的响应,并验证原始服务器是否不正确的计算了内容长度.大多数情形下,这2个数字相等.</span></li> <li><span class="long_text">方式: 请求目标的HTTP方式,跟access.log里的一样.</span></li> <li><span class="long_text">URI: 最后一个域是请求URI,跟access.log里的一样.该域也有前述章节提到的空格问题.然而,这里不必为此担忧,因为你可安全的忽略任何多余的域.</span></li> </ol> <h2>总结</h2> 代理缓存本身也作为中间人攻击的一种方式,已经被一些技术防范,比如打开Chrom浏览器时候会自动加载大批域名强制绑定CA,火狐浏览器干脆把CA机构做死在自己的APP中,不使用系统中CA证书,这些措施都一定程度上防范了中间人攻击的行为。另外不同网站的用途和设定又不一样,很难实现通吃的完美配置,这里主要作为技术参考实践,深入了解http(s)协议。是否有必要在家搞一套来降低一些延迟,需要从如上情况综合考虑。如下是验证某些缓存生效的监控图,对部分网站效果还是不错的,建议的做法是先想好需要缓存哪些文件,然后对只对这些资源进行缓存,比如jpg、png、mp3、wmv、mpeg、flv、wmv等特定后缀的文件。 <span class="external-link"><a class="no-external-link" href="https://storage.bbcking5.com/%E6%96%87%E7%AB%A0%E5%86%85%E9%83%A8%E5%9B%BE/Squid%E9%80%8F%E6%98%8E%E4%BB%A3%E7%90%86%E7%BC%93%E5%AD%982/Squid1-JK.jpg-wuxingyuwordpresspic" target="_blank"><i data-feather="external-link"></i><img class="aligncenter" src="https://storage.bbcking5.com/%E6%96%87%E7%AB%A0%E5%86%85%E9%83%A8%E5%9B%BE/Squid%E9%80%8F%E6%98%8E%E4%BB%A3%E7%90%86%E7%BC%93%E5%AD%982/Squid1-JK.jpg-wuxingyuwordpresspic" alt="Squid1-JK.jpg" style=""></a></span> <em>借此,提醒一下,话不能乱说,饭不能乱吃,证书不能乱安装,wifi不能乱连。</em> 此文原创,如有参考,请注明出处 https://blog.bbcking5.com ! Last modification:June 4, 2024 © Allow specification reprint Like 如果觉得我的文章对你有用,请随意赞赏