如何在 Azure Cosmos DB 中使用缓存

这篇具有很好参考价值的文章主要介绍了如何在 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。文章来源地址https://www.toymoban.com/news/detail-756421.html

到了这里,关于如何在 Azure Cosmos DB 中使用缓存的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Azure动手实验 - 使用Azure Data Factory 迁移数据

    该实验使用 Azure CosmosDB,这个实验的点在于: 1:使用了 cosmicworks 生成了实验数据 2:弄清楚cosmosDB 的 accout Name 与 database id 和 container id 关系。 3:创建了 ADF 的连接和任务,让数据从 cosmicworks 数据库的 products 容器,迁移到 cosmicworks数据库的 flatproducts 容器。 实验来自于:练

    2024年02月04日
    浏览(42)
  • Azure Machine Learning - 使用自己的数据与 Azure OpenAI 模型对话

    在本文中,可以将自己的数据与 Azure OpenAI 模型配合使用。 对数据使用 Azure OpenAI 模型可以提供功能强大的对话 AI 平台,从而实现更快、更准确的通信。 关注TechLead,分享AI全维度知识。作者拥有10+年互联网服务架构、AI产品研发经验、团队管理经验,同济本复旦硕,复旦机器

    2024年02月04日
    浏览(44)
  • Azure 机器学习 - 如何使用模板创建安全工作区

    本教程介绍如何使用 [Microsoft Bicep]和 [Hashicorp Terraform]模板创建以下 Azure 资源: Azure 虚拟网络。 以下资源在此 VNet 后面进行保护: Azure 机器学习工作区 Azure 机器学习计算实例 Azure 机器学习计算群集 Azure 存储帐户 Azure Key Vault Azure Application Insights Azure 容器注册表 Azure Bastion

    2024年02月04日
    浏览(49)
  • 如何在 .NET Core 中使用 Azure Key Vaul

    Azure Key Vault是一个安全可靠的存储库,用于存储在.NET Core应用程序中使用的令牌、密钥、密码、证书和其他敏感数据。接下来我们讲讲如何在C#中使用它。 在构建.NET Core应用程序时,我们经常使用各种“秘密”,如客户端ID、访问令牌、密码、证书、加密密钥和API密钥。自然

    2024年02月16日
    浏览(34)
  • 如何使用W5100S-EVB-Pico连接Azure物联网中心

    使用Wiznet的W5100S-EVB-Pico板以及X.509证书连接到Azure物联网中心 注:最初发表-by renakim 组成: 硬件设施: W5100S-EVB-Pico ×1 W5100S-EVB-Pico | WIZnet Document System 软件应用程序和在线服务: Azure物联网中心 详细信息: 开发环境(Window 10,Code) 关于设置开发环境的信息可以在官方文档中

    2024年02月05日
    浏览(69)
  • Azure - 机器学习:使用 Apache Spark 进行交互式数据整理

    关注TechLead,分享AI全维度知识。作者拥有10+年互联网服务架构、AI产品研发经验、团队管理经验,同济本复旦硕,复旦机器人智能实验室成员,阿里云认证的资深架构师,项目管理专业人士,上亿营收AI产品研发负责人。 数据整理已经成为机器学习项目中最重要的步骤之一。

    2024年02月08日
    浏览(50)
  • 如何配置azure AD 通过登录azure的账户密码登录Azure VM

    Azure vm 添加 Azure AD 通过邮箱的账户密码登录 首先创建一个虚拟机,并且勾选Azure AD的复选框。 将创建虚机生成的资源最好配置到同一资源组 例如: 在vm生成的全部资源所在的资源组下打开访问控制

    2024年02月09日
    浏览(57)
  • Azure 机器学习 - 使用自动化机器学习训练计算机视觉模型的数据架构

    了解如何设置Azure Machine Learning JSONL 文件格式,以便在训练和推理期间在计算机视觉任务的自动化 ML 实验中使用数据。 关注TechLead,分享AI全维度知识。作者拥有10+年互联网服务架构、AI产品研发经验、团队管理经验,同济本复旦硕,复旦机器人智能实验室成员,阿里云认证的

    2024年02月05日
    浏览(52)
  • 使用Azure Data Factory REST API和HDInsight Spark进行简化数据处理

    在这篇文章中,我们将探讨如何利用Azure Data Factory和HDInsight Spark创建一个强大的数据处理管道。 在当今数据驱动的世界中,组织经常面临着高效可靠地处理和分析大量数据的挑战。Azure Data Factory是一种基于云的数据集成服务,结合HDInsight Spark,一种快速可扩展的大数据处理框

    2024年02月10日
    浏览(103)
  • 如何申请微软Azure的ChatGPT API,国内商业ChatGPT的apikey最稳定的途径且免费1年使用!!

    ` 目前,微软云服务Azure在中国区已经开通了过滤版的ChatGPT服务,国内的创业公司可以快速地申请使用。这一消息为国内的AI创业公司提供了良好的机会,可以借助微软的技术和资源,加速自身的发展。 可以申请azure 1 年免费试用,申请网址: https://azure.microsoft.com/zh-cn/free/ 注

    2024年02月01日
    浏览(51)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包