StackExchange.Redis 封装类

 

 

using StackExchange.Redis;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Configuration;
using Newtonsoft.Json;

namespace Services
{
    public class CacheService
    {
        private static CacheService instance = new CacheService();
        private static Logger logger = LogManager.GetCurrentClassLogger();

        int Default_Timeout = 20;//默认超时时间(单位秒)
        ConnectionMultiplexer redisConnection;
        IDatabase cache;

        /// <summary>
        /// 连接超时设置
        /// </summary>
        public int TimeOut
        {
            get
            {
                return Default_Timeout;
            }
            set
            {
                Default_Timeout = value;
            }
        }
        /// <summary>
        /// 构造函数
        /// </summary>
        private CacheService()
        {
            //redisConnection = ConnectionMultiplexer.Connect(ConfigurationManager.ConnectionStrings["RedisConnection"].ConnectionString);
            redisConnection = ConnectionMultiplexer.Connect(AppConfig.connectClientRedis);


            #region 注册事件
            //注册如下事件
            redisConnection.ConnectionFailed += MuxerConnectionFailed;
            redisConnection.ConnectionRestored += MuxerConnectionRestored;
            redisConnection.ErrorMessage += MuxerErrorMessage;
            redisConnection.ConfigurationChanged += MuxerConfigurationChanged;
            redisConnection.HashSlotMoved += MuxerHashSlotMoved;
            redisConnection.InternalError += MuxerInternalError;
            #endregion

            cache = redisConnection.GetDatabase();

        }
        /// <summary>
        /// 实例化
        /// </summary>
        /// <returns></returns>
        public static CacheService GetInstance()
        {
            return instance;
        }
        /// <summary>
        /// 保存一个对象
        /// </summary>
        /// <typeparam name="T">泛型对象</typeparam>
        /// <param name="key">key</param>
        /// <param name="obj">对象</param>
        /// <returns></returns>
        public bool Set<T>(string key, T obj)
        {
            try
            {
                // var timeSpan = TimeSpan.FromSeconds(TimeOut);
                var json = ConvertJson(obj);
                return cache.StringSet(key, json);
            }
            catch (Exception ex)
            {
                logger.Error("=========== Class:CacheService method:Set ===========");
                logger.Error("=========== Key:" + key + "   value:" + ConvertJson(obj) + "===========");
                logger.Error(ex);
            }
            return false;

        }
        /// <summary>
        /// 获取一个key的对象
        /// </summary>
        /// <typeparam name="T"></typeparam>
        /// <param name="key"></param>
        /// <returns></returns>
        public T Get<T>(string key)
        {
            RedisValue values = cache.StringGet(key);
            return ConvertObj<T>(values);
        }
        public void Batch(IEnumerable<KeyValuePair<string, string>> keyValuePairs)
        {
            var batch = cache.CreateBatch();
            foreach (var k in keyValuePairs)
            {
                //var json = ConvertJson(k.Value);
                batch.StringSetAsync(k.Key, k.Value);
                //batch.SetAddAsync(k.Key, k.Value);
            }
            batch.Execute();
        }
        #region JSON,T 相互转换
        private string ConvertJson<T>(T value)
        {
            string result = value is string ? value.ToString() : JsonConvert.SerializeObject(value);
            return result;
        }
        private T ConvertObj<T>(RedisValue value)
        {
            if (value.IsNull)
            {
                return default(T);
            }
            return JsonConvert.DeserializeObject<T>(value);
        }
        #endregion
        #region 事件

        /// <summary>
        /// 配置更改时
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private static void MuxerConfigurationChanged(object sender, EndPointEventArgs e)
        {
            logger.Info("Configuration changed: " + e.EndPoint);
        }

        /// <summary>
        /// 发生错误时
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private static void MuxerErrorMessage(object sender, RedisErrorEventArgs e)
        {
            logger.Error("ErrorMessage: " + e.Message);
        }

        /// <summary>
        /// 重新建立连接之前的错误
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private static void MuxerConnectionRestored(object sender, ConnectionFailedEventArgs e)
        {
            logger.Error("ConnectionRestored: " + e.EndPoint);
        }

        /// <summary>
        /// 连接失败 , 如果重新连接成功你将不会收到这个通知
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private static void MuxerConnectionFailed(object sender, ConnectionFailedEventArgs e)
        {
            logger.Error("重新连接: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)
        {
            logger.Info("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)
        {
            logger.Error("InternalError:Message" + e.Exception.Message);
        }

        #endregion 事件
    }
}

 

转载于:https://www.cnblogs.com/cicada/p/10868249.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
NetGain是Stack Overflow(StackExchange)开源的一个高性能的websocket服务端库。       它只有一个dll:StackExchange.NetGain.dll。     Stack Overflow使用 websocket 向用户推送实时的更新内容,比如顶部栏中的通知、投票数、新导航数、新的答案和评论等等。      socket 服务器本身在 web 层上运行,使用原生的 socket。这是一个基于我们的开源库实现的非常小型的应用程序:StackExchange.NetGain。在高峰时刻,我们大约有 50 万个并发的 websocket 连接,这可是一大堆浏览器。一个有趣的事实:其中一些浏览器已经打开超过 18 个月了,得找人去看看那些开发者是不是还活着。下面这张图是本周 websocket 并发量的模式:       为什么用 websocket?在我们这个规模下,它比轮询要有效率得多。通过这种方式,我们可以简单地使用更少资源来推送更多数据,而且对用户而言实时性也更高。安装:Install-Package StackExchange.NetGain代码示例:using System;using System.Net;using StackExchange.NetGain;using StackExchange.NetGain.WebSockets;namespace Example{  public class Program   {    public static void Main (string[] args)     {         IPEndPoint endpoint = new IPEndPoint(IPAddress.Loopback, 6002);        using(var server = new TcpServer())         {             server.ProtocolFactory = WebSocketsSelectorProcessor.Default;             server.ConnectionTimeoutSeconds = 60;             server.Received  = msg =>             {                var conn = (WebSocketConnection)msg.Connection;                string reply = (string)msg.Value   " / "   conn.Host;                 Console.WriteLine("[server] {0}", msg.Value);                 msg.Connection.Send(msg.Context, reply);             };             server.Start("abc", endpoint);             Console.WriteLine("Server running");             Console.ReadKey();         }         Console.WriteLine("Server dead; press any key");         Console.ReadKey();       }     }   } } 标签:WebSocket
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值