ASP.Net Core -- 缓存

2021-01-07 07:29

阅读:442

标签:reason   视图   bsp   sof   回调   intern   企业   sticky   server   

缓存的优点有很多,比如:提高网站的访问速度,适用于不易改变的数据,当然也有缺点,使用缓存之前需要仔细规划这个项目,不然容易引起一些奇怪的副作用

缓存地点

1:服务器

比如是一个单服务器的web应用,缓存就可以放到这个服务器上,就是和web服务器放在一起

2:缓存服务器

如果web应用涉及到多个服务器的话,这个时候可以考虑单做做一个缓存服务器,然后其它的web服务器都可以访问这个缓存服务器

3:客户端

也就是本地

In-Memory缓存

1:这是最简单的,它实现了InMemoryCache这个接口

2:它适用于Sticky session这样的会话,翻译成中文就是黏性的会话,比如web应用涉及到多个服务器,那么就要保证,你的请求之前是访问的那一台服务器,那么之后想访问缓存数据的话,就必须访问的还是那一台服务器

3:最后,由于In-Memory使用的内存缓存,所以适用于任何类型的对象

代码示例

添加缓存服务,在startup.cs的ConfigureServices()方法中添加:

services.AddMemoryCache();

这样就可以使用In-Memory这个缓存了,比如要在HomeController里使用,只需要将InMemoryCache这个服务注入即可:

private readonly ILogger _logger;
        private readonly IMemoryCache _memoryCache;

        public HomeController(ILogger logger,
            IMemoryCache memoryCache)
        {
            _logger = logger;
            _memoryCache = memoryCache;
        }

另外,我们还需要给缓存设置一些东西,比如:

1:缓存时间,

      绝对过期时间::Absolute expiration time,比如一天

      Sliding expiration time:这个不知道怎么翻译,比如当访问到某个缓存后,把该缓存的时间时间再往后调一个小时

2:缓存的优先级

3:PostEvictionDelegate:当缓存的数据被清除后将被调用

再新建一个类,存放一个常量,因为缓存需要一个Key,如下:

public class CacheEntryConstants
    {
        public const string AlbumsOfToday = nameof(AlbumsOfToday);
    }

然后在控制器中在Index里,把用户列表数据进行缓存

public IActionResult Index() 
        {
            if (!_memoryCache.TryGetValue(
                CacheEntryConstants.AlbumsOfToday,
                out IEnumerable cachedStudent))
            {
                cachedStudent =  _repository.GetAll();

                var cacheEntryOptions = new MemoryCacheEntryOptions()
                    // .SetAbsoluteExpiration(TimeSpan.FromSeconds(600))
                    .SetSlidingExpiration(TimeSpan.FromSeconds(30));

                cacheEntryOptions.RegisterPostEvictionCallback(FillCache, this);

                _memoryCache.Set(CacheEntryConstants.AlbumsOfToday, cachedStudent, cacheEntryOptions);
            }


            return View(cachedStudent);
        }

然后写一个当缓存被清除后被调用的函数:

private void FillCache(object key, object value, EvictionReason reason, object state)
        {
            
        }

这里边就不写东西了,主要是用来测试,当缓存被清除后,会不会走这里边

打断点调试:

技术图片

 

 

第一次,没有缓存,进入判断里边:

技术图片

 

第二次,直接返回视图:

技术图片

 

等待30秒,再刷新页面,进入回调函数:

技术图片

具体内容:

1:先判断缓存里是否有数据,有的话直接用,没有的话就去数据库读取:

2:然后设置缓存时间

3:当缓存被清除后进入回调函数

关于In-Memory就简单学习到这里,如果以后需要可以具体看官方文档

Cache Tag Helper

既然是Helper,就是用在Razor View里边,基本格式如下:

@await Component.InvokeAsync("xxx")

当然,里边也可以添加一些属性,所以它也是在服务器端进行操作的,实际上它使用的还是内存里的缓存

Tag Helper的属性比较多,这里介绍一些相对重要的,如下:

enabled:         是否启用
expires-on:      绝对过期时间
expires-after:   时间长度
expires-sliding: 可调式过期时间
vary-by-header
vary-by-query
vary-by-route
vary-by-cookie
vary-by-user
vary-by priority

具体可以看文档

代码示例

 在layout.cshtml里写入:


         @await Component.InvokeAsync("InternetStatus")
 

这没啥功能,就是测试网络是否连接正常,如下:

public async Task InvokeAsync()
        {
            var httpClient = new HttpClient();

            var response = await httpClient.GetAsync("https://www.baidu.com");
            if (response.StatusCode == HttpStatusCode.OK)
            {
                return View(true);
            }

            return View(false);
        }

可以在layout里对加入哪一行代码打断点

1:第一次走进来,没问题

2:然后把电脑网络连接关闭,再刷新,还是没问题

3:等30秒后,就抛出异常了,因为缓存没了

分布式 缓存

以上的例子,因为用的是单个服务器,所以只对那一个服务器起作用,但是我们在实际企业项目开发时候,可能要做个集群什么的,比如,当用户发出请求后有多个web服务器,这个时候请求不一定请求的是那一台web服务器,所以这个时候我们就要把缓存数据提出来,单独放在一台缓存服务器上,来供其它web服务器来访问,如下:

技术图片

 

 

分布式缓存的一些特点:

1:无需Sticky Session

2:可扩展

3:服务器重启不会影响缓存

4:性能更好

分布式缓存接口名和一些方法:

1:IDistributedCache

2:Get,GetAsnyc

3:Set,SetAsync

4:Refresh,RefreshAsync

5:Remove,RemoveAsync

方法的参数类型都是byte数组类型

分布式缓存默认使用一下几种:

1:分布式 Memory Cache       这个只在开发时候使用,不太分布式

2:分布式 SQL server Cache   可以在生产环境使用

3:分布式 Redis Chche        可以在生产环境使用(使用最多)

 

ASP.Net Core -- 缓存

标签:reason   视图   bsp   sof   回调   intern   企业   sticky   server   

原文地址:https://www.cnblogs.com/dcy521/p/13574943.html


评论


亲,登录后才可以留言!