最开始用的是ServiceStack.Redis,但是从4.0版本开始商业化之后,有每个小时访问次数限制6000次访问。这个就很烦了,后来就改成了使用RedisStackExchange。
public class RedisStackExchange
{
#region private field
private static IConnectionMultiplexer _connMultiplexer = null;
///
/// 锁
///
private static readonly object Locker = new object();
///
/// 数据库
///
private readonly IDatabase _db = null;
#endregion private field
public ITransaction GetTransaction()
{
return _db.CreateTransaction();
}
#region 构造函数
public RedisStackExchange(int db = 0)
{
string strconn = ConfigurationManager.ConnectionStrings["RedisDBConnString"].ConnectionString;
string[] redisMaster = strconn.Split(':');
string strPwd = ConfigurationManager.ConnectionStrings["RedisDBPwd"].ConnectionString;
ConfigurationOptions fRedisConfig = new ConfigurationOptions()
{
EndPoints = { { redisMaster[0], int.Parse(redisMaster[1]) } },
Password = strPwd,
KeepAlive = 180,
DefaultDatabase = 0
};
_connMultiplexer = ConnectionMultiplexer.Connect(fRedisConfig);
AddRegisterEvent();
_db = _connMultiplexer.GetDatabase(db);
}
#endregion 构造函数
#region String 操作
///
/// 设置 key 并保存字符串(如果 key 已存在,则覆盖值)
///
///
///
///
///
public bool StringSet(string redisKey, string redisValue, TimeSpan? expiry = null)
{
return _db.StringSet(redisKey, redisValue, expiry);
}
///
/// 保存多个 Key-value
///
///
///
public bool StringSet(IEnumerable> keyValuePairs)
{
var pairs = keyValuePairs.Select(x => new KeyValuePair(x.Key, x.Value));
return _db.StringSet(pairs.ToArray());
}
///
/// 获取字符串
///
///
///
///
public string StringGet(string redisKey, TimeSpan? expiry = null)
{
return _db.StringGet(redisKey);
}
///
/// 存储一个对象(该对象会被序列化保存)
///
///
///
///
///
public bool StringSet(string redisKey, T redisValue, TimeSpan? expiry = null)
{
var json = Serialize(redisValue);
return _db.StringSet(redisKey, json, expiry);
}
///
/// 获取一个对象(会进行反序列化)
///
///
///
///
public T StringGet(string redisKey, TimeSpan? expiry = null)
{
return Deserialize(_db.StringGet(redisKey));
}
#region async
///
/// 保存一个字符串值
///
///
///
///
///
public async Task StringSetAsync(string redisKey, string redisValue, TimeSpan? expiry = null)
{
return await _db.StringSetAsync(redisKey, redisValue, expiry);
}
///
/// 保存一组字符串值
///
///
///
public async Task StringSetAsync(IEnumerable> keyValuePairs)
{
var pairs = keyValuePairs.Select(x => new KeyValuePair(x.Key, x.Value));
return await _db.StringSetAsync(pairs.ToArray());
}
///
/// 获取单个值
///
///
///
///
///
public async Task StringGetAsync(string redisKey, string redisValue, TimeSpan? expiry = null)
{
return await _db.StringGetAsync(redisKey);
}
///
/// 存储一个对象(该对象会被序列化保存)
///
///
///
///
///
public async Task StringSetAsync(string redisKey, T redisValue, TimeSpan? expiry = null)
{
var json = Serialize(redisValue);
return await _db.StringSetAsync(redisKey, json, expiry);
}
///
/// 获取一个对象(会进行反序列化)
///
///
///
///
public async Task StringGetAsync(string redisKey, TimeSpan? expiry = null)
{
return Deserialize(await _db.StringGetAsync(redisKey));
}
#endregion async
#endregion String 操作
#region Hash 操作
///
/// 判断该字段是否存在 hash 中
///
///
///
///
public bool HashExists(string redisKey, string hashField)
{
return _db.HashExists(redisKey, hashField);
}
///
/// 从 hash 中移除指定字段
///
///
///
///
public bool HashDelete(string redisKey, string hashField)
{
return _db.HashDelete(redisKey, hashField);
}
///
/// 从 hash 中移除指定字段
///
///
///
///
public long HashDelete(string redisKey, IEnumerable hashFields)
{
var fields = hashFields.Select(x => (RedisValue)x);
return _db.HashDelete(redisKey, fields.ToArray());
}
///
/// 在 hash 设定值
///
///
///
///
///
public bool HashSet(string redisKey, string hashField, string value)
{
return _db.HashSet(redisKey, hashField, value);
}
///
/// 在 hash 中设定值
///
///
///
public void HashSet(string redisKey, IEnumerable> hashFields)
{
var entries = hashFields.Select(x => new HashEntry(x.Key, x.Value));
_db.HashSet(redisKey, entries.ToArray());
}
///
/// 在 hash 中获取值
///
///
///
///
public string HashGet(string redisKey, string hashField)
{
return _db.HashGet(redisKey, hashField);
}
///
/// 在 hash 中获取值
///
///
///
///
public IEnumerable HashGet(string redisKey, IEnumerable hashFields)
{
var fields = hashFields.Select(x => (RedisValue)x);
return ConvertStrings(_db.HashGet(redisKey, fields.ToArray()));
}
///
/// 从 hash 返回所有的字段值
///
///
///
public IEnumerable HashKeys(string redisKey)
{
return ConvertStrings(_db.HashKeys(redisKey));
}
///
/// 返回 hash 中的所有值
///
///
///
public IEnumerable HashValues(string redisKey)
{
return ConvertStrings(_db.HashValues(redisKey));
}
///
/// 在 hash 设定值(序列化)
///
///
///
///
///
public bool HashSet(string redisKey, string hashField, T redisValue)
{
var json = Serialize(redisValue);
return _db.HashSet(redisKey, hashField, json);
}
///
/// 在 hash 中获取值(反序列化)
///
///
///
///
public T HashGet(string redisKey, string hashField)
{
return Deserialize(_db.HashGet(redisKey, hashField));
}
//批量新增 SortedSet
///
/// /
///
///
///
///
public bool SortedSetAddList(string redisKey, Dictionary seList)
{
bool result = false;
try
{
var batch = _db.CreateBatch();
foreach (var se in seList)
{
batch.SortedSetAddAsync(redisKey, se.Key, se.Value);
}
batch.Execute();
result = true;
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
}
return result;
}
//批量新增 SortedSet
///
/// /
///
///
///
///
public bool SortedSetAddList(string redisKey, Dictionary seList)
{
bool result = false;
try
{
var batch = _db.CreateBatch();
foreach (var se in seList)
{
batch.SortedSetAddAsync(redisKey, se.Key, se.Value);
}
batch.Execute();
result = true;
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
}
return result;
}
//批量新增 SortedSet
///
/// /
///
///
///
///
public bool SortedSetAddList(string redisKey, Dictionary seList)
{
bool result = false;
try
{
var batch = _db.CreateBatch();
foreach (var se in seList)
{
batch.SortedSetAddAsync(redisKey, se.Key, se.Value);
}
batch.Execute();
result = true;
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
}
return result;
}
///
/// 在 hash 中获取值(反序列化)
///
///
///
///
public bool HashAddList(string redisKey, Dictionary seList)
{
bool result = false;
try
{
var batch = _db.CreateBatch();
foreach (var se in seList)
{
batch.HashSetAsync(redisKey, se.Key, se.Value);
}
batch.Execute();
result = true;
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
}
return result;
}
public Dictionary HashGetList(string redisKey, List ids)
{
Dictionary result = new Dictionary();
List> valueList = new List>();
try
{
var batch = _db.CreateBatch();
foreach (int id in ids)
{
Task tres = batch.HashGetAsync(redisKey, (RedisValue)id);
valueList.Add(tres);
}
batch.Execute();
for (int i = 0; i < valueList.Count(); i++)
{
result.Add(ids[i], valueList[i].Result.ToString());
}
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
}
return result;
}
public Dictionary HashGetList(string redisKey)
{
Dictionary result = new Dictionary();
List> valueList = new List>();
try
{
var list = HashKeys(redisKey).ToList();
var batch = _db.CreateBatch();
foreach (var id in list)
{
Task tres = batch.HashGetAsync(redisKey, (RedisValue)id);
valueList.Add(tres);
}
batch.Execute();
for (int i = 0; i < valueList.Count(); i++)
{
result.Add(Convert.ToInt32(list[i]), valueList[i].Result.ToString());
}
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
}
return result;
}
public Dictionary GetAllSortedHashKeyValue(string redisKey)
{
Dictionary result = new Dictionary();
List> valueList = new List>();
try
{
var list = SortedSetRangeByRank(redisKey).ToList();
var batch = _db.CreateBatch();
foreach (var id in list)
{
Task tres = batch.SortedSetScoreAsync(redisKey, (RedisValue)id);
valueList.Add(tres);
}
batch.Execute();
for (int i = 0; i < valueList.Count(); i++)
{
result.Add(Convert.ToInt32(list[i]), valueList[i].Result.ToString());
}
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
}
return result;
}
public Dictionary HashGetList(string redisKey, RedisValue[] ids)
{
Dictionary result = new Dictionary();
List> valueList = new List>();
try
{
var batch = _db.CreateBatch();
foreach (int id in ids)
{
Task tres = batch.SortedSetScoreAsync(redisKey, (RedisValue)id);
valueList.Add(tres);
}
batch.Execute();
for (int i = 0; i < valueList.Count(); i++)
{
result.Add(ids[i].ToString(), valueList[i].Result.ToString());
}
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
}
return result;
}
#region async
///
/// 判断该字段是否存在 hash 中
///
///
///
///
public async Task HashExistsAsync(string redisKey, string hashField)
{
return await _db.HashExistsAsync(redisKey, hashField);
}
///
/// 从 hash 中移除指定字段
///
///
///
///
public async Task HashDeleteAsync(string redisKey, string hashField)
{
return await _db.HashDeleteAsync(redisKey, hashField);
}
///
/// 从 hash 中移除指定字段
///
///
///
///
public async Task HashDeleteAsync(string redisKey, IEnumerable hashFields)
{
var fields = hashFields.Select(x => (RedisValue)x);
return await _db.HashDeleteAsync(redisKey, fields.ToArray());
}
///
/// 在 hash 设定值
///
///
///
///
///
public async Task HashSetAsync(string redisKey, string hashField, string value)
{
return await _db.HashSetAsync(redisKey, hashField, value);
}
///
/// 在 hash 中设定值
///
///
///
public async Task HashSetAsync(string redisKey, IEnumerable> hashFields)
{
var entries = hashFields.Select(x => new HashEntry(x.Key, x.Value));
await _db.HashSetAsync(redisKey, entries.ToArray());
}
///
/// 在 hash 中获取值
///
///
///
///
public async Task HashGetAsync(string redisKey, string hashField)
{
return await _db.HashGetAsync(redisKey, hashField);
}
///
/// 在 hash 中获取值
///
///
///
///
///
public async Task> HashGetAsync(string redisKey, IEnumerable hashFields,
string value)
{
var fields = hashFields.Select(x => (RedisValue)x);
return ConvertStrings(await _db.HashGetAsync(redisKey, fields.ToArray()));
}
///
/// 从 hash 返回所有的字段值
///
///
///
public async Task> HashKeysAsync(string redisKey)
{
return ConvertStrings(await _db.HashKeysAsync(redisKey));
}
///
/// 返回 hash 中的所有值
///
///
///
public async Task> HashValuesAsync(string redisKey)
{
return ConvertStrings(await _db.HashValuesAsync(redisKey));
}
///
/// 在 hash 设定值(序列化)
///
///
///
///
///
public async Task HashSetAsync(string redisKey, string hashField, T value)
{
var json = Serialize(value);
return await _db.HashSetAsync(redisKey, hashField, json);
}
///
/// 在 hash 中获取值(反序列化)
///
///
///
///
public async Task HashGetAsync(string redisKey, string hashField)
{
return Deserialize(await _db.HashGetAsync(redisKey, hashField));
}
#endregion async
#endregion Hash 操作
#region List 操作
///
/// 移除并返回存储在该键列表的第一个元素
///
///
///
public string ListLeftPop(string redisKey)
{
return _db.ListLeftPop(redisKey);
}
///
/// 移除并返回存储在该键列表的最后一个元素
///
///
///
public string ListRightPop(string redisKey)
{
return _db.ListRightPop(redisKey);
}
///
/// 移除列表指定键上与该值相同的元素
///
///
///
///
public long ListRemove(string redisKey, string redisValue)
{
return _db.ListRemove(redisKey, redisValue);
}
///
/// 在列表尾部插入值。如果键不存在,先创建再插入值
///
///
///
///
public long ListRightPush(string redisKey, string redisValue)
{
return _db.ListRightPush(redisKey, redisValue);
}
///
/// 在列表头部插入值。如果键不存在,先创建再插入值
///
///
///
///
public long ListLeftPush(string redisKey, string redisValue)
{
return _db.ListLeftPush(redisKey, redisValue);
}
///
/// 返回列表上该键的长度,如果不存在,返回 0
///
///
///
public long ListLength(string redisKey)
{
return _db.ListLength(redisKey);
}
///
/// 返回在该列表上键所对应的元素
///
///
///
///
///
public IEnumerable ListRange(string redisKey, long start = 0L, long stop = -1L)
{
return ConvertStrings(_db.ListRange(redisKey, start, stop));
}
///
/// 移除并返回存储在该键列表的第一个元素
///
///
///
public T ListLeftPop(string redisKey)
{
return Deserialize(_db.ListLeftPop(redisKey));
}
///
/// 移除并返回存储在该键列表的最后一个元素
///
///
///
public T ListRightPop(string redisKey)
{
return Deserialize(_db.ListRightPop(redisKey));
}
///
/// 在列表尾部插入值。如果键不存在,先创建再插入值
///
///
///
///
public long ListRightPush(string redisKey, T redisValue)
{
return _db.ListRightPush(redisKey, Serialize(redisValue));
}
///
/// 在列表头部插入值。如果键不存在,先创建再插入值
///
///
///
///
public long ListLeftPush(string redisKey, T redisValue)
{
return _db.ListLeftPush(redisKey, Serialize(redisValue));
}
#region List-async
///
/// 移除并返回存储在该键列表的第一个元素
///
///
///
public async Task ListLeftPopAsync(string redisKey)
{
return await _db.ListLeftPopAsync(redisKey);
}
///
/// 移除并返回存储在该键列表的最后一个元素
///
///
///
public async Task ListRightPopAsync(string redisKey)
{
return await _db.ListRightPopAsync(redisKey);
}
///
/// 移除列表指定键上与该值相同的元素
///
///
///
///
public async Task ListRemoveAsync(string redisKey, string redisValue)
{
return await _db.ListRemoveAsync(redisKey, redisValue);
}
///
/// 在列表尾部插入值。如果键不存在,先创建再插入值
///
///
///
///
public async Task ListRightPushAsync(string redisKey, string redisValue)
{
return await _db.ListRightPushAsync(redisKey, redisValue);
}
///
/// 在列表头部插入值。如果键不存在,先创建再插入值
///
///
///
///
public async Task ListLeftPushAsync(string redisKey, string redisValue)
{
return await _db.ListLeftPushAsync(redisKey, redisValue);
}
///
/// 返回列表上该键的长度,如果不存在,返回 0
///
///
///
public async Task ListLengthAsync(string redisKey)
{
return await _db.ListLengthAsync(redisKey);
}
///
/// 返回在该列表上键所对应的元素
///
///
///
///
///
public async Task> ListRangeAsync(string redisKey, long start = 0L, long stop = -1L)
{
var query = await _db.ListRangeAsync(redisKey, start, stop);
return query.Select(x => x.ToString());
}
///
/// 移除并返回存储在该键列表的第一个元素
///
///
///
public async Task ListLeftPopAsync(string redisKey)
{
return Deserialize(await _db.ListLeftPopAsync(redisKey));
}
///
/// 移除并返回存储在该键列表的最后一个元素
///
///
///
public async Task ListRightPopAsync(string redisKey)
{
return Deserialize(await _db.ListRightPopAsync(redisKey));
}
///
/// 在列表尾部插入值。如果键不存在,先创建再插入值
///
///
///
///
public async Task ListRightPushAsync(string redisKey, T redisValue)
{
return await _db.ListRightPushAsync(redisKey, Serialize(redisValue));
}
///
/// 在列表头部插入值。如果键不存在,先创建再插入值
///
///
///
///
public async Task ListLeftPushAsync(string redisKey, T redisValue)
{
return await _db.ListLeftPushAsync(redisKey, Serialize(redisValue));
}
#endregion List-async
#endregion List 操作
#region SortedSet 操作
///
/// 从 SortedSet 中移除指定字段
///
///
///
///
public bool SortedSetDelete(string redisKey, string item)
{
return _db.SortedSetRemove(redisKey, item);
}
///
/// SortedSet 新增
///
///
///
///
///
public double SortedSetScore(string redisKey, string member)
{
double? score = _db.SortedSetScore(redisKey, member);
return score == null ? 0 : score.Value;
}
///
/// SortedSet 新增
///
///
///
///
///
public bool SortedSetAdd(string redisKey, string member, double score)
{
return _db.SortedSetAdd(redisKey, member, score);
}
///
/// 在有序集合中返回指定范围的元素,默认情况下从低到高。
///
///
///
///
///
///
public RedisValue[] SortedSetRangeByRank(string redisKey, long start = 0L, long stop = -1L,
OrderType order = OrderType.Descending)
{
return _db.SortedSetRangeByRank(redisKey, start, stop, (Order)order);
}
public Dictionary getGroupScoreListByList(RedisValue[] list)
{
var result = new Dictionary();
if (list != null && list.Length > 0)
{
var List = list.ToList();
List.ForEach(x =>
{
result.Add(x.ToString(), SortedSetScore("Group_Star_Count", x.ToString()));
});
}
return result;
}
public Dictionary getGroupHotListByList(RedisValue[] list)
{
var result = new Dictionary();
if (list != null && list.Length > 0)
{
var List = list.ToList();
List.ForEach(x =>
{
result.Add(x.ToString(), SortedSetScore("Group_Hot", x.ToString()));
});
}
return result;
}
public Dictionary getGroupCommentCountListByList(RedisValue[] list)
{
var result = new Dictionary();
if (list != null && list.Length > 0)
{
var List = list.ToList();
List.ForEach(x =>
{
result.Add(x.ToString(), SortedSetScore("Group_Comment_Count", x.ToString()));
});
}
return result;
}
///
/// 返回有序集合的元素个数
///
///
///
public long SortedSetLength(string redisKey)
{
return _db.SortedSetLength(redisKey);
}
///
/// 返回有序集合的元素个数
///
///
///
///
public bool SortedSetLength(string redisKey, string memebr)
{
return _db.SortedSetRemove(redisKey, memebr);
}
///
/// SortedSet 新增
///
///
///
///
///
public bool SortedSetAdd(string redisKey, T member, double score)
{
var json = Serialize(member);
return _db.SortedSetAdd(redisKey, json, score);
}
///
/// 增量的得分排序的集合中的成员存储键值键按增量
///
///
///
///
///
public double SortedSetIncrement(string redisKey, string member, double value = 1)
{
return _db.SortedSetIncrement(redisKey, member, value);
}
#region SortedSet-Async
///
/// SortedSet 新增
///
///
///
///
///
public async Task SortedSetAddAsync(string redisKey, string member, double score)
{
return await _db.SortedSetAddAsync(redisKey, member, score);
}
///
/// 在有序集合中返回指定范围的元素,默认情况下从低到高。
///
///
///
public async Task SortedSetRangeByRankAsync(string redisKey)
{
return await _db.SortedSetRangeByRankAsync(redisKey);
}
///
/// 返回有序集合的元素个数
///
///
///
public async Task SortedSetLengthAsync(string redisKey)
{
return await _db.SortedSetLengthAsync(redisKey);
}
///
/// 返回有序集合的元素个数
///
///
///
///
public async Task SortedSetRemoveAsync(string redisKey, string memebr)
{
return await _db.SortedSetRemoveAsync(redisKey, memebr);
}
///
/// SortedSet 新增
///
///
///
///
///
public async Task SortedSetAddAsync(string redisKey, T member, double score)
{
var json = Serialize(member);
return await _db.SortedSetAddAsync(redisKey, json, score);
}
///
/// 增量的得分排序的集合中的成员存储键值键按增量
///
///
///
///
///
public Task SortedSetIncrementAsync(string redisKey, string member, double value = 1)
{
return _db.SortedSetIncrementAsync(redisKey, member, value);
}
#endregion SortedSet-Async
#endregion SortedSet 操作
#region key 操作
///
/// 移除指定 Key
///
///
///
public bool KeyDelete(string redisKey)
{
return _db.KeyDelete(redisKey);
}
///
/// 移除指定 Key
///
///
///
public long KeyDelete(IEnumerable redisKeys)
{
var keys = redisKeys.Select(x => (RedisKey)x);
return _db.KeyDelete(keys.ToArray());
}
///
/// 校验 Key 是否存在
///
///
///
public bool KeyExists(string redisKey)
{
return _db.KeyExists(redisKey);
}
///
/// 重命名 Key
///
///
///
///
public bool KeyRename(string redisKey, string redisNewKey)
{
return _db.KeyRename(redisKey, redisNewKey);
}
///
/// 设置 Key 的时间
///
///
///
///
public bool KeyExpire(string redisKey, TimeSpan? expiry)
{
return _db.KeyExpire(redisKey, expiry);
}
#region key-async
///
/// 移除指定 Key
///
///
///
public async Task KeyDeleteAsync(string redisKey)
{
return await _db.KeyDeleteAsync(redisKey);
}
///
/// 移除指定 Key
///
///
///
public async Task KeyDeleteAsync(IEnumerable redisKeys)
{
var keys = redisKeys.Select(x => (RedisKey)x);
return await _db.KeyDeleteAsync(keys.ToArray());
}
///
/// 校验 Key 是否存在
///
///
///
public async Task KeyExistsAsync(string redisKey)
{
return await _db.KeyExistsAsync(redisKey);
}
///
/// 重命名 Key
///
///
///
///
public async Task KeyRenameAsync(string redisKey, string redisNewKey)
{
return await _db.KeyRenameAsync(redisKey, redisNewKey);
}
///
/// 设置 Key 的时间
///
///
///
///
public async Task KeyExpireAsync(string redisKey, TimeSpan? expiry)
{
return await _db.KeyExpireAsync(redisKey, expiry);
}
#endregion key-async
#endregion key 操作
#region 发布订阅
///
/// 订阅
///
///
///
public void Subscribe(RedisChannel channel, Action handle)
{
var sub = _connMultiplexer.GetSubscriber();
sub.Subscribe(channel, handle);
}
///
/// 发布
///
///
///
///
public long Publish(RedisChannel channel, RedisValue message)
{
var sub = _connMultiplexer.GetSubscriber();
return sub.Publish(channel, message);
}
///
/// 发布(使用序列化)
///
///
///
///
///
public long Publish(RedisChannel channel, T message)
{
var sub = _connMultiplexer.GetSubscriber();
return sub.Publish(channel, Serialize(message));
}
#region 发布订阅-async
///
/// 订阅
///
///
///
public async Task SubscribeAsync(RedisChannel channel, Action handle)
{
var sub = _connMultiplexer.GetSubscriber();
await sub.SubscribeAsync(channel, handle);
}
///
/// 发布
///
///
///
///
public async Task PublishAsync(RedisChannel channel, RedisValue message)
{
var sub = _connMultiplexer.GetSubscriber();
return await sub.PublishAsync(channel, message);
}
///
/// 发布(使用序列化)
///
///
///
///
///
public async Task PublishAsync(RedisChannel channel, T message)
{
var sub = _connMultiplexer.GetSubscriber();
return await sub.PublishAsync(channel, Serialize(message));
}
#endregion 发布订阅-async
#endregion 发布订阅
#region private method
///
/// 添加 Key 的前缀
///
///
///
//private static string AddKeyPrefix(string key)
//{
// return "{DefaultKey}:{key}";
//}
///
/// 转换为字符串
///
///
///
///
private static IEnumerable ConvertStrings(IEnumerable list) where T : struct
{
if (list == null) throw new ArgumentNullException();
return list.Select(x => x.ToString());
}
#region 注册事件
///
/// 添加注册事件
///
private static void AddRegisterEvent()
{
_connMultiplexer.ConnectionRestored += ConnMultiplexer_ConnectionRestored;
_connMultiplexer.ConnectionFailed += ConnMultiplexer_ConnectionFailed;
_connMultiplexer.ErrorMessage += ConnMultiplexer_ErrorMessage;
_connMultiplexer.ConfigurationChanged += ConnMultiplexer_ConfigurationChanged;
_connMultiplexer.HashSlotMoved += ConnMultiplexer_HashSlotMoved;
_connMultiplexer.InternalError += ConnMultiplexer_InternalError;
_connMultiplexer.ConfigurationChangedBroadcast += ConnMultiplexer_ConfigurationChangedBroadcast;
}
///
/// 重新配置广播时(通常意味着主从同步更改)
///
///
///
private static void ConnMultiplexer_ConfigurationChangedBroadcast(object sender, EndPointEventArgs e)
{
Console.WriteLine("{nameof(ConnMultiplexer_ConfigurationChangedBroadcast)}: {e.EndPoint}");
}
///
/// 发生内部错误时(主要用于调试)
///
///
///
private static void ConnMultiplexer_InternalError(object sender, InternalErrorEventArgs e)
{
Console.WriteLine("{nameof(ConnMultiplexer_InternalError)}: {e.Exception}");
}
///
/// 更改集群时
///
///
///
private static void ConnMultiplexer_HashSlotMoved(object sender, HashSlotMovedEventArgs e)
{
Console.WriteLine("{nameof(ConnMultiplexer_HashSlotMoved)}: {nameof(e.OldEndPoint)}-{e.OldEndPoint} To {nameof(e.NewEndPoint)}-{e.NewEndPoint}, ");
}
///
/// 配置更改时
///
///
///
private static void ConnMultiplexer_ConfigurationChanged(object sender, EndPointEventArgs e)
{
Console.WriteLine("{nameof(ConnMultiplexer_ConfigurationChanged)}: {e.EndPoint}");
}
///
/// 发生错误时
///
///
///
private static void ConnMultiplexer_ErrorMessage(object sender, RedisErrorEventArgs e)
{
Console.WriteLine("{nameof(ConnMultiplexer_ErrorMessage)}: {e.Message}");
}
///
/// 物理连接失败时
///
///
///
private static void ConnMultiplexer_ConnectionFailed(object sender, ConnectionFailedEventArgs e)
{
Console.WriteLine("{nameof(ConnMultiplexer_ConnectionFailed)}: {e.Exception}");
}
///
/// 建立物理连接时
///
///
///
private static void ConnMultiplexer_ConnectionRestored(object sender, ConnectionFailedEventArgs e)
{
Console.WriteLine("{nameof(ConnMultiplexer_ConnectionRestored)}: {e.Exception}");
}
#endregion 注册事件
///
/// 序列化
///
///
///
private static byte[] Serialize(object obj)
{
if (obj == null)
return null;
var binaryFormatter = new BinaryFormatter();
using (var memoryStream = new MemoryStream())
{
binaryFormatter.Serialize(memoryStream, obj);
var data = memoryStream.ToArray();
return data;
}
}
///
/// 反序列化
///
///
///
///
private static T Deserialize(byte[] data)
{
if (data == null)
return default(T);
var binaryFormatter = new BinaryFormatter();
using (var memoryStream = new MemoryStream(data))
{
var result = (T)binaryFormatter.Deserialize(memoryStream);
return result;
}
}
#endregion private method
}