反模式:将大于 256 KB 的数据存储在缓存中
您正在查看的是 Apigee Edge 文档。
转到 Apigee X 文档。 信息
Apigee Edge 能够在运行时将数据存储在缓存中,以实现持久性并加快检索速度。
- 数据最初存储在消息处理器的内存缓存中,称为“L1 缓存”。
- L1 缓存受为其保留的内存量(占 JVM 内存的百分比)的限制。
- 缓存的条目随后保留在 L2 缓存中,可供所有 Message Processor 访问。更多详情,请参阅下文。
- L2 缓存对缓存条目数量没有任何硬性限制,但可缓存的条目大小上限为 256 KB。为获得最佳性能,建议将缓存大小设置为 256 KB。
反模式
这一特定的反模式讨论了超出 Apigee Edge 平台中当前缓存大小限制的影响。
当缓存大于 256 KB 的数据时,会产生以下后果:
- 因为在 L2 缓存中没有大于 256 KB 的条目,因此在每个 Message Processor 上首次执行的 API 请求都需要独立于原始来源(政策或目标服务器)获取数据。
- 在 L1 缓存中存储较大的数据(大于 256 KB)会给平台资源带来更大的压力。这使得 L1 缓存内存的填充速度更快,从而使得其他数据的空间更少。因此,任何人都无法像希望的那样缓存数据。
- 达到条目数量上限时,Message Processor 中的缓存条目将被移除。这会导致相应 Message Processor 重新从原始来源提取数据。
影响
- 大于 256 KB 的数据不会存储在 L2/persistent 缓存中。
- 更频繁地调用原始来源(政策或目标服务器)会增加 API 请求的延迟时间。
最佳做法
- 为了获得最佳性能,最好在缓存中存储小于 256 KB 的数据。
- 如果需要存储大于 256 KB 的数据,请考虑:
更多详情
如未另行说明,那么本页面中的内容已根据知识共享署名 4.0 许可获得了许可,并且代码示例已根据 Apache 2.0 许可获得了许可。有关详情,请参阅 Google 开发者网站政策。Java 是 Oracle 和/或其关联公司的注册商标。
最后更新时间 (UTC):2024-02-07。
[{
"type": "thumb-down",
"id": "missingTheInformationINeed",
"label":"没有我需要的信息"
},{
"type": "thumb-down",
"id": "tooComplicatedTooManySteps",
"label":"太复杂/步骤太多"
},{
"type": "thumb-down",
"id": "outOfDate",
"label":"内容需要更新"
},{
"type": "thumb-down",
"id": "translationIssue",
"label":"翻译问题"
},{
"type": "thumb-down",
"id": "samplesCodeIssue",
"label":"示例/代码问题"
},{
"type": "thumb-down",
"id": "otherDown",
"label":"其他"
}]
[{
"type": "thumb-up",
"id": "easyToUnderstand",
"label":"易于理解"
},{
"type": "thumb-up",
"id": "solvedMyProblem",
"label":"解决了我的问题"
},{
"type": "thumb-up",
"id": "otherUp",
"label":"其他"
}]
{"lastModified": "\u6700\u540e\u66f4\u65b0\u65f6\u95f4 (UTC)\uff1a2024-02-07\u3002"}
[[["易于理解","easyToUnderstand","thumb-up"],["解决了我的问题","solvedMyProblem","thumb-up"],["其他","otherUp","thumb-up"]],[["没有我需要的信息","missingTheInformationINeed","thumb-down"],["太复杂/步骤太多","tooComplicatedTooManySteps","thumb-down"],["内容需要更新","outOfDate","thumb-down"],["翻译问题","translationIssue","thumb-down"],["示例/代码问题","samplesCodeIssue","thumb-down"],["其他","otherDown","thumb-down"]],["最后更新时间 (UTC):2024-02-07。"],[],[]]