mirror of
http://git.coreshop.cn/jianweie/coreshoppro.git
synced 2025-12-06 15:53:26 +08:00
【优化】移除EasyCaching.Core,EasyCaching.CSRedis,EasyCaching.InMemory等组件,直接使用原生CSRedis组件,替换SqlSugar二级缓存组件。
This commit is contained in:
@@ -5,7 +5,7 @@
|
||||
</PropertyGroup>
|
||||
|
||||
<ItemGroup>
|
||||
<PackageReference Include="EasyCaching.Core" Version="1.9.0" />
|
||||
<PackageReference Include="CSRedisCore" Version="3.8.670" />
|
||||
<PackageReference Include="Microsoft.Extensions.Caching.Memory" Version="7.0.0" />
|
||||
<PackageReference Include="SKIT.FlurlHttpClient.Wechat.Api" Version="2.24.0" />
|
||||
<PackageReference Include="StackExchange.Redis" Version="2.6.96" />
|
||||
|
||||
@@ -14,65 +14,11 @@ using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using CoreCms.Net.Caching.Manual;
|
||||
using CoreCms.Net.Configuration;
|
||||
using CoreCms.Net.Utility.Extensions;
|
||||
using StackExchange.Redis;
|
||||
|
||||
namespace CoreCms.Net.Caching.Redis
|
||||
{
|
||||
public class RedisCacheManager : IManualCacheManager
|
||||
{
|
||||
private readonly string _redisConnenctionString;
|
||||
|
||||
public volatile ConnectionMultiplexer RedisConnection;
|
||||
|
||||
private readonly object _redisConnectionLock = new object();
|
||||
|
||||
public RedisCacheManager()
|
||||
{
|
||||
string redisConfiguration = AppSettingsConstVars.RedisConfigConnectionString;//获取连接字符串
|
||||
|
||||
if (string.IsNullOrWhiteSpace(redisConfiguration))
|
||||
{
|
||||
throw new ArgumentException("redis config is empty", nameof(redisConfiguration));
|
||||
}
|
||||
_redisConnenctionString = redisConfiguration;
|
||||
|
||||
RedisConnection = GetRedisConnection();
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// 核心代码,获取连接实例
|
||||
/// 通过双if 夹lock的方式,实现单例模式
|
||||
/// </summary>
|
||||
/// <returns></returns>
|
||||
private ConnectionMultiplexer GetRedisConnection()
|
||||
{
|
||||
//如果已经连接实例,直接返回
|
||||
if (RedisConnection != null && RedisConnection.IsConnected)
|
||||
{
|
||||
return RedisConnection;
|
||||
}
|
||||
//加锁,防止异步编程中,出现单例无效的问题
|
||||
lock (_redisConnectionLock)
|
||||
{
|
||||
if (RedisConnection != null)
|
||||
{
|
||||
//释放redis连接
|
||||
RedisConnection.Dispose();
|
||||
}
|
||||
try
|
||||
{
|
||||
RedisConnection = ConnectionMultiplexer.Connect(_redisConnenctionString);
|
||||
}
|
||||
catch (Exception)
|
||||
{
|
||||
throw new Exception("Redis服务未启用,请开启该服务,并且请注意端口号,Redis默认使用6379端口号。");
|
||||
}
|
||||
}
|
||||
return RedisConnection;
|
||||
}
|
||||
|
||||
|
||||
/// <summary>
|
||||
/// 判断key是否存在
|
||||
@@ -81,12 +27,10 @@ namespace CoreCms.Net.Caching.Redis
|
||||
/// <returns></returns>
|
||||
public bool Exists(string key)
|
||||
{
|
||||
return RedisConnection.GetDatabase().KeyExists(key);
|
||||
return RedisHelper.Exists(key);
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
/// <summary>
|
||||
/// 添加缓存
|
||||
/// </summary>
|
||||
@@ -98,15 +42,7 @@ namespace CoreCms.Net.Caching.Redis
|
||||
{
|
||||
if (value != null)
|
||||
{
|
||||
//序列化,将object值生成RedisValue
|
||||
if (expiresIn > 0)
|
||||
{
|
||||
return RedisConnection.GetDatabase().StringSet(key, SerializeExtensions.Serialize(value), TimeSpan.FromMinutes(expiresIn));
|
||||
}
|
||||
else
|
||||
{
|
||||
return RedisConnection.GetDatabase().StringSet(key, SerializeExtensions.Serialize(value));
|
||||
}
|
||||
return expiresIn > 0 ? RedisHelper.Set(key, value, TimeSpan.FromMinutes(expiresIn)) : RedisHelper.Set(key, value);
|
||||
}
|
||||
return false;
|
||||
}
|
||||
@@ -118,7 +54,7 @@ namespace CoreCms.Net.Caching.Redis
|
||||
/// <returns></returns>
|
||||
public void Remove(string key)
|
||||
{
|
||||
RedisConnection.GetDatabase().KeyDelete(key);
|
||||
RedisHelper.DelAsync(key);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
@@ -127,11 +63,9 @@ namespace CoreCms.Net.Caching.Redis
|
||||
/// <returns></returns>
|
||||
public void RemoveAll(IEnumerable<string> keys)
|
||||
{
|
||||
foreach (var key in keys)
|
||||
{
|
||||
RedisConnection.GetDatabase().KeyDelete(key);
|
||||
}
|
||||
|
||||
var enumerable = keys as string[] ?? keys.ToArray();
|
||||
string[] keyStrings = enumerable.ToArray();
|
||||
RedisHelper.DelAsync(keyStrings);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
@@ -141,19 +75,12 @@ namespace CoreCms.Net.Caching.Redis
|
||||
/// <returns></returns>
|
||||
public T Get<T>(string key)
|
||||
{
|
||||
var value = RedisConnection.GetDatabase().StringGet(key);
|
||||
if (value.HasValue)
|
||||
{
|
||||
//需要用的反序列化,将Redis存储的Byte[],进行反序列化
|
||||
return SerializeExtensions.Deserialize<T>(value);
|
||||
}
|
||||
|
||||
return default;
|
||||
return RedisHelper.Get<T>(key);
|
||||
}
|
||||
|
||||
public object Get(string key)
|
||||
{
|
||||
return RedisConnection.GetDatabase().StringGet(key);
|
||||
return RedisHelper.Get<object>(key);
|
||||
}
|
||||
|
||||
public IDictionary<string, object> GetAll(IEnumerable<string> keys)
|
||||
@@ -162,48 +89,27 @@ namespace CoreCms.Net.Caching.Redis
|
||||
throw new ArgumentNullException(nameof(keys));
|
||||
var dict = new Dictionary<string, object>();
|
||||
|
||||
keys.ToList().ForEach(item => dict.Add(item, RedisConnection.GetDatabase().StringGet(item)));
|
||||
keys.ToList().ForEach(item => dict.Add(item, RedisHelper.Get(item)));
|
||||
return dict;
|
||||
|
||||
}
|
||||
|
||||
public void RemoveCacheAll()
|
||||
{
|
||||
foreach (var endPoint in GetRedisConnection().GetEndPoints())
|
||||
{
|
||||
var server = GetRedisConnection().GetServer(endPoint);
|
||||
foreach (var key in server.Keys())
|
||||
{
|
||||
RedisConnection.GetDatabase().KeyDelete(key);
|
||||
}
|
||||
}
|
||||
//查找所有分区节点中符合给定模式(pattern)的 key
|
||||
var cacheKeys = RedisHelper.Keys("*");
|
||||
RedisHelper.Del(cacheKeys);
|
||||
}
|
||||
|
||||
public void RemoveCacheRegex(string pattern)
|
||||
{
|
||||
var script = "return redis.call('keys',@pattern)";
|
||||
var prepared = LuaScript.Prepare(script);
|
||||
var redisResult = RedisConnection.GetDatabase().ScriptEvaluate(prepared, new { pattern });
|
||||
if (!redisResult.IsNull)
|
||||
{
|
||||
RedisConnection.GetDatabase().KeyDelete((RedisKey[])redisResult); //删除一组key
|
||||
}
|
||||
var cacheKeys = RedisHelper.Keys(pattern);
|
||||
RedisHelper.Del(cacheKeys);
|
||||
}
|
||||
|
||||
public IList<string> SearchCacheRegex(string pattern)
|
||||
{
|
||||
var list = new List<String>();
|
||||
var script = "return redis.call('keys',@pattern)";
|
||||
var prepared = LuaScript.Prepare(script);
|
||||
var redisResult = RedisConnection.GetDatabase().ScriptEvaluate(prepared, new { pattern });
|
||||
if (!redisResult.IsNull)
|
||||
{
|
||||
foreach (var key in (RedisKey[])redisResult)
|
||||
{
|
||||
list.Add(key);
|
||||
}
|
||||
}
|
||||
return list;
|
||||
return RedisHelper.Keys(pattern);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,58 +0,0 @@
|
||||
using CoreCms.Net.Utility;
|
||||
using EasyCaching.Core;
|
||||
using SqlSugar;
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
|
||||
namespace CoreCms.Net.Caching.SqlSugar
|
||||
{
|
||||
/// <summary>
|
||||
/// 仅供ORM缓存使用
|
||||
/// </summary>
|
||||
public class SqlSugarCache : ICacheService
|
||||
{
|
||||
private static readonly IEasyCachingProvider cache = Storage.GetService<IEasyCachingProvider>();
|
||||
|
||||
public void Add<V>(string key, V value)
|
||||
{
|
||||
cache.Set(key, value, TimeSpan.FromSeconds(int.MaxValue));
|
||||
}
|
||||
|
||||
public void Add<V>(string key, V value, int cacheDurationInSeconds)
|
||||
{
|
||||
cache.Set(key, value, TimeSpan.FromSeconds(cacheDurationInSeconds));
|
||||
}
|
||||
|
||||
public bool ContainsKey<V>(string key)
|
||||
{
|
||||
return cache.Exists(key);
|
||||
}
|
||||
|
||||
public V Get<V>(string key)
|
||||
{
|
||||
return cache.Get<V>(key).Value;
|
||||
}
|
||||
|
||||
public IEnumerable<string> GetAllKey<V>()
|
||||
{
|
||||
return cache.GetByPrefix<object>("SqlSugarDataCache.").Keys;
|
||||
}
|
||||
|
||||
public void Remove<V>(string key)
|
||||
{
|
||||
cache.Remove(key);
|
||||
}
|
||||
|
||||
public V GetOrCreate<V>(string cacheKey, Func<V> create, int cacheDurationInSeconds = 2147483647)
|
||||
{
|
||||
if (cache.Exists(cacheKey))
|
||||
{
|
||||
return cache.Get<V>(cacheKey).Value;
|
||||
}
|
||||
|
||||
V v = create();
|
||||
cache.Set(cacheKey, v, TimeSpan.FromSeconds(cacheDurationInSeconds));
|
||||
return v;
|
||||
}
|
||||
}
|
||||
}
|
||||
282
CoreCms.Net.Caching/SqlSugar/SqlSugarMemoryCache.cs
Normal file
282
CoreCms.Net.Caching/SqlSugar/SqlSugarMemoryCache.cs
Normal file
@@ -0,0 +1,282 @@
|
||||
using System;
|
||||
using System.Collections;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Reflection;
|
||||
using System.Text;
|
||||
using System.Text.RegularExpressions;
|
||||
using System.Threading.Tasks;
|
||||
using Microsoft.Extensions.Caching.Memory;
|
||||
using SqlSugar;
|
||||
|
||||
namespace CoreCms.Net.Caching.SqlSugar
|
||||
{
|
||||
public class SqlSugarMemoryCache : ICacheService
|
||||
{
|
||||
MemoryCacheHelper cache = new MemoryCacheHelper();
|
||||
public void Add<V>(string key, V value)
|
||||
{
|
||||
cache.Set(key, value);
|
||||
}
|
||||
|
||||
public void Add<V>(string key, V value, int cacheDurationInSeconds)
|
||||
{
|
||||
cache.Set(key, value, cacheDurationInSeconds);
|
||||
}
|
||||
|
||||
public bool ContainsKey<V>(string key)
|
||||
{
|
||||
return cache.Exists(key);
|
||||
}
|
||||
|
||||
public V Get<V>(string key)
|
||||
{
|
||||
return cache.Get<V>(key);
|
||||
}
|
||||
|
||||
public IEnumerable<string> GetAllKey<V>()
|
||||
{
|
||||
return cache.GetCacheKeys();
|
||||
}
|
||||
|
||||
public V GetOrCreate<V>(string cacheKey, Func<V> create, int cacheDurationInSeconds = int.MaxValue)
|
||||
{
|
||||
if (cache.Exists(cacheKey))
|
||||
{
|
||||
return cache.Get<V>(cacheKey);
|
||||
}
|
||||
else
|
||||
{
|
||||
var result = create();
|
||||
cache.Set(cacheKey, result, cacheDurationInSeconds);
|
||||
return result;
|
||||
}
|
||||
}
|
||||
|
||||
public void Remove<V>(string key)
|
||||
{
|
||||
cache.Remove(key);
|
||||
}
|
||||
}
|
||||
public class MemoryCacheHelper
|
||||
{
|
||||
private static readonly Microsoft.Extensions.Caching.Memory.MemoryCache Cache = new Microsoft.Extensions.Caching.Memory.MemoryCache(new MemoryCacheOptions());
|
||||
|
||||
/// <summary>
|
||||
/// 验证缓存项是否存在
|
||||
/// </summary>
|
||||
/// <param name="key">缓存Key</param>
|
||||
/// <returns></returns>
|
||||
public bool Exists(string key)
|
||||
{
|
||||
if (key == null)
|
||||
throw new ArgumentNullException(nameof(key));
|
||||
return Cache.TryGetValue(key, out _);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// 添加缓存
|
||||
/// </summary>
|
||||
/// <param name="key">缓存Key</param>
|
||||
/// <param name="value">缓存Value</param>
|
||||
/// <param name="expiresSliding">滑动过期时长(如果在过期时间内有操作,则以当前时间点延长过期时间)</param>
|
||||
/// <param name="expiressAbsoulte">绝对过期时长</param>
|
||||
/// <returns></returns>
|
||||
public bool Set(string key, object value, TimeSpan expiresSliding, TimeSpan expiressAbsoulte)
|
||||
{
|
||||
if (key == null)
|
||||
throw new ArgumentNullException(nameof(key));
|
||||
if (value == null)
|
||||
throw new ArgumentNullException(nameof(value));
|
||||
|
||||
Cache.Set(key, value,
|
||||
new MemoryCacheEntryOptions().SetSlidingExpiration(expiresSliding)
|
||||
.SetAbsoluteExpiration(expiressAbsoulte));
|
||||
return Exists(key);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// 添加缓存
|
||||
/// </summary>
|
||||
/// <param name="key">缓存Key</param>
|
||||
/// <param name="value">缓存Value</param>
|
||||
/// <param name="expiresIn">缓存时长</param>
|
||||
/// <param name="isSliding">是否滑动过期(如果在过期时间内有操作,则以当前时间点延长过期时间)</param>
|
||||
/// <returns></returns>
|
||||
public bool Set(string key, object value, TimeSpan expiresIn, bool isSliding = false)
|
||||
{
|
||||
if (key == null)
|
||||
throw new ArgumentNullException(nameof(key));
|
||||
if (value == null)
|
||||
throw new ArgumentNullException(nameof(value));
|
||||
|
||||
Cache.Set(key, value,
|
||||
isSliding
|
||||
? new MemoryCacheEntryOptions().SetSlidingExpiration(expiresIn)
|
||||
: new MemoryCacheEntryOptions().SetAbsoluteExpiration(expiresIn));
|
||||
|
||||
return Exists(key);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// 添加缓存
|
||||
/// </summary>
|
||||
/// <param name="key">缓存Key</param>
|
||||
/// <param name="value">缓存Value</param>
|
||||
/// <returns></returns>
|
||||
public void Set(string key, object value)
|
||||
{
|
||||
Set(key, value, TimeSpan.FromDays(1));
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// 添加缓存
|
||||
/// </summary>
|
||||
/// <param name="key">缓存Key</param>
|
||||
/// <param name="value">缓存Value</param>
|
||||
/// <param name="ts"></param>
|
||||
/// <returns></returns>
|
||||
public void Set(string key, object value, TimeSpan ts)
|
||||
{
|
||||
Set(key, value, ts, false);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// 添加缓存
|
||||
/// </summary>
|
||||
/// <param name="key">缓存Key</param>
|
||||
/// <param name="value">缓存Value</param>
|
||||
/// <param name="ts"></param>
|
||||
/// <returns></returns>
|
||||
public void Set(string key, object value, int seconds)
|
||||
{
|
||||
var ts = TimeSpan.FromSeconds(seconds);
|
||||
Set(key, value, ts, false);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// 删除缓存
|
||||
/// </summary>
|
||||
/// <param name="key">缓存Key</param>
|
||||
/// <returns></returns>
|
||||
public void Remove(string key)
|
||||
{
|
||||
if (key == null)
|
||||
throw new ArgumentNullException(nameof(key));
|
||||
Cache.Remove(key);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// 批量删除缓存
|
||||
/// </summary>
|
||||
/// <returns></returns>
|
||||
public void RemoveAll(IEnumerable<string> keys)
|
||||
{
|
||||
if (keys == null)
|
||||
throw new ArgumentNullException(nameof(keys));
|
||||
|
||||
keys.ToList().ForEach(item => Cache.Remove(item));
|
||||
}
|
||||
|
||||
|
||||
#region 获取缓存
|
||||
|
||||
/// <summary>
|
||||
/// 获取缓存
|
||||
/// </summary>
|
||||
/// <param name="key">缓存Key</param>
|
||||
/// <returns></returns>
|
||||
public T Get<T>(string key)
|
||||
{
|
||||
if (key == null)
|
||||
throw new ArgumentNullException(nameof(key));
|
||||
|
||||
return Cache.Get<T>(key);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// 获取缓存
|
||||
/// </summary>
|
||||
/// <param name="key">缓存Key</param>
|
||||
/// <returns></returns>
|
||||
public object Get(string key)
|
||||
{
|
||||
if (key == null)
|
||||
throw new ArgumentNullException(nameof(key));
|
||||
|
||||
return Cache.Get(key);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// 获取缓存集合
|
||||
/// </summary>
|
||||
/// <param name="keys">缓存Key集合</param>
|
||||
/// <returns></returns>
|
||||
public IDictionary<string, object> GetAll(IEnumerable<string> keys)
|
||||
{
|
||||
if (keys == null)
|
||||
throw new ArgumentNullException(nameof(keys));
|
||||
|
||||
var dict = new Dictionary<string, object>();
|
||||
keys.ToList().ForEach(item => dict.Add(item, Cache.Get(item)));
|
||||
return dict;
|
||||
}
|
||||
#endregion
|
||||
|
||||
/// <summary>
|
||||
/// 删除所有缓存
|
||||
/// </summary>
|
||||
public void RemoveCacheAll()
|
||||
{
|
||||
var l = GetCacheKeys();
|
||||
foreach (var s in l)
|
||||
{
|
||||
Remove(s);
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// 删除匹配到的缓存
|
||||
/// </summary>
|
||||
/// <param name="pattern"></param>
|
||||
/// <returns></returns>
|
||||
public void RemoveCacheRegex(string pattern)
|
||||
{
|
||||
IList<string> l = SearchCacheRegex(pattern);
|
||||
foreach (var s in l)
|
||||
{
|
||||
Remove(s);
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// 搜索 匹配到的缓存
|
||||
/// </summary>
|
||||
/// <param name="pattern"></param>
|
||||
/// <returns></returns>
|
||||
public IList<string> SearchCacheRegex(string pattern)
|
||||
{
|
||||
var cacheKeys = GetCacheKeys();
|
||||
var l = cacheKeys.Where(k => Regex.IsMatch(k, pattern)).ToList();
|
||||
return l.AsReadOnly();
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// 获取所有缓存键
|
||||
/// </summary>
|
||||
/// <returns></returns>
|
||||
public List<string> GetCacheKeys()
|
||||
{
|
||||
const BindingFlags flags = BindingFlags.Instance | BindingFlags.NonPublic;
|
||||
var entries = Cache.GetType().GetField("_entries", flags).GetValue(Cache);
|
||||
var cacheItems = entries as IDictionary;
|
||||
var keys = new List<string>();
|
||||
if (cacheItems == null) return keys;
|
||||
foreach (DictionaryEntry cacheItem in cacheItems)
|
||||
{
|
||||
keys.Add(cacheItem.Key.ToString());
|
||||
}
|
||||
return keys;
|
||||
}
|
||||
}
|
||||
}
|
||||
59
CoreCms.Net.Caching/SqlSugar/SqlSugarRedisCache.cs
Normal file
59
CoreCms.Net.Caching/SqlSugar/SqlSugarRedisCache.cs
Normal file
@@ -0,0 +1,59 @@
|
||||
using SqlSugar;
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
|
||||
namespace CoreCms.Net.Caching.SqlSugar
|
||||
{
|
||||
public class SqlSugarRedisCache : ICacheService
|
||||
{
|
||||
|
||||
public SqlSugarRedisCache()
|
||||
{
|
||||
}
|
||||
|
||||
public void Add<TV>(string key, TV value)
|
||||
{
|
||||
RedisHelper.Set(key, value);
|
||||
}
|
||||
|
||||
public void Add<TV>(string key, TV value, int cacheDurationInSeconds)
|
||||
{
|
||||
RedisHelper.Set(key, value, cacheDurationInSeconds);
|
||||
}
|
||||
|
||||
public bool ContainsKey<TV>(string key)
|
||||
{
|
||||
return RedisHelper.Exists(key);
|
||||
}
|
||||
|
||||
public TV Get<TV>(string key)
|
||||
{
|
||||
return RedisHelper.Get<TV>(key);
|
||||
}
|
||||
|
||||
public IEnumerable<string> GetAllKey<TV>()
|
||||
{
|
||||
return RedisHelper.Keys("SqlSugarDataCache.*");
|
||||
}
|
||||
|
||||
public TV GetOrCreate<TV>(string cacheKey, Func<TV> create, int cacheDurationInSeconds = int.MaxValue)
|
||||
{
|
||||
if (this.ContainsKey<TV>(cacheKey))
|
||||
{
|
||||
return this.Get<TV>(cacheKey);
|
||||
}
|
||||
else
|
||||
{
|
||||
var result = create();
|
||||
this.Add(cacheKey, result, cacheDurationInSeconds);
|
||||
return result;
|
||||
}
|
||||
}
|
||||
|
||||
public void Remove<TV>(string key)
|
||||
{
|
||||
RedisHelper.DelAsync(key);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
@@ -5,6 +5,7 @@ using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
using CoreCms.Net.Caching.AutoMate.RedisCache;
|
||||
using CoreCms.Net.Configuration;
|
||||
using CSRedis;
|
||||
using Microsoft.Extensions.DependencyInjection;
|
||||
using StackExchange.Redis;
|
||||
|
||||
@@ -19,6 +20,13 @@ namespace CoreCms.Net.Core.Config
|
||||
{
|
||||
if (services == null) throw new ArgumentNullException(nameof(services));
|
||||
|
||||
|
||||
if (AppSettingsConstVars.RedisUseCache)
|
||||
{
|
||||
//初始化Redis及分布式缓存
|
||||
RedisHelper.Initialization(new CSRedisClient(AppSettingsConstVars.RedisConfigConnectionString));
|
||||
}
|
||||
|
||||
services.AddTransient<IRedisOperationRepository, RedisOperationRepository>();
|
||||
|
||||
// 配置启动Redis服务,虽然可能影响项目启动速度,但是不能在运行的时候报错,所以是合理的
|
||||
@@ -34,6 +42,7 @@ namespace CoreCms.Net.Core.Config
|
||||
return ConnectionMultiplexer.Connect(configuration);
|
||||
});
|
||||
|
||||
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -49,8 +49,7 @@ namespace CoreCms.Net.Core.Config
|
||||
db.CurrentConnectionConfig.ConfigureExternalServices = new ConfigureExternalServices()
|
||||
{
|
||||
//判断是否开启redis设置二级缓存方式
|
||||
//DataInfoCacheService = AppSettingsConstVars.RedisUseCache ? (ICacheService)new SqlSugarRedisCache() : new SqlSugarMemoryCache()
|
||||
DataInfoCacheService = new SqlSugarCache()
|
||||
DataInfoCacheService = AppSettingsConstVars.RedisUseCache ? new SqlSugarRedisCache() : new SqlSugarMemoryCache()
|
||||
};
|
||||
db.CurrentConnectionConfig.MoreSettings = new ConnMoreSettings()
|
||||
{
|
||||
|
||||
@@ -49,9 +49,7 @@
|
||||
<PackageReference Include="Autofac.Extensions.DependencyInjection" Version="8.0.0" />
|
||||
<PackageReference Include="Autofac.Extras.DynamicProxy" Version="6.0.1" />
|
||||
<PackageReference Include="AutoMapper.Extensions.Microsoft.DependencyInjection" Version="12.0.0" />
|
||||
<PackageReference Include="EasyCaching.CSRedis" Version="1.9.0" />
|
||||
<PackageReference Include="EasyCaching.InMemory" Version="1.9.0" />
|
||||
<PackageReference Include="EasyCaching.Serialization.Json" Version="1.9.0" />
|
||||
<PackageReference Include="CSRedisCore" Version="3.8.670" />
|
||||
<PackageReference Include="Essensoft.Paylink.Alipay" Version="4.1.0" />
|
||||
<PackageReference Include="Essensoft.Paylink.WeChatPay" Version="4.1.0" />
|
||||
<PackageReference Include="IdentityModel" Version="6.0.0" />
|
||||
|
||||
@@ -4,21 +4,16 @@ using CoreCms.Net.Configuration;
|
||||
using CoreCms.Net.Loging;
|
||||
using Essensoft.Paylink.Alipay;
|
||||
using Essensoft.Paylink.WeChatPay;
|
||||
using Microsoft.AspNetCore.Authentication.Cookies;
|
||||
using Microsoft.AspNetCore.Builder;
|
||||
using Microsoft.AspNetCore.Hosting;
|
||||
using Microsoft.AspNetCore.HttpOverrides;
|
||||
using Microsoft.AspNetCore.Mvc.Controllers;
|
||||
using Microsoft.AspNetCore.Mvc;
|
||||
using Microsoft.Extensions.Configuration;
|
||||
using Microsoft.Extensions.DependencyInjection;
|
||||
using Microsoft.Extensions.Hosting;
|
||||
using Microsoft.Extensions.Logging;
|
||||
using NLog.Web;
|
||||
using StackExchange.Redis;
|
||||
using System;
|
||||
using System.Linq;
|
||||
using System.Reflection;
|
||||
using CoreCms.Net.Auth;
|
||||
using CoreCms.Net.Core.AutoFac;
|
||||
using CoreCms.Net.Core.Config;
|
||||
@@ -27,7 +22,6 @@ using CoreCms.Net.Mapping;
|
||||
using CoreCms.Net.Middlewares;
|
||||
using CoreCms.Net.Swagger;
|
||||
using CoreCms.Net.Utility;
|
||||
using EasyCaching.Core;
|
||||
using Microsoft.Extensions.DependencyInjection.Extensions;
|
||||
using Newtonsoft.Json;
|
||||
using Newtonsoft.Json.Serialization;
|
||||
@@ -132,27 +126,6 @@ YitIdHelper.SetIdGenerator(options);
|
||||
// 初始化以后,即可在任何需要生成ID的地方,调用以下方法:
|
||||
//var newId = YitIdHelper.NextId();
|
||||
|
||||
|
||||
#region 缓存配置
|
||||
string cacheProviderName = "default";
|
||||
builder.Services.AddEasyCaching(options =>
|
||||
{
|
||||
////使用文档 https://easycaching.readthedocs.io/en/latest
|
||||
if (AppSettingsConstVars.RedisUseCache)
|
||||
{
|
||||
options.UseCSRedis(builder.Configuration);
|
||||
cacheProviderName = EasyCachingConstValue.DefaultCSRedisName;
|
||||
}
|
||||
else
|
||||
{
|
||||
cacheProviderName = EasyCachingConstValue.DefaultInMemoryName;
|
||||
options.UseInMemory(builder.Configuration);
|
||||
}
|
||||
options.WithJson(cacheProviderName);
|
||||
|
||||
});
|
||||
#endregion
|
||||
|
||||
#region AutoFac注册============================================================================
|
||||
|
||||
builder.Host.UseServiceProviderFactory(new AutofacServiceProviderFactory());
|
||||
@@ -199,8 +172,6 @@ app.UseRequestResponseLog();
|
||||
app.UseRecordAccessLogsMildd(GlobalEnumVars.CoreShopSystemCategory.Admin.ToString());
|
||||
// 记录ip请求 (注意开启权限,不然本地无法写入)
|
||||
app.UseIpLogMildd();
|
||||
//注册csredis中间件处理
|
||||
Storage.Container = app.Services.CreateScope().ServiceProvider.GetAutofacRoot();
|
||||
#endregion
|
||||
|
||||
app.UseSwagger().UseSwaggerUI(c =>
|
||||
|
||||
@@ -27,37 +27,6 @@
|
||||
// 如果采用容器化部署Service 要写成redis的服务名,否则写地址
|
||||
"ConnectionString": "127.0.0.1:6379,password=,connectTimeout=30000,responseTimeout=30000,abortConnect=false,connectRetry=1,syncTimeout=10000,DefaultDatabase=9" //redis数据库连接字符串
|
||||
},
|
||||
"easycaching": {
|
||||
"csredis": {
|
||||
"MaxRdSecond": 0, //预防缓存在同一时间全部失效,可以为每个key的过期时间添加一个随机的秒数,默认值是120秒
|
||||
"EnableLogging": false, // 是否开启日志,默认值是false
|
||||
"LockMs": 5000, // 互斥锁的存活时间, 默认值是5000毫秒
|
||||
"SleepMs": 300, // 没有获取到互斥锁时的休眠时间,默认值是300毫秒
|
||||
"dbconfig": {
|
||||
"ConnectionStrings": [
|
||||
"127.0.0.1:6379,password=,connectTimeout=30000,responseTimeout=30000,abortConnect=false,connectRetry=1,syncTimeout=10000,DefaultDatabase=9" //如果没有密码请保持为空
|
||||
],
|
||||
//"Sentinels": [
|
||||
// "192.169.1.10:26379",
|
||||
// "192.169.1.11:26379",
|
||||
// "192.169.1.12:26379"
|
||||
//],
|
||||
"ReadOnly": false
|
||||
}
|
||||
},
|
||||
"inmemory": {
|
||||
"MaxRdSecond": 0,
|
||||
"EnableLogging": false,
|
||||
"LockMs": 5000,
|
||||
"SleepMs": 300,
|
||||
"DBConfig": {
|
||||
"SizeLimit": 10000,
|
||||
"ExpirationScanFrequency": 60, // InMemory的过期扫描频率,默认值是60秒
|
||||
"EnableReadDeepClone": true,
|
||||
"EnableWriteDeepClone": false
|
||||
}
|
||||
}
|
||||
},
|
||||
//jwt授权认证的一些设置
|
||||
"JwtConfig": {
|
||||
"SecretKey": "8kh2luzmp0oq9wfbdeasygj647vr531n",
|
||||
|
||||
@@ -53,9 +53,7 @@
|
||||
<PackageReference Include="Autofac.Extensions.DependencyInjection" Version="8.0.0" />
|
||||
<PackageReference Include="Autofac.Extras.DynamicProxy" Version="6.0.1" />
|
||||
<PackageReference Include="AutoMapper.Extensions.Microsoft.DependencyInjection" Version="12.0.0" />
|
||||
<PackageReference Include="EasyCaching.CSRedis" Version="1.9.0" />
|
||||
<PackageReference Include="EasyCaching.InMemory" Version="1.9.0" />
|
||||
<PackageReference Include="EasyCaching.Serialization.Json" Version="1.9.0" />
|
||||
<PackageReference Include="CSRedisCore" Version="3.8.670" />
|
||||
<PackageReference Include="Essensoft.Paylink.Alipay" Version="4.1.0" />
|
||||
<PackageReference Include="Essensoft.Paylink.WeChatPay" Version="4.1.0" />
|
||||
<PackageReference Include="Hangfire" Version="1.7.33" />
|
||||
|
||||
@@ -14,18 +14,14 @@ using CoreCms.Net.Swagger;
|
||||
using CoreCms.Net.Task;
|
||||
using CoreCms.Net.Utility;
|
||||
using CoreCms.Net.WeChat.Service.Mediator;
|
||||
using EasyCaching.Core;
|
||||
using Essensoft.Paylink.Alipay;
|
||||
using Essensoft.Paylink.WeChatPay;
|
||||
using Hangfire;
|
||||
using Hangfire.Dashboard.BasicAuthorization;
|
||||
using MediatR;
|
||||
using Microsoft.AspNetCore.Builder;
|
||||
using Microsoft.AspNetCore.Hosting;
|
||||
using Microsoft.AspNetCore.HttpOverrides;
|
||||
using Microsoft.AspNetCore.Mvc.Controllers;
|
||||
using Microsoft.AspNetCore.Mvc;
|
||||
using Microsoft.Extensions.Configuration;
|
||||
using Microsoft.Extensions.DependencyInjection;
|
||||
using Microsoft.Extensions.DependencyInjection.Extensions;
|
||||
using Microsoft.Extensions.Hosting;
|
||||
@@ -143,27 +139,6 @@ YitIdHelper.SetIdGenerator(options);
|
||||
// 初始化以后,即可在任何需要生成ID的地方,调用以下方法:
|
||||
//var newId = YitIdHelper.NextId();
|
||||
|
||||
|
||||
#region 缓存配置
|
||||
string cacheProviderName = "default";
|
||||
builder.Services.AddEasyCaching(options =>
|
||||
{
|
||||
////使用文档 https://easycaching.readthedocs.io/en/latest
|
||||
if (AppSettingsConstVars.RedisUseCache)
|
||||
{
|
||||
options.UseCSRedis(builder.Configuration);
|
||||
cacheProviderName = EasyCachingConstValue.DefaultCSRedisName;
|
||||
}
|
||||
else
|
||||
{
|
||||
cacheProviderName = EasyCachingConstValue.DefaultInMemoryName;
|
||||
options.UseInMemory(builder.Configuration);
|
||||
}
|
||||
options.WithJson(cacheProviderName);
|
||||
|
||||
});
|
||||
#endregion
|
||||
|
||||
#region AutoFac注册============================================================================
|
||||
|
||||
builder.Host.UseServiceProviderFactory(new AutofacServiceProviderFactory());
|
||||
@@ -210,8 +185,6 @@ app.UseRequestResponseLog();
|
||||
app.UseRecordAccessLogsMildd(GlobalEnumVars.CoreShopSystemCategory.Api.ToString());
|
||||
// 记录ip请求 (注意开启权限,不然本地无法写入)
|
||||
app.UseIpLogMildd();
|
||||
//注册csredis中间件处理
|
||||
Storage.Container = app.Services.CreateScope().ServiceProvider.GetAutofacRoot();
|
||||
#endregion
|
||||
|
||||
//强制显示中文
|
||||
|
||||
@@ -27,37 +27,6 @@
|
||||
// 如果采用容器化部署Service 要写成redis的服务名,否则写地址
|
||||
"ConnectionString": "127.0.0.1:6379,password=,connectTimeout=30000,responseTimeout=30000,abortConnect=false,connectRetry=1,syncTimeout=10000,DefaultDatabase=9" //redis数据库连接字符串
|
||||
},
|
||||
"easycaching": {
|
||||
"csredis": {
|
||||
"MaxRdSecond": 0, //预防缓存在同一时间全部失效,可以为每个key的过期时间添加一个随机的秒数,默认值是120秒
|
||||
"EnableLogging": false, // 是否开启日志,默认值是false
|
||||
"LockMs": 5000, // 互斥锁的存活时间, 默认值是5000毫秒
|
||||
"SleepMs": 300, // 没有获取到互斥锁时的休眠时间,默认值是300毫秒
|
||||
"dbconfig": {
|
||||
"ConnectionStrings": [
|
||||
"127.0.0.1:6379,password=,connectTimeout=30000,responseTimeout=30000,abortConnect=false,connectRetry=1,syncTimeout=10000,DefaultDatabase=9" //如果没有密码请保持为空
|
||||
],
|
||||
//"Sentinels": [
|
||||
// "192.169.1.10:26379",
|
||||
// "192.169.1.11:26379",
|
||||
// "192.169.1.12:26379"
|
||||
//],
|
||||
"ReadOnly": false
|
||||
}
|
||||
},
|
||||
"inmemory": {
|
||||
"MaxRdSecond": 0,
|
||||
"EnableLogging": false,
|
||||
"LockMs": 5000,
|
||||
"SleepMs": 300,
|
||||
"DBConfig": {
|
||||
"SizeLimit": 10000,
|
||||
"ExpirationScanFrequency": 60, // InMemory的过期扫描频率,默认值是60秒
|
||||
"EnableReadDeepClone": true,
|
||||
"EnableWriteDeepClone": false
|
||||
}
|
||||
}
|
||||
},
|
||||
//jwt授权认证的一些设置
|
||||
"JwtConfig": {
|
||||
"SecretKey": "8kh2luzmp0oq9wfbdeasygj647vr531n",
|
||||
|
||||
Reference in New Issue
Block a user