如何在 Azure Cosmos DB 中使用缓存

2023-12-10 02:01

本文主要是介绍如何在 Azure Cosmos DB 中使用缓存,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Cosmos DB 是微软在 Azure 云中发布的新 NoSQL 数据库。与关系数据库不同,Cosmos DB 是一种托管数据库服务,因此具有可扩展性,因此在高事务性 .NET 和 .NET Core 应用程序中很受欢迎。

但是,使用 Cosmos DB 时,您需要警惕访问数据库的性能瓶颈和成本开销,因为 Microsoft 会针对 Cosmos DB 的每个事务向您收费。虽然 Cosmos DB 在事务容量方面具有可扩展性,但速度并不快,因为数据库服务与应用程序位于单独的 VNet 或订阅中。因此,即使您的应用程序运行在 Azure 云中,跨 VNet 访问数据库也会对性能造成巨大打击。

因此,为了解决这两个问题,最好在 Cosmos DB 应用程序中引入缓存。您将看到应用程序性能显着提高,同时运营成本显着降低,因为 80-90% 的时间,您的应用程序将从缓存而不是 Cosmos DB 获取数据。

将缓存与 Cosmos DB 结合使用
以下代码片段说明了如何在 Cosmos DB 中使用缓存。假设 Cosmos DB 实例包含客户集合。

根据缓存键在缓存中搜索指定客户。
如果该项目不是缓存,请查询 Cosmos DB 以搜索客户。
如果数据库集合中存在该客户,则检索该项目。
将指定客户添加到缓存,过期值为5分钟,保证数据一致性。

使用 NCache 作为 Cosmos DB 的分布式缓存
使用 Cosmos DB 时,您的应用程序很可能是通过负载均衡器在多服务器环境中运行的高事务应用程序,并且正在进行大量数据库调用。此外,在此环境中不可能使用独立缓存,因此您需要在应用程序和 Cosmos DB 数据库之间使用像 NCache 这样的分布式缓存。

您需要分布式缓存,因为它允许您随着事务负载的增长添加更多缓存服务器,因此缓存永远不会成为瓶颈。因此,应用程序服务器的数量并不重要,因为您可以在应用程序和数据库之间拥有足够的缓存服务器,这与关系数据库不同,关系数据库是任何可扩展性的主要瓶颈。

虽然 Cosmos DB 的扩展效率比关系数据库高得多,但它仍然无法与内存中分布式缓存(例如 NCache)相比,NCache 将与应用程序的 VNet 一起使用。事实上,缓存的一部分将驻留在应用程序进程本身内(称为客户端缓存),这为您提供了进程内缓存速度。

图片标题

与 Azure Cosmos DB 的公共云部署相比,这意味着更短的 RTT。使用缓存减少数据库命中还意味着请求单位 (RU) 产生的费用更少。了解有关NCache 中的缓存操作的更多信息。

缓存数据库项目集合
使用分布式缓存,您可以通过减少网络上的数据库行程(尤其是读取操作)来显着增强 Cosmos DB 应用程序性能。因此,虽然您可以从数据库中检索单个实体,但在吞吐量和减少 R/U 方面更经济的方法是从数据库中检索项目集合并在缓存层应用操作。对集合状态的任何更改都可以在操作结束时推送到数据库。

为此,NCache 允许将集合缓存为单个缓存项,并缓存集合的各个元素,每个元素都针对其自己指定的缓存键。

将集合缓存为单个项目
如果您想要集中加载集合项目(例如所有德国客户),您可以将集合缓存为单个项目。您可以查询德国所有客户的 Cosmos DB,并将结果作为单个列表返回,该列表可以添加到缓存中以供进一步使用。


单独缓存集合项
您可以将元数据与 NCache 中的缓存项相关联,以通过唯一标识符(例如标签)对数据进行分类。这样,可以根据单个标识符从缓存中检索多个项目,例如属于德国的客户。

为此,您可以在 Cosmos DB 中查询德国客户,并关联一个标签,例如Customer:Country:Germany 针对结果项目。单独缓存这些项目将使它们可用于各种查询组合,甚至可以更快地获取单个客户。

使用前面的示例,我们首先在缓存中搜索带有标签 的客户Customer:Country:Germany。如果缓存中不存在项目,请在 Cosmos DB 中查询 Customer 集合中“Country”属性指定为“Germany”的项目。但是,由于我们现在想要单独缓存集合项,因此我们执行以下操作:

从数据库中获取项目后,指定项目的到期值。
Customer:Country:Germany为每个缓存项指定标签。

Azure 中的 NCache 部署
除了下载供现场使用外,Azure 和 AWS 等主要云市场也提供 NCache。对于所有其他云系统,您只需以自带许可证 (BYOL) 模式在虚拟机上下载并安装 NCache。NCache 通过以下方式部署在 Azure 中:

在 Azure 中部署 NCache 云
将 NCache 部署为虚拟机
在 Azure 的平台即服务 (PaaS) 产品中使用 NCache。

这篇关于如何在 Azure Cosmos DB 中使用缓存的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Swagger2与Springdoc集成与使用详解

《Swagger2与Springdoc集成与使用详解》:本文主要介绍Swagger2与Springdoc集成与使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录1. 依赖配置2. 基础配置2.1 启用 Springdoc2.2 自定义 OpenAPI 信息3.

mysql中的group by高级用法详解

《mysql中的groupby高级用法详解》MySQL中的GROUPBY是数据聚合分析的核心功能,主要用于将结果集按指定列分组,并结合聚合函数进行统计计算,本文给大家介绍mysql中的groupby... 目录一、基本语法与核心功能二、基础用法示例1. 单列分组统计2. 多列组合分组3. 与WHERE结合使

Golang interface{}的具体使用

《Golanginterface{}的具体使用》interface{}是Go中可以表示任意类型的空接口,本文主要介绍了Golanginterface{}的具体使用,具有一定的参考价值,感兴趣的可以了... 目录一、什么是 interface{}?定义形China编程式:二、interface{} 有什么特别的?✅

使用Python实现调用API获取图片存储到本地的方法

《使用Python实现调用API获取图片存储到本地的方法》开发一个自动化工具,用于从JSON数据源中提取图像ID,通过调用指定API获取未经压缩的原始图像文件,并确保下载结果与Postman等工具直接... 目录使用python实现调用API获取图片存储到本地1、项目概述2、核心功能3、环境准备4、代码实现

MySQL数据库实现批量表分区完整示例

《MySQL数据库实现批量表分区完整示例》通俗地讲表分区是将一大表,根据条件分割成若干个小表,:本文主要介绍MySQL数据库实现批量表分区的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考... 目录一、表分区条件二、常规表和分区表的区别三、表分区的创建四、将既有表转换分区表脚本五、批量转换表为分区

宝塔安装的MySQL无法连接的情况及解决方案

《宝塔安装的MySQL无法连接的情况及解决方案》宝塔面板是一款流行的服务器管理工具,其中集成的MySQL数据库有时会出现连接问题,本文详细介绍两种最常见的MySQL连接错误:“1130-Hostisn... 目录一、错误 1130:Host ‘xxx.xxx.xxx.xxx’ is not allowed

windows和Linux安装Jmeter与简单使用方式

《windows和Linux安装Jmeter与简单使用方式》:本文主要介绍windows和Linux安装Jmeter与简单使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录Windows和linux安装Jmeter与简单使用一、下载安装包二、JDK安装1.windows设

JSR-107缓存规范介绍

《JSR-107缓存规范介绍》JSR是JavaSpecificationRequests的缩写,意思是Java规范提案,下面给大家介绍JSR-107缓存规范的相关知识,感兴趣的朋友一起看看吧... 目录1.什么是jsR-1072.应用调用缓存图示3.JSR-107规范使用4.Spring 缓存机制缓存是每一

Spring 缓存在项目中的使用详解

《Spring缓存在项目中的使用详解》Spring缓存机制,Cache接口为缓存的组件规范定义,包扩缓存的各种操作(添加缓存、删除缓存、修改缓存等),本文给大家介绍Spring缓存在项目中的使用... 目录1.Spring 缓存机制介绍2.Spring 缓存用到的概念Ⅰ.两个接口Ⅱ.三个注解(方法层次)Ⅲ.

Spring Boot 整合 Redis 实现数据缓存案例详解

《SpringBoot整合Redis实现数据缓存案例详解》Springboot缓存,默认使用的是ConcurrentMap的方式来实现的,然而我们在项目中并不会这么使用,本文介绍SpringB... 目录1.添加 Maven 依赖2.配置Redis属性3.创建 redisCacheManager4.使用Sp