|
|
@@ -0,0 +1,140 @@
|
|
|
+using System;
|
|
|
+using System.Collections.Concurrent;
|
|
|
+using System.Configuration;
|
|
|
+using StackExchange.Redis;
|
|
|
+
|
|
|
+namespace Masuit.Tools.NoSQL
|
|
|
+{
|
|
|
+ /// <summary>
|
|
|
+ /// ConnectionMultiplexer对象管理帮助类
|
|
|
+ /// </summary>
|
|
|
+ public static class RedisConnectionManager
|
|
|
+ {
|
|
|
+ /// <summary>
|
|
|
+ /// Redis服务器连接字符串,在config配置文件中的ConnectionStrings节下配置,name固定为RedisHosts,值的格式:127.0.0.1:6379,allowadmin=true,如:<br/>
|
|
|
+ /// <connectionStrings><br/>
|
|
|
+ /// <add name = "RedisHosts" connectionString="127.0.0.1:6379,allowadmin=true"/><br/>
|
|
|
+ /// </connectionStrings>
|
|
|
+ /// </summary>
|
|
|
+ public static readonly string RedisConnectionString = ConfigurationManager.ConnectionStrings["RedisHosts"]?.ConnectionString ?? "127.0.0.1:6379,allowadmin=true";
|
|
|
+
|
|
|
+ private static readonly object Locker = new object();
|
|
|
+ private static ConnectionMultiplexer _instance;
|
|
|
+ private static readonly ConcurrentDictionary<string, ConnectionMultiplexer> ConnectionCache = new ConcurrentDictionary<string, ConnectionMultiplexer>();
|
|
|
+
|
|
|
+ /// <summary>
|
|
|
+ /// 单例获取
|
|
|
+ /// </summary>
|
|
|
+ public static ConnectionMultiplexer Instance
|
|
|
+ {
|
|
|
+ get
|
|
|
+ {
|
|
|
+ if (_instance == null)
|
|
|
+ {
|
|
|
+ lock (Locker)
|
|
|
+ {
|
|
|
+ if (_instance == null || !_instance.IsConnected)
|
|
|
+ {
|
|
|
+ _instance = GetManager();
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ return _instance;
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ /// <summary>
|
|
|
+ /// 缓存获取
|
|
|
+ /// </summary>
|
|
|
+ /// <param name="connectionString">连接字符串</param>
|
|
|
+ /// <returns>连接对象</returns>
|
|
|
+ public static ConnectionMultiplexer GetConnectionMultiplexer(string connectionString)
|
|
|
+ {
|
|
|
+ if (!ConnectionCache.ContainsKey(connectionString))
|
|
|
+ {
|
|
|
+ ConnectionCache[connectionString] = GetManager(connectionString);
|
|
|
+ }
|
|
|
+ return ConnectionCache[connectionString];
|
|
|
+ }
|
|
|
+
|
|
|
+ private static ConnectionMultiplexer GetManager(string connectionString = null)
|
|
|
+ {
|
|
|
+ connectionString = connectionString ?? RedisConnectionString;
|
|
|
+ var connect = ConnectionMultiplexer.Connect(ConfigurationOptions.Parse(connectionString, true));
|
|
|
+
|
|
|
+ //注册如下事件
|
|
|
+ connect.ConnectionFailed += MuxerConnectionFailed;
|
|
|
+ connect.ConnectionRestored += MuxerConnectionRestored;
|
|
|
+ connect.ErrorMessage += MuxerErrorMessage;
|
|
|
+ connect.ConfigurationChanged += MuxerConfigurationChanged;
|
|
|
+ connect.HashSlotMoved += MuxerHashSlotMoved;
|
|
|
+ connect.InternalError += MuxerInternalError;
|
|
|
+
|
|
|
+ return connect;
|
|
|
+ }
|
|
|
+
|
|
|
+ #region 事件
|
|
|
+
|
|
|
+ /// <summary>
|
|
|
+ /// 配置更改时
|
|
|
+ /// </summary>
|
|
|
+ /// <param name="sender">触发者</param>
|
|
|
+ /// <param name="e">事件参数</param>
|
|
|
+ private static void MuxerConfigurationChanged(object sender, EndPointEventArgs e)
|
|
|
+ {
|
|
|
+ Console.WriteLine("Configuration changed: " + e.EndPoint);
|
|
|
+ }
|
|
|
+
|
|
|
+ /// <summary>
|
|
|
+ /// 发生错误时
|
|
|
+ /// </summary>
|
|
|
+ /// <param name="sender"></param>
|
|
|
+ /// <param name="e"></param>
|
|
|
+ private static void MuxerErrorMessage(object sender, RedisErrorEventArgs e)
|
|
|
+ {
|
|
|
+ Console.WriteLine("ErrorMessage: " + e.Message);
|
|
|
+ }
|
|
|
+
|
|
|
+ /// <summary>
|
|
|
+ /// 重新建立连接之前的错误
|
|
|
+ /// </summary>
|
|
|
+ /// <param name="sender"></param>
|
|
|
+ /// <param name="e"></param>
|
|
|
+ private static void MuxerConnectionRestored(object sender, ConnectionFailedEventArgs e)
|
|
|
+ {
|
|
|
+ Console.WriteLine("ConnectionRestored: " + e.EndPoint);
|
|
|
+ }
|
|
|
+
|
|
|
+ /// <summary>
|
|
|
+ /// 连接失败 , 如果重新连接成功你将不会收到这个通知
|
|
|
+ /// </summary>
|
|
|
+ /// <param name="sender"></param>
|
|
|
+ /// <param name="e"></param>
|
|
|
+ private static void MuxerConnectionFailed(object sender, ConnectionFailedEventArgs e)
|
|
|
+ {
|
|
|
+ Console.WriteLine("重新连接:Endpoint failed: " + e.EndPoint + ", " + e.FailureType + (e.Exception == null ? "" : (", " + e.Exception.Message)));
|
|
|
+ }
|
|
|
+
|
|
|
+ /// <summary>
|
|
|
+ /// 更改集群
|
|
|
+ /// </summary>
|
|
|
+ /// <param name="sender"></param>
|
|
|
+ /// <param name="e"></param>
|
|
|
+ private static void MuxerHashSlotMoved(object sender, HashSlotMovedEventArgs e)
|
|
|
+ {
|
|
|
+ Console.WriteLine("HashSlotMoved:NewEndPoint" + e.NewEndPoint + ", OldEndPoint" + e.OldEndPoint);
|
|
|
+ }
|
|
|
+
|
|
|
+ /// <summary>
|
|
|
+ /// redis类库错误
|
|
|
+ /// </summary>
|
|
|
+ /// <param name="sender"></param>
|
|
|
+ /// <param name="e"></param>
|
|
|
+ private static void MuxerInternalError(object sender, InternalErrorEventArgs e)
|
|
|
+ {
|
|
|
+ Console.WriteLine("InternalError:Message" + e.Exception.Message);
|
|
|
+ }
|
|
|
+
|
|
|
+ #endregion 事件
|
|
|
+ }
|
|
|
+}
|