如何在 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

相关文章

vue使用docxtemplater导出word

《vue使用docxtemplater导出word》docxtemplater是一种邮件合并工具,以编程方式使用并处理条件、循环,并且可以扩展以插入任何内容,下面我们来看看如何使用docxtempl... 目录docxtemplatervue使用docxtemplater导出word安装常用语法 封装导出方

Linux换行符的使用方法详解

《Linux换行符的使用方法详解》本文介绍了Linux中常用的换行符LF及其在文件中的表示,展示了如何使用sed命令替换换行符,并列举了与换行符处理相关的Linux命令,通过代码讲解的非常详细,需要的... 目录简介检测文件中的换行符使用 cat -A 查看换行符使用 od -c 检查字符换行符格式转换将

使用Jackson进行JSON生成与解析的新手指南

《使用Jackson进行JSON生成与解析的新手指南》这篇文章主要为大家详细介绍了如何使用Jackson进行JSON生成与解析处理,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 核心依赖2. 基础用法2.1 对象转 jsON(序列化)2.2 JSON 转对象(反序列化)3.

使用Python实现快速搭建本地HTTP服务器

《使用Python实现快速搭建本地HTTP服务器》:本文主要介绍如何使用Python快速搭建本地HTTP服务器,轻松实现一键HTTP文件共享,同时结合二维码技术,让访问更简单,感兴趣的小伙伴可以了... 目录1. 概述2. 快速搭建 HTTP 文件共享服务2.1 核心思路2.2 代码实现2.3 代码解读3.

Elasticsearch 在 Java 中的使用教程

《Elasticsearch在Java中的使用教程》Elasticsearch是一个分布式搜索和分析引擎,基于ApacheLucene构建,能够实现实时数据的存储、搜索、和分析,它广泛应用于全文... 目录1. Elasticsearch 简介2. 环境准备2.1 安装 Elasticsearch2.2 J

使用C#代码在PDF文档中添加、删除和替换图片

《使用C#代码在PDF文档中添加、删除和替换图片》在当今数字化文档处理场景中,动态操作PDF文档中的图像已成为企业级应用开发的核心需求之一,本文将介绍如何在.NET平台使用C#代码在PDF文档中添加、... 目录引言用C#添加图片到PDF文档用C#删除PDF文档中的图片用C#替换PDF文档中的图片引言在当

Java中List的contains()方法的使用小结

《Java中List的contains()方法的使用小结》List的contains()方法用于检查列表中是否包含指定的元素,借助equals()方法进行判断,下面就来介绍Java中List的c... 目录详细展开1. 方法签名2. 工作原理3. 使用示例4. 注意事项总结结论:List 的 contain

C#使用SQLite进行大数据量高效处理的代码示例

《C#使用SQLite进行大数据量高效处理的代码示例》在软件开发中,高效处理大数据量是一个常见且具有挑战性的任务,SQLite因其零配置、嵌入式、跨平台的特性,成为许多开发者的首选数据库,本文将深入探... 目录前言准备工作数据实体核心技术批量插入:从乌龟到猎豹的蜕变分页查询:加载百万数据异步处理:拒绝界面

Android中Dialog的使用详解

《Android中Dialog的使用详解》Dialog(对话框)是Android中常用的UI组件,用于临时显示重要信息或获取用户输入,本文给大家介绍Android中Dialog的使用,感兴趣的朋友一起... 目录android中Dialog的使用详解1. 基本Dialog类型1.1 AlertDialog(

MySQL双主搭建+keepalived高可用的实现

《MySQL双主搭建+keepalived高可用的实现》本文主要介绍了MySQL双主搭建+keepalived高可用的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录一、测试环境准备二、主从搭建1.创建复制用户2.创建复制关系3.开启复制,确认复制是否成功4.同