(精华)2020年10月18日 高可用高并发 缓存的使用(Sqlserver)

举报
愚公搬代码 发表于 2021/10/20 00:47:42 2021/10/20
【摘要】 首先安装缓存数据包 dotnet tool install --global dotnet-sql-cache 1 执行 dotnet sql-cache create 数据库连接字符串 dbo 缓...

首先安装缓存数据包

dotnet tool install --global dotnet-sql-cache

  
 
  • 1

执行

dotnet sql-cache create 数据库连接字符串 dbo 缓存数据表名称

  
 
  • 1

nutget 安装如下包

Microsoft.Extensions.Caching.SqlServer

  
 
  • 1

配置

public class Startup
    {
        public Startup(IConfiguration configuration)
        {
            Configuration = configuration;
        }

        public IConfiguration Configuration { get; }

        public void ConfigureServices(IServiceCollection services)
        {
            services.AddDistributedSqlServerCache(options =>
            {
                // 缓存过期扫描时钟
                options.SystemClock = new LocalSystemClock();
                // 连接字符串
                options.ConnectionString = @"Data Source=(localdb)\MSSQLLocalDB;Initial Catalog=EFCoreSample;Integrated Security=True;";
                // 架构名称
                options.SchemaName = "dbo";
                // 缓存表名
                options.TableName = "TestCache";
                // 缓存过期时间1分钟,默认20分钟
                options.DefaultSlidingExpiration = TimeSpan.FromMinutes(1);
	        });
        }

        public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
        {
            if (env.IsDevelopment())
            {
                app.UseDeveloperExceptionPage();
            }

            app.UseRouting();

            app.UseAuthorization();

            app.UseEndpoints(endpoints =>
            {
                endpoints.MapControllers();
            });
        }
    }

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
public class LocalSystemClock : ISystemClock
    {
        public DateTimeOffset UtcNow => DateTime.Now;
    }

  
 
  • 1
  • 2
  • 3
  • 4

使用

[Route("api/[controller]")]
    [ApiController]
    public class Sample01Controller : ControllerBase
    {
        private readonly IDistributedCache _cache;

        public Sample01Controller(IDistributedCache distributedCache)
        {
            _cache = distributedCache;
        }

        public async Task<IActionResult> Get()
        {
            var cacheTime = await _cache.GetStringAsync("CacheTime");
            if (cacheTime == null)
            {
                cacheTime = DateTime.Now.ToString("yyyy-MM-dd hh:mm:ss");
                await _cache.SetAsync("CacheTime", Encoding.UTF8.GetBytes(cacheTime));
            }

            return Ok(new
            {
                cacheTime,
                currentTime = DateTime.Now.ToString("yyyy-MM-dd hh:mm:ss")
            });
        }
    }

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
[Route("api/[controller]")]
    [ApiController]
    public class Sample02Controller : ControllerBase
    {
        private readonly IDistributedCache _cache;

        public Sample02Controller(IDistributedCache distributedCache)
        {
            _cache = distributedCache;
        }

        public async Task<IActionResult> Get()
        {
            var cacheTime = await _cache.GetStringAsync("CacheTime");
            if (cacheTime == null)
            {
                cacheTime = DateTime.Now.ToString("yyyy-MM-dd hh:mm:ss");
                var cacheEntryOptions = new DistributedCacheEntryOptions()
                    .SetSlidingExpiration(TimeSpan.FromSeconds(10))
                    .SetAbsoluteExpiration(TimeSpan.FromSeconds(20));

                await _cache.SetAsync("CacheTime", Encoding.UTF8.GetBytes(cacheTime), cacheEntryOptions);
            }

            return Ok(new
            {
                cacheTime,
                currentTime = DateTime.Now.ToString("yyyy-MM-dd hh:mm:ss")
            });
        }
    }

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31

文章来源: codeboy.blog.csdn.net,作者:愚公搬代码,版权归原作者所有,如需转载,请联系作者。

原文链接:codeboy.blog.csdn.net/article/details/109151327

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。