ATS 5.2.1中Background-Fetch插件调研笔记

2024-03-18 15:38

本文主要是介绍ATS 5.2.1中Background-Fetch插件调研笔记,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

简介

这是Apache Traffic Server(简称ATS)中的一个插件, 允许你从源站主动获取Object内容并填充到缓存中, 当你的所有或是大部分client request都是byte-ranged类型时, 这特别有用. 目前ATS并不能缓存byte0-range类型的request/response.

功能

检查回源的响应, 在原始的(客户端)请求满足下面条件时, 是否触发一条background fetch操作:

  • 目前只支持GET请求
  • 响应是206状态码
  • 通过接口TSHttpTxnIsCacheable()判断响应是否可缓存

一旦确定要执行一次background fetch, 我们将去掉Range头, replay客户端请求, 再次通过Traffic Server的Proxy功能, 去回源请求, 这对于original request是透明的, 它会继续进行并不受任何影响.确保每个url最多只能有一次background fetch, 以免给Original Server意外增加额外的压力.

开启插件

在编译时, 开启如下配置选项,就会将plugings/experimental目录下面所有的模块的动态库都编译和安装进系统中

autoconf -i
./configure --enable-experimental-plugins
make

该插件既可以作为一个global插件,也可以作为一个per remap插件, 它后面带一个参数来指定配置文件的路径, 可以是绝对路径,也可以是相对于安装目录的路径.
使用方法:
1.in global mode
在plugin.config中添加一行

background_fetch.so –config background_fetch.config

2.in per remap mode
在remap.config中添加如下到一行特定的改写规则后面, 也就是可以实现对单条转发规则使用

@plugin=background_fetch.so @pparm=background_fetch.config

配置文件的内容

配置文件background_fetch.config中基于任意的Http header or Client-ip, 可以指定包含(include)或是排除(exclude)的规则, 比如

include User-Agent ABCDEF
exclude User-Agent *
exclude Content-Type text
exclude X-Foo-Bar text
exclude ip  1.2.3.4
exclude Client-IP *
exclude Content-Length <1000

尚待添加的功能

限制对某些大小的内容的background fetch

源码分析

和其他插件一样的代码结构, 这里只添加了一个READ_HTTP_RESPONSE_HDR Hook, 下面是基本的函数调用流程

TSPluginInit() ==> cont_handle_response() ==> is_background_fetch_allowed() ==> 
check_field_configured() ==> check_field_configured()\\>cont_check_cacheable()==> data->initialize()\\>data->schedule()

对每个符合要求的http transaction, 会生成一个名为BGFetchData的continuation, 它的回调函数是cont_bg_fetch()
另外里面定义了几个数据结构:
static BgFetchRuleMap是一个全局的配置项数据结构
BGFetchConfig类定义了针对每个url的预取配置, BGFetchData类会引用它
插件一启动时会首先调用BGFetchConfig()来读取配置文件, 如果没有指定的配置文件,就使用全局的.
这里写图片描述

这篇关于ATS 5.2.1中Background-Fetch插件调研笔记的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/822816

相关文章

CnPlugin是PL/SQL Developer工具插件使用教程

《CnPlugin是PL/SQLDeveloper工具插件使用教程》:本文主要介绍CnPlugin是PL/SQLDeveloper工具插件使用教程,具有很好的参考价值,希望对大家有所帮助,如有错... 目录PL/SQL Developer工具插件使用安装拷贝文件配置总结PL/SQL Developer工具插

maven中的maven-antrun-plugin插件示例详解

《maven中的maven-antrun-plugin插件示例详解》maven-antrun-plugin是Maven生态中一个强大的工具,尤其适合需要复用Ant脚本或实现复杂构建逻辑的场景... 目录1. 核心功能2. 典型使用场景3. 配置示例4. 关键配置项5. 优缺点分析6. 最佳实践7. 常见问题

javascript fetch 用法讲解

《javascriptfetch用法讲解》fetch是一个现代化的JavaScriptAPI,用于发送网络请求并获取资源,它是浏览器提供的全局方法,可以替代传统的XMLHttpRequest,这篇... 目录1. 基本语法1.1 语法1.2 示例:简单 GET 请求2. Response 对象3. 配置请求

MyBatis分页插件PageHelper深度解析与实践指南

《MyBatis分页插件PageHelper深度解析与实践指南》在数据库操作中,分页查询是最常见的需求之一,传统的分页方式通常有两种内存分页和SQL分页,MyBatis作为优秀的ORM框架,本身并未提... 目录1. 为什么需要分页插件?2. PageHelper简介3. PageHelper集成与配置3.

Maven 插件配置分层架构深度解析

《Maven插件配置分层架构深度解析》:本文主要介绍Maven插件配置分层架构深度解析,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录Maven 插件配置分层架构深度解析引言:当构建逻辑遇上复杂配置第一章 Maven插件配置的三重境界1.1 插件配置的拓扑

Idea插件MybatisX失效的问题解决

《Idea插件MybatisX失效的问题解决》:本文主要介绍Idea插件MybatisX失效的问题解决,详细的介绍了4种问题的解决方法,具有一定的参考价值,感兴趣的可以了解一下... 目录一、重启idea或者卸载重装MyBATis插件(无需多言)二、检查.XML文件与.Java(该文件后缀Idea可能会隐藏

利用Python快速搭建Markdown笔记发布系统

《利用Python快速搭建Markdown笔记发布系统》这篇文章主要为大家详细介绍了使用Python生态的成熟工具,在30分钟内搭建一个支持Markdown渲染、分类标签、全文搜索的私有化知识发布系统... 目录引言:为什么要自建知识博客一、技术选型:极简主义开发栈二、系统架构设计三、核心代码实现(分步解析

一文详解JavaScript中的fetch方法

《一文详解JavaScript中的fetch方法》fetch函数是一个用于在JavaScript中执行HTTP请求的现代API,它提供了一种更简洁、更强大的方式来处理网络请求,:本文主要介绍Jav... 目录前言什么是 fetch 方法基本语法简单的 GET 请求示例代码解释发送 POST 请求示例代码解释

IDEA常用插件之代码扫描SonarLint详解

《IDEA常用插件之代码扫描SonarLint详解》SonarLint是一款用于代码扫描的插件,可以帮助查找隐藏的bug,下载并安装插件后,右键点击项目并选择“Analyze”、“Analyzewit... 目录SonajavascriptrLint 查找隐藏的bug下载安装插件扫描代码查看结果总结Sona

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学