zoukankan      html  css  js  c++  java
  • c#之Redis队列

    摘要

    这两天一直在考虑redis队列:一个生产者,多个消费者的情况,这里弄了一个demo进行测试。

    一个例子

    关于如何引用Redisclient 可以参考之前的这篇文章:c#之Redis实践list,hashtable

    生产者一个线程,然后开启多个线程用来消费数据。

    代码如下:

    复制代码
    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Text;
    using System.Threading.Tasks;
    using NServiceKit.Redis;
    using NServiceKit.ServiceClient;
    using System.Threading;
    namespace RedisDemo
    {
        class Program
        {
            static void Main(string[] args)
            {
                Thread thread = new Thread(run);
                thread.Start();
    
                Thread[] threads = new Thread[10];
                for (int i = 0; i < threads.Length; i++)
                {
                    threads[i] = new Thread(Pull);
                    threads[i].Start();
                }
    
                Console.Read();
            }
            private static void Pull()
            {
                IRedisClientFactory factory = RedisClientFactory.Instance;
                using (IRedisClient client = factory.CreateRedisClient("192.168.1.37", 6379))
                {
                    client.Password = "wolfy";
                    while (true)
                    {
                        if (client.GetListCount("Myqueue") > 0)
                        {
                            string result = client.DequeueItemFromList("Myqueue");
                            //如果获取的内容为空,将当前线程挂起1s
                            if (string.IsNullOrEmpty(result))
                            {
                                Thread.SpinWait(1000);
                            }
                            else
                            {
                                Console.WriteLine("Threadid:" + Thread.CurrentThread.ManagedThreadId.ToString() + "	" + result);
                            }
                        }
                        else
                        {
                            //如果当前队列为空,挂起1s
                            Thread.SpinWait(1000);
                        }
                    }
                }
    
            }
            private static void run()
            {
                IRedisClientFactory factory = RedisClientFactory.Instance;
                using (IRedisClient client = factory.CreateRedisClient("192.168.1.37", 6379))
                {
                    client.Password = "wolfy";
                    while (true)
                    {
                        client.EnqueueItemOnList("Myqueue", DateTime.Now.ToString());
                    }
                }
    
    
            }
        }
    }
    复制代码

    测试

    总结

    关于队列有考虑过rabbitmq,msmq等,考虑到公司有现成的redis服务器,所以就考虑使用redis队列。既然实现了一生产者,多个消费者,那么接下来,想实现一种多队列,然后设置队列的容量,通过容量,生产者在入队的时候,根据队列是否满,然后对数据进行分发的情况。

    转载:博客地址:http://www.cnblogs.com/wolf-sun/

  • 相关阅读:
    按需导入NavMenu无法使用情况解决办法
    如果要使用另一台电脑作为服务器,注意关掉防火墙
    mongoose学习
    koa2的学习
    vue中swiper的使用
    447. Number of Boomerangs
    33. Search in Rotated Sorted Array
    461. Hamming Distance
    392. Is Subsequence
    412. Fizz Buzz
  • 原文地址:https://www.cnblogs.com/cqqinjie/p/7297950.html
Copyright © 2011-2022 走看看