【微服务】07-缓存

news/2024/5/19 23:24:26 标签: 微服务, 缓存, .netcore, 后端, 开发语言

文章目录

为不同的场景设计合适的缓存策略

1. 缓存是什么

  • 缓存是计算结果的“临时”存储和重复使用
  • 缓存本质是用“空间”换取“时间”

2. 缓存的场景

  • 计算结果,如:反射对象缓存
  • 请求结果,如:DNS缓存
  • 临时共享数据,如:会话存储
  • 热点访问内容页,如:商品详情
  • 热点变更逻辑数据,如:秒杀的库存数

3. 缓存的策略

  • 越接近最终的输出结果(靠前),效果越好
  • 缓存命中率越高越好,命中率低就意味着“空间”浪费

4. 缓存位置

  • 浏览器中
  • 反向代理服务器中(负载均衡)
  • 应用进程内存中
  • 分布式存储系统中

5. 缓存实现的要点

  • 缓存Key生成策略,表示缓存数据的范围、业务含义
  • 缓存失效策略,如:过期事件机制、主动刷新机制
  • 缓存更新策略,表示更新缓存数据的时机

6. 注意问题

  • 缓存失效,导致数据不一致
  • 缓存穿透,查询无数据时,导致缓存不生效,查询都落在数据库
  • 缓存击穿,缓存失效瞬间,大量请求访问到数据库
  • 缓存雪崩,大量缓存同一时间失效,导致数据库压力

缓存穿透,一般查询结果为null时,在缓存里面强制返回一个默认值,避免缓存穿透的产生

缓存击穿,一般建议做法是使用二级缓存的策略,当一级缓存失效时,允许一个请求去落到数据库上面去更新缓存数据,重置缓存有效时间,其他请求仍然是通过缓存去响应

缓存雪崩,建议缓存失效时间的策略定义应当相对均匀的,使得数据库接收到的请求相对均匀,不会出现缓存key会同一时间有大量的失效情况

7. 使用的组件

  • ResponseCache
  • Microsoft.Extensions.Cacheing.Memory.IMemoryCache
  • Microsoft.Extensions.Caching.Distributed.IDistributedCache ⇒ 内置分布式缓存
  • EasyCaching

8. 内存缓存和分布式缓存区别

  • 内存缓存可以存储任意的对象
  • 分布式缓存的对象需要支持序列化
  • 分布式缓存远程请求可能失败,内存缓存不会
// Startup
public void ConfigureServices(IServiceCollection services)
{
	...
	// 内存缓存
	services.AddMemoryCache();
	
	// Redis缓存
	services.AddStackExchangeRedisCache(options =>
    {
        Configuration.GetSection("RedisCache").Bind(options);
    });
    
    // ResponseCaching
    services.AddResponseCaching();
    
    // EasyCaching
    services.AddEasyCaching(options =>
    {
        options.UseRedis(Configuration, name: "easycaching");
    });
}

//Configure
public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
{
	...
	app.UseRouting();
	 app.UseResponseCaching();
}

// 控制器
// ResponseCache
// VaryByQueryKeys表示缓存key生成策略基于query值,不同值缓存为不同cache
 [ResponseCache(Duration = 6000, VaryByQueryKeys = new string[] { "query" })]
 public IActionResult GetAbc([FromQuery]string query)
 {
     return Content("abc" + DateTime.Now);
 } 

// EasyCaching / IMemoryCache
public IActionResult GetDis([FromServices] IDistributedCache cache, [FromServices]IMemoryCache memoryCache, [FromServices]IEasyCachingProvider easyCaching, [FromQuery]string query)
{
       #region IDistributedCache
       var key = $"GetDis-{query ?? ""}";
       var time = cache.GetString(key);
       if (string.IsNullOrEmpty(time)) //此处需要考虑并发情形
       {
           var option = new DistributedCacheEntryOptions();
           time = DateTime.Now.ToString();
           cache.SetString(key, time, new DistributedCacheEntryOptions { AbsoluteExpirationRelativeToNow = TimeSpan.FromSeconds(600) });
       }
       #endregion

       #region IEasyCachingProvider
       //var key = $"GetDis-{query ?? ""}";
       //var time = easyCaching.Get(key, () => DateTime.Now.ToString(), TimeSpan.FromSeconds(600));


       #endregion

       return Content("abc" + time);
   }


// Redis,Easycaching缓存配置
{
	...,
	"RedisCache": {
    "Configuration": "localhost:6379",
    "InstanceName": "GoodSite"
  },
   "easycaching": {
    "redis": {
      "MaxRdSecond": 120,
      "EnableLogging": false,
      "LockMs": 5000,
      "SleepMs": 300,
      "dbconfig": {
        "Password": null,
        "IsSsl": false,
        "SslHost": null,
        "ConnectionTimeout": 5000,
        "AllowAdmin": true,
        "Endpoints": [
          {
            "Host": "localhost",
            "Port": 6379
          }
        ],
        "Database": 0
      }
    }
  }
}

总结

缓存的设计重点在于设计缓存的key和失效更新策略,需要关注缓存失效、缓存击穿、缓存穿透、缓存雪崩这些问题。


http://www.niftyadmin.cn/n/4972735.html

相关文章

4.16 TCP 协议有什么缺陷?

目录 升级 TCP 的工作很困难 TCP 建立连接的延迟 TCP 存在队头阻塞问题 网络迁移需要重新建立 TCP 连接 升级 TCP 的工作很困难;TCP 建立连接的延迟;TCP 存在队头阻塞问题;网络迁移需要重新建立 TCP 连接; 升级 TCP 的工作很…

新版微信小程序获取用户手机号

小程序手机号验证组件有两种 手机号快速验证组件 //原生写法 <button open-type"getPhoneNumber" bindgetphonenumber"getPhoneNumber"></button>Page({getPhoneNumber (e) {console.log(e.detail.code)} })uniapp写法 <button open-type…

CentOS 上通过 NFS 挂载远程服务器硬盘

NFS&#xff08;Network File System&#xff09;是一种用于在不同的计算机系统之间共享文件和目录的协议。它允许一个计算机系统将其文件系统的一部分或全部内容暴露给其他计算机系统&#xff0c;使其能够像访问本地文件一样访问这些内容。在这篇博客中&#xff0c;我们将介绍…

MySQL - 安装

MySQL 安装 | 菜鸟教程 linux:yum方式安装mysql 8 - 点击领取 一、Cent OS系统 &#xff08;一&#xff09;安装前 1.1 删除mariadb数据库软件包 rpm -qa|grep mari //查询mariadb数据库软件包 rpm -e --nodeps 查到的包名 //删除软件包 2.1 检…

2022年06月 C/C++(四级)真题解析#中国电子学会#全国青少年软件编程等级考试

第1题&#xff1a;公共子序列 我们称序列Z < z1, z2, …, zk >是序列X < x1, x2, …, xm >的子序列当且仅当存在 严格上升 的序列< i1, i2, …, ik >&#xff0c;使得对j 1, 2, … ,k, 有xij zj。比如Z < a, b, f, c > 是X < a, b, c, f, b, …

dji uav建图导航系列()ROS中创建dji_sdk节点包(一)项目结构

文章目录 1、整体项目结构1.1、 目录launch1.2、文件CMakeLists.txt1.3、文件package.xml1.4、目录include1.4、目录srv在ROS框架下创建一个无人机的节点dji_sdk,实现必需的订阅(控制指令)、发布(无人机里程计)、服务(无人机起飞降落、控制权得很)功能,就能实现一个类似…

利用Minimist框架简化Java类库的设计与实现

利用Minimist框架简化Java类库的设计与实现 摘要&#xff1a;在软件开发中&#xff0c;设计和实现类库是一项重要且耗时的任务。为了简化这一过程&#xff0c;可以使用Minimist框架。本文将介绍Minimist框架的使用&#xff0c;并通过Java代码示例展示如何利用该框架来…

DEFORMABLE DETR: DEFORMABLE TRANSFORMERS FOR END-TO-END OBJECT DETECTION 论文精度笔记

DEFORMABLE DETR DEFORMABLE DETR: DEFORMABLE TRANSFORMERS FOR END-TO-END OBJECT DETECTION 参考&#xff1a;AI-杂货铺-Transformer跨界CV又一佳作&#xff01;Deformable DETR&#xff1a;超强的小目标检测算法&#xff01; 摘要 摘要部分&#xff0c;作者主要说明了如…