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

首先安装缓存数据包

dotnet tool install --global dotnet-sql-cache

执行

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

nutget 安装如下包

Microsoft.Extensions.Caching.SqlServer

配置

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();
            });
        }
    }
public class LocalSystemClock : ISystemClock
    {
        public DateTimeOffset UtcNow => DateTime.Now;
    }

使用

[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")
            });
        }
    }
[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")
            });
        }
    }
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

愚公搬代码

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值