富平做网站,安国市城乡建设局网站,潜江人才网官网,个人做淘宝客网站有哪些背景缓存击穿是指缓存中没有但数据库中有的数据#xff08;一般是缓存时间到期#xff09;#xff0c;这时由于并发用户特别多#xff0c;同时读缓存没读到数据#xff0c;又同时去数据库去取数据#xff0c;引起数据库压力瞬间增大#xff0c;造成过大压力。解决方案1、… 背景缓存击穿是指缓存中没有但数据库中有的数据一般是缓存时间到期这时由于并发用户特别多同时读缓存没读到数据又同时去数据库去取数据引起数据库压力瞬间增大造成过大压力。解决方案 1、设置热点数据永远不过期。 2、加互斥锁互斥锁参考代码如下 2.1、根据key生成object() private static object GetMemoryCacheLockObject(string key){string cacheLockKey string.Format(MemoryCacheLockObjectFormat, key);lock (CacheObject){var lockObject CacheObject[cacheLockKey];if (lockObject null){// 取得每個 Key專屬的 lock object若同時有多個 thread要求相同資料只會(到資料庫)查第一次剩下的從 cache讀取lockObject new object();CacheObject.Set(cacheLockKey,lockObject,new System.Runtime.Caching.CacheItemPolicy(){AbsoluteExpiration DateTimeOffset.UtcNow.AddMinutes(10)});}return lockObject;}}
2.2、lock住GetMemoryCacheLockObject(key) public T GetT(string key, FuncT getDataWork, TimeSpan absoluteExpireTime, bool forceRefresh false, bool returnCopy true) where T : class{try{lock (GetMemoryCacheLockObject(key)){/*
System.ArgumentNullException: Value cannot be null.
at System.Threading.Monitor.Enter(Object obj)
at BQoolCommon.Helpers.Cache.MemoryCacheLayer.Get[T](String key, Func1 getDataWork, TimeSpan absoluteExpireTime, Boolean forceRefresh, Boolean returnCopy) in D:\Source\BQoolCommon\BQoolCommon.Helpers\Cache\MemoryCacheLayer.cs:line 46*/T result CacheObject[key] as T;if (result ! null forceRefresh){// 是否清除Cache強制重查result null;}if (result null){//執行取得資料的委派作業result getDataWork();if (result ! null){Set(key, result, absoluteExpireTime);}}if (returnCopy){//複製一份新的參考string serialize JsonConvert.SerializeObject(result);return JsonConvert.DeserializeObjectT(serialize);}else{return result;}}}catch{return getDataWork();}}总结说明1、缓存中有数据直接走下述代码就返回结果了 T result CacheObject[key] as T;2、缓存中没有数据第1个进入的线程获取锁并从数据库去取数据没释放锁之前其他并行进入的线程会等待再重新去缓存取数据。这样就防止都去数据库重复取数据重复往缓存中更新数据情况出现。 try{lock (GetMemoryCacheLockObject(key)){/*
System.ArgumentNullException: Value cannot be null.
at System.Threading.Monitor.Enter(Object obj)
at BQoolCommon.Helpers.Cache.MemoryCacheLayer.Get[T](String key, Func1 getDataWork, TimeSpan absoluteExpireTime, Boolean forceRefresh, Boolean returnCopy) in D:\Source\BQoolCommon\BQoolCommon.Helpers\Cache\MemoryCacheLayer.cs:line 46*/T result CacheObject[key] as T;
3、取得每个 Key专有的 lock object若同时有多个 thread要求相同资料只会(到数据库)查第一次剩下的从 cache读取。 string cacheLockKey string.Format(MemoryCacheLockObjectFormat, key);lock (CacheObject){var lockObject CacheObject[cacheLockKey];if (lockObject null){// 取得每個 Key專屬的 lock object若同時有多個 thread要求相同資料只會(到資料庫)查第一次剩下的從 cache讀取lockObject new object();