上篇博文介紹了怎麼樣在 asp.net core 中使用中間件,以及如何自定義中間件。項目中恰好也用到了Redis,因此本篇就介紹下怎麼樣在 asp.net core 中使用 Redis 進行資源緩存和Session緩存。 若是你以爲對你有幫助的話,不妨點個【推薦】。html
下面是Redis官網的介紹:git
Redis is an open source (BSD licensed), in-memory data structure store, used as database, cache and message broker. It supports data structures such as strings, hashes, lists, sets, sorted sets with range queries, bitmaps, hyperloglogs and geospatial indexes with radius queries. Redis has built-in replication, Lua scripting, LRU eviction, transactions and different levels of on-disk persistence, and provides high availability via Redis Sentinel and automatic partitioning with Redis Cluster.github
Redis 是一個開源的(基於BSD許可),內存數據存儲結構,經常使用做數據庫,緩存,和消息隊列。它支持如字符串、哈希表、列表、集合、排序集範圍查詢、位圖、hyperloglogs半徑和地理空間索引與查詢。Redis內置主從鏈接,Lua腳本、LRU回收,事務和不一樣級別文件持久化,並提供了利用集羣的主從切換和自動分區等來保證高可用性。面試
Redis的深刻介紹我就直接開傳送門了,不是本篇的重點,可是我給大家整理了一下,大家仍是要感謝我滴:redis
redis 高可用部署及監控:http://blog.sina.com.cn/s/blog_75ad98f30101fwqj.html
redis 主從鏈接:http://www.tuicool.com/articles/fAnYFb
redis 事務: http://redisbook.readthedocs.io/en/latest/feature/transaction.html
redis 內存回收LRU:http://www.open-open.com/lib/view/open1427547789059.html
redis 數據持久化:http://qifuguang.me/2015/10/13/Redis%E6%8C%81%E4%B9%85%E5%8C%96/數據庫
以上知識學習完,使用和麪試時應付Redis的提問應該不成問題了。瀏覽器
session自己是一個很難解釋的名詞,在http中session表明服務器與瀏覽器的一次會話過程,這個過程可能一直,也可能間斷的。緩存
asp.net core中的session以中間件的方式提供給咱們來使用。服務器
下面來看一下使用方法:
首先,添加session的NuGet包Microsoft.AspNetCore.Http.Abstractions
到項目中,在startup.cs
文件的ConfigureServices(IServiceCollection services)
函數中,使用app.UseSession()
和app.UseCaching()
來使用session.session
//在使用session以前要注入cacheing,由於session依賴於cache進行存儲 services.AddCaching(); services.AddSession();
添加了session以後就須要有存儲session的地方,可使用內存存儲,也可使用其餘自定義存儲,好比redis或者SQL Server等。
// 重要: session的註冊必須在UseMvc以前,由於MVC裏面要用 app.UseSession(); app.UseMvc(routes => { routes.MapRoute( name: "default", template: "{controller}/{action}/{id?}", defaults: new { controller = "Home", action = "Index" }); });
要在Session中使用Redis,只須要把services.AddCaching();
換成services.AddDistributedRedisCache();
就能夠了,以下:
services.AddDistributedRedisCache(option => { //redis 數據庫鏈接字符串 option.Configuration = Configuration.GetConnectionString("RedisConnection"); //redis 實例名 option.InstanceName = "master"; } );
在 asp.net core 的 MVC Controller 中,你能夠HttpContext.Session
來獲取Session對象。
若是不是在 Controller 中須要使用 Session 的話,可使用IHttpContextAccessor
這個接口經過注入的方式來獲取Session。
如下是在 Controller 中使用Session,須要引入Microsoft.AspNetCore.Http
空間:
public class HomeController : Controller { public IActionResult Index() { HttpContext.Session.SetString("Test", "Ben Rules!"); return View(); } public IActionResult About() { ViewBag.Message = HttpContext.Session.GetString("Test"); return View(); } }
如下是在除了 Controller 的其餘地方使用 Session:
public class SomeOtherClass { private readonly IHttpContextAccessor _httpContextAccessor; private ISession _session => _httpContextAccessor.HttpContext.Session; public SomeOtherClass(IHttpContextAccessor httpContextAccessor) { _httpContextAccessor = httpContextAccessor; } public void TestSet() { _session.SetString("Test", "Ben Rules!"); } public void TestGet() { var message = _session.GetString("Test"); } }
默認狀況下,咱們只能存儲byte[]
到咱們的Session當中,這讓咱們使用起來很不方便,在Microsoft.HttpCore.Extension
中 Microsoft 給提供了一個SetString,SetInt32 和GetString,GetInt32的方法,可是在不少狀況下,咱們是須要使用Session來存儲一個對象的,那麼此時就須要給Session添加一個擴展方法。
爲了追求效率和性能,咱們選擇Google的Protobuf序列化組件,而不使用Json.Net,在性能方面,Protobuf要比XML或者Json效率高不少。
在Nuget包中引入protobuf-net
:
public static class SessionExtensions { public static T Get<T>(this ISession session, string key) where T : class { byte[] byteArray = null; if (session.TryGetValue(key, out byteArray)) { using (var memoryStream = new MemoryStream(byteArray)) { var obj = ProtoBuf.Serializer.Deserialize<T>(memoryStream); return obj; } } return null; } public static void Set<T>(this ISession session, string key, T value) where T : class { try { using (var memoryStream = new MemoryStream()) { ProtoBuf.Serializer.Serialize(memoryStream, value); byte[] byteArray = memoryStream.ToArray(); session.Set(key, byteArray); } } catch (Exception) { throw; } } }
使用Protobuf-net序列化,須要在序列化的對象打上[ProtoContract][ProtoMember]等標記。
Ps:目前Redis的擴展Microsoft.Extensions.DependencyInjection
下面的AddDistributedRedisCache
還不支持RC2,能夠去github上搜索源代碼,添加到項目中,也能夠留下郵箱,我會發給你。
本文地址:http://www.cnblogs.com/savorboard/p/5592948.html
做者博客:Savorboard 歡迎轉載,請保留出處