proxy-cache
proxy-cache 插件提供了根据缓存键缓存响应的功能。该插件支持基于磁盘和基于内存的缓存选项,可缓存 GET、POST 和 HEAD 请求。
可以根据请求 HTTP 方法、响应状态码、请求头值等条件有选择地缓存响应。
示例
以下示例演示了如何在不同场景下配置 proxy-cache。
在磁盘上缓存数据
与内存缓存相比,磁盘缓存策略具有系统重启时数据持久化和存储容量更大的优点。它适用于优先考虑持久性并且可以容忍稍大的缓存访问延迟的应用程序。
以下示例演示了如何在路由上使用 proxy-cache 插件将数据缓存在磁盘上。
使用磁盘缓存策略时,缓存 TTL 由响应头 Expires 或 Cache-Control 的值确定。如果不存在这些响应头,或者 APISIX 由于上游不可用而返回 502 Bad Gateway 或 504 Gateway Timeout,则缓存 TTL 默认为配置文件中配置的值。
创建一个使用 proxy-cache 插件的路由以在磁盘上缓存数据:
curl "http://127.0.0.1:9180/apisix/admin/routes" -X PUT \
-H "X-API-KEY: ${ADMIN_API_KEY}" \
-d '{
"id": "proxy-cache-route",
"uri": "/anything",
"plugins": {
"proxy-cache": {
"cache_strategy": "disk"
}
},
"upstream": {
"type": "roundrobin",
"nodes": {
"httpbin.org": 1
}
}
}'
向路由发送请求:
curl -i "http://127.0.0.1:9080/anything"
你应该会看到 HTTP/1.1 200 OK 响应,并带有以下响应头,表明插件已成功启用:
Apisix-Cache-Status: MISS
由于第一个响应之前没有可用缓存,因此显示 Apisix-Cache-Status: MISS。
在缓存 TTL 窗口内再次发送相同的请求。你应该会看到 HTTP/1.1 200 OK 响应,并带有以下响应头,表明缓存命中:
Apisix-Cache-Status: HIT
等待缓存超过 TTL 后过期,然后再次发送相同的请求。你应该会看到 HTTP/1.1 200 OK 响应,并带有以下响应头,表明缓存已过期:
Apisix-Cache-Status: EXPIRED