zoukankan      html  css  js  c++  java
  • C# Redis消息队列例子2

    • 2 创建类

    创建接口IRedisCache.cs和RedisCache.cs

    using H.Emos.Common.Helper;
    using StackExchange.Redis;
    using System;
    using System.Collections.Generic;
    using System.Text;
    using System.Threading.Tasks;
     
    namespace H.Emos.Common.Redis
    {
        public class RedisCache : IRedisCache
        {
            /// <summary>
            /// 连接字符串
            /// </summary>
            private  readonly string ConnectionString;
            /// <summary>
            /// redis 连接对象
            /// </summary>
            private volatile IConnectionMultiplexer redisConnection;
          
            /// <summary>
            ////// </summary>
            private  readonly object redisConnectLock = new object();
            public RedisCache()
            {
                this.ConnectionString = "127.0.0.1:6379,allowadmin=true,password=123456";
                this.redisConnection = getConnection();
            }
     
            private IConnectionMultiplexer getConnection()
            {
                if(this.redisConnection!=null&&this.redisConnection.IsConnected)
                {
                    return this.redisConnection;
                }
                lock(redisConnectLock)
                {
                    if(this.redisConnection != null)
                    {
                        this.redisConnection.Dispose();
                    }
                    try
                    {
                        this.redisConnection = ConnectionMultiplexer.Connect(this.ConnectionString);
                    }
                    catch (Exception)
                    {
     
                        throw new Exception("redis 服务未启动") ;
                    }
                    return this.redisConnection;
                    
                }
            }
            public void Clear()
            {
                foreach (var endPoint in this.getConnection().GetEndPoints())
                {
                    var server = this.getConnection().GetServer(endPoint);
                    foreach (var key in server.Keys())
                    {
                        redisConnection.GetDatabase().KeyDelete(key);
                    }
                }
            }
     
            public long publish<T>(string topic, T message)
            {
               var  subscriber= redisConnection.GetSubscriber();
                return subscriber.Publish(topic,SerializeHelper.SerializeString(message));
            }
            public string  subscriber(string topic)
            {
                var msg = string.Empty;
                var subscriber = redisConnection.GetSubscriber();
                subscriber.Subscribe(topic,(channel,message)=> {
     
                     msg=message;
                });
                return msg;
            }
     
            public string stringGet(string key)
            {
                return redisConnection.GetDatabase().StringGet(key);
            }
     
            public bool stringSet(string key, string keyValue,TimeSpan time)
            {
                return redisConnection.GetDatabase().StringSet(key,keyValue,time);
            }
     
            public bool stringSet<T>(string key, T keyValue,TimeSpan time)
            {
                return redisConnection.GetDatabase().StringSet(key, SerializeHelper.Serialize(keyValue),time);
            }
     
            public async Task<bool> taskStringSet(string key, string keyValue)
            {
                return await redisConnection.GetDatabase().StringSetAsync(key, keyValue);
            }
        }
    }
    using StackExchange.Redis;
    using System;
    using System.Collections.Generic;
    using System.Text;
    using System.Threading.Tasks;
     
    namespace H.Emos.Common.Redis
    {
         public interface IRedisCache
        {
            bool stringSet(string key, string keyValue,TimeSpan time);
            string stringGet(string key);
            bool stringSet<T>(string key, T keyVale,TimeSpan time);
     
            Task<bool> taskStringSet(string key, string keyValue);
            long publish<T>(string topic,T message);
            string subscriber(string topic);
        }
    }
    ————————————————
    版权声明:本文为CSDN博主「Wonderful1025」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    原文链接:https://blog.csdn.net/Wonderful1025/article/details/106475960/

    在WeatherForestcastController中构造函数注入,然后测试

    [HttpGet]
            public IEnumerable<WeatherForecast> Get()
            {
                var rng = new Random();
             //   _redisCache.stringSet("test01","test01",TimeSpan.FromHours(5));
     
                WeatherForecast weatherForecast = new WeatherForecast();
                weatherForecast.Date = DateTime.Now;
                weatherForecast.TemperatureC = rng.Next(-20, 55);
                weatherForecast.Summary = Summaries[rng.Next(2)];
                var value=_redisCache.publish("redisChat",weatherForecast);
              
                var tt= Enumerable.Range(1, 5).Select(index => new WeatherForecast
                {
                    Date = DateTime.Now.AddDays(index),
                    TemperatureC = rng.Next(-20, 55),
                    Summary = Summaries[rng.Next(Summaries.Length)]
                })
                .ToArray();
     
                return tt;
     
            }
    ————————————————
    版权声明:本文为CSDN博主「Wonderful1025」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    原文链接:https://blog.csdn.net/Wonderful1025/article/details/106475960/

    人各有命,上天注定,有人天生为王,有人落草为寇。脚下的路,如果不是你自己的选择,那么旅程的终点在哪,也没人知道。你会走到哪,会遇到谁,都不一定。
  • 相关阅读:
    [编程题] 基础 [位运算基础]
    [编程题] lc [191. 位1的个数]
    [编程题] lc [69. x 的平方根]
    php 中php-fpm工作原理
    redis分布式锁
    3种Redis分布式锁的对比
    php使用数据库的并发问题(乐观锁与悲观锁)
    php观察者模式应用场景实例详解
    [Usaco2008 Jan]电话网络
    关于二分图结论的一些证明
  • 原文地址:https://www.cnblogs.com/ZkbFighting/p/15149287.html
Copyright © 2011-2022 走看看