理解缓存分级cache hierarchies

缓存分级是由彼此能够相互通信的各级缓存组成的,ATS支持几种类型的缓存分级。所有的缓存分级都有父子缓存概念。

父缓存位于缓存分级的较高级别,ATS能将请求转发(farward)转发给它。子缓存就是将ATS作为父缓存的缓存。

ATS支持父缓存和ICP两种形式的缓存选项。

父级缓存Parent Caching

假如ATS节点在自身缓存中找不到请求对象,那么它将查询父缓存,父缓存找不到的情况下,会继续查找其它缓存,如果父缓存都找不到,就会回源去取。

你能够配置ATS节点去使用多个父缓存,以便假如某个父缓存不可用时,转而去查询另一个父缓存,依次下去,直至要么能有资源响应该请求,要么在没有更多父缓存的情况下

去源站回源。这种情况叫做父缓存故障转移Parent Failover。ATS支持HTTP和HTTPS的父级缓存。

假如你不想将所有的请求都转发到父缓存,那么可以只简单配置ATS让一部分请求(比如含有特殊URL的那些请求)直接回源,只需要在parent.config中设置

父缓存规则parent proxy rules。

下图描述了一个配置使用父缓存的ATS节点的简单分级缓存,在该场景scenario中,client向分级缓存的ATS子缓存发送请求,子缓存cache
miss,然后子缓存转发请求到父缓存,并cache
hit,父缓存发送内容副本到ATS子缓存,子缓存保存一份,并响应给client。后续对该资源的请求将会直接从子缓存处命中,直至该资源变旧stale或是失效expired

加入请求在父缓存cache miss,父缓存会回源或是从其它缓存获取,依据父缓存的配置而定。父缓存缓存该内容后,将副本返回给子缓存ATS,子缓存缓存后再返回给client。

与remap.config结合

假如要求使用remap规则(配置了proxy.config.reverse_proxy.enabled),当请求到达子节点是,它的remap.config将在parent规则之前处理。这意味着client的请求先安装remap rule转换,

因而任何parent规则将会基于改写后的主机名remapped host name,这不管pristine host
header是否启用(proxy.config.url_remap.pristine_host_hdr)
都成立。父缓存将会接收转换后的请求,因此需要配置去接受该情况。

示例

客户端发送请求到 http://example.com. 上的ATS,发到源站的请求是http://origin.example.com;父节点是parent1.example.com,子节点被配置为反向代理

子缓存节点

remap.config中添加

map http://example.com http://origin.example.com

parent.config中添加

dest_domain=origin.example.com method=get parent="parent1.example.com:80

父缓存节点

remap.config中配置

map http://origin.example.com http://origin.example.com

该例子中,假如 parent1.example.com宕机,子节点在cache miss的情况下,会自动直连源站 origin.example.com

父缓存故障转移Parent Failover

ATS支持使用多个父缓存,这能确保假如一个父缓存不可用时,另一个父缓存能对client请求服务

当你使用多个父缓存配置ATS时,ATS探测到一个父缓存不可用时,会将miss请求发送到另一个父缓存。假如你指定了两个以上的父缓存,父缓存查询次序依赖于你在parent.config中配置parent
proxy rules,默认按照该配置文件中配置的先后次序查询。

配置ATS使用父缓存

为了配置ATS使用一个或多个父缓存,你需要向下面那样详细配置。
注意

你只需要配置子缓存,假设父缓存配置为子缓存的源站,对父缓存不需要额外配置

1.在records.config中开启父缓存选项parent caching option

CONFIG proxy.config.http.parent_proxy_routing_enable INT 1

2.确保你想使用父缓存去服务于 service missed requests。如果另外要使用parent failover,你必须指定一个以上的父缓存,以便当一个父缓存不可用时,请求可以转发到另一个父缓存

3.配置parent.config中的parent proxy rules 

下面的例子配置ATS子缓存将所有path为/viewpoint 和含有正则表达式politics的请求直接发往源站(跳过任何父缓存)

url_regex=politics prefix=/viewpoint go_direct=true

下面的例子配置ATS子缓存将所有以http://host1开头的URL的missed请求转发到父缓存,假如parent1不能服务,就转发到parent2.

因为round-robin=true, ATS会基于client IP address轮询方式遍历父缓存列表

dest_host=host1 scheme=http parent="parent1;parent2" round-robin=strict

运行traffic_ctl config reload命令去让配置变动生效。

ICP Peering

The Internet Cache Protocol (ICP)被代理缓存使用去交换彼此的资源信息,ICP query消息去查询其它缓存是否存有指定的URL?

ICP response消息会应答为hit或miss。缓存只会和自己相邻的,并且能够接收ICP消息的特定ICP peer交换ICP消息。一个ICP缓存可以是一个

sibling缓存(在分级缓存中同级)或是parent缓存(在分级缓存中高一级)

假如ATS开启了ICP caching,那么当HTTP请求cache miss时,它发送ICP query到ICP peers。假如ICP peers都没有hit,但是存在父级缓存,它会使用轮询策略

(round-robin policy)选择一个父缓存。假如没有ICP父缓存存在,ATS会将请求转发到HTTP父缓存。假如没有HTTP父缓存,ATS会转发请求到源站。

为了配置ATS节点作为ICP分级缓存的一部分,你必须执行下面的任务:

  • 确定ATS是否只能接收ICP消息,或者是否发送和接收ICP消息
  • 确定ATS是否可以直接将消息发给每个ICP peer,或者在指定多播通道发送单个消息
  • 指定ICP消息使用的端口
  • 确定能与ATS通信的ICP peer(siblings and parents)

在records.config中配置如下选项来使用ICP分级缓存ICP cache hierarchy

proxy.config.icp.enabled

proxy.config.icp.icp_port

proxy.config.icp.multicast_enabled

proxy.config.icp.query_timeout

配置icp.config,对每个你想识别的ICP peer,给出一条单独的规则

运行traffic_ctl config reload去让配置变动生效

ATS 分级缓存的更多相关文章

  1. ats 分层缓存

    了解缓存层次结构 缓存层次结构由彼此通信的缓存级别组成.ats支持多种类型的缓存层次结构. 所有缓存层次结构都识别父和子的概念. 父缓存是层次结构中较高的缓存, ats可以 将请求转发到该缓存.子缓存 ...

  2. ats显示代理缓存

    如果要将ats用作显示代理缓存,则必须配置客户端软件(即浏览器)以将请求直接发送到ats. 如果没有将ats配置为使用透明度选项(通过交换机或路由器在路由到源服务器的情况下拦截客户端请求并重新路由到a ...

  3. ats缓存规则

    一. 用户访问过程:1. ats收到一个用户对web对象的请求;2. 使用该地址, ats尝试着在其对象数据库(缓存)中用被请求对象的地址来定位该对象;3. 如果对象在缓存中, ats会检查该对象是否 ...

  4. .Net缓存管理框架CacheManager(转)

    转载地址:http://www.cnblogs.com/JustRun1983/p/CacheManager.html Cache缓存在计算机领域是一个被普遍使用的概念.硬件中CPU有一级缓存,二级缓 ...

  5. .Net缓存管理框架CacheManager

    using System; using CacheManager.Core; namespace ConsoleApplication { class Program { static void Ma ...

  6. Web开发基本准则-55实录-缓存策略

    续上篇<Web开发基本准则-55实录-Web访问安全>. Web开发基本准则-55实录-缓存策略 郑昀 创建于2013年2月 郑昀 最后更新于2013年10月26日 提纲: Web访问安全 ...

  7. Apache Traffic Server(ats)

    零.前言1.官网 http://trafficserver.apache.org/2.国内社区 https://blog.zymlinux.net3.简洁明了的配置:http://blog.csdn. ...

  8. 5个强大的Java分布式缓存框架推荐

    在开发中大型Java软件项目时,很多Java架构师都会遇到数据库读写瓶颈,如果你在系统架构时并没有将缓存策略考虑进去,或者并没有选择更优的 缓存策略,那么到时候重构起来将会是一个噩梦.本文主要是分享了 ...

  9. ATS日志说明

    在ATS日志中我们经常遇到形形色色的缓存结果码,为了更清晰地认识它们,相关资料整理到这里: TCP_HIT 请求对象的一份合法拷贝被缓存,ATS将发送该对象给client TCP_MISS 请求对象未 ...

随机推荐

  1. GCC编译选项 -OX[转]

    作者:知乎用户链接:https://www.zhihu.com/question/27090458/answer/137944410来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请 ...

  2. 【iOS】控件截图、MP4格式视频流和m3u8格式视频流截取某一帧功能的实现

    最近开发遇到一个点击按钮实现直播视频流截屏的功能,去网上查了一下资料,总结了一下iOS中截屏相关的知识,然后自己做了个demo. demo主要实现了3种截屏方法,分别对应三种不同的应用场景. 1.im ...

  3. webpack编译流程漫谈

    前言 weback在web构建工具的激烈竞争中逐渐脱引而出. 无论是编译速度.报错提示.可扩展性等都给前端开发者耳目一新的感觉.本篇文章是个人对webpack的一点小研究总结. webpack在开发者 ...

  4. [51nod1299]监狱逃离

    到现在还是不会写系列,直接贴题解了. http://www.51nod.com/question/index.html#!questionId=1157 #include<cstdio> ...

  5. B. OR in Matrix

    B. OR in Matrix time limit per test 1 second memory limit per test 256 megabytes input standard inpu ...

  6. HDU--2017

    字符串统计 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Subm ...

  7. python笔记一(正则表达式)

    #!/usr/bin/env python # -*- coding: utf-8 -*- # 1 如果直接给出字符,则表示精确匹配 # 2 \d 表示数字, \w 表示字母或数字, . 可以匹配任意 ...

  8. Sass嵌套

    Sass 中还提供了选择器嵌套功能,但这也并不意味着你在 Sass 中的嵌套是无节制的,因为你嵌套的层级越深,编译出来的 CSS 代码的选择器层级将越深,这往往是大家不愿意看到的一点. 选择器嵌套为样 ...

  9. PhpStorm中报 “Cannot run program git.exe, 系统找不到指定的文件” 

    http://blog.csdn.net/lamp_yang_3533/article/details/52003021 在使用PhpStorm的GitHub或Git功能时,经常会出现以下错误信息: ...

  10. 如何判断NSDictionary是否包含某个键

    方法一: if([[dictionary allKeys] containsObject:key){     // contains key} 方法二: if([dictionary objectFo ...