zoukankan      html  css  js  c++  java
  • c# Redis 使用


    1、服务端两个版本
    窗口版与安装windows服务版

    1.1、窗口版

    下载地址:https://github.com/dmajkic/redis/downloads

    redis-server.exe:服务程序
    redis-check-dump.exe:本地数据库检查
    redis-check-aof.exe:更新日志检查
    redis-benchmark.exe:性能测试,用以模拟同时由N个客户端发送M个 SETs/GETs 查询.
    redis-cli.exe: 服务端开启后,我们的客户端就可以输入各种命令测试了

    首先以管理员身份打开cmd (窗口+R),进入到安装包下载的位置。输入:redis-server.exe redis.conf 开启Redis服务。提示信息没有报错表示启动成功。

    客户端测试,双击打开redis-cli.exe 输入“set aaa 1234”,回车,提示ok,表示缓存写入成功, 再输入"get aaa",回车,即可取到缓存的值

    1.2、安装windows服务版

    下载地址:https://github.com/rgl/redis/downloads

    下载完成后直接点击.exe下一步下一步OK。安装完后我们会在windows服务中找到Redis Service服务。即可跟窗口版效果一样测试客户端。
    (注:如果启动失败肯定是端口被占用,如窗口版的测试窗口没关闭掉 redis 端口是 6379)

    2、使用(服务端必须运行中)
    新建控制台应用程序,下载dll,RedisClient 引用
    粘贴以下代码即可马上使用,取消注释部分一块块测试

     static void Main(string[] args)
            {
                //在Redis中存储常用的5种数据类型:String,Hash,List,SetSorted set
    
                RedisClient client = new RedisClient("localhost", 6379);
                client.FlushAll();
    
                #region string
                //client.Add<string>("StringValueTime", "我已设置过期时间噢30秒后会消失", DateTime.Now.AddMilliseconds(10000));
                //while (true)
                //{
                //    if (client.ContainsKey("StringValueTime"))
                //    {
                //        Console.WriteLine("String.键:StringValue,值:{0} {1}", client.Get<string>("StringValueTime"), DateTime.Now);
                //        Thread.Sleep(1000);
                //    }
                //    else
                //    {
                //        Console.WriteLine("键:StringValue,值:我已过期 {0}", DateTime.Now);
                //        Thread.Sleep(1000);
                //        break;
                //    }
                //}
    
                //client.Add<string>("StringValue", " String和Memcached操作方法差不多");
                //Console.WriteLine("数据类型为:String.键:StringValue,值:{0}", client.Get<string>("StringValue"));
    
                //Student stud = new Student() { id = "1001", name = "李四" };
                //client.Add<Student>("StringEntity", stud);
                //Student Get_stud = client.Get<Student>("StringEntity");
                //Console.WriteLine("数据类型为:String.键:StringEntity,值:{0} {1}", Get_stud.id, Get_stud.name);
                #endregion
    
                #region Hash
                //client.SetEntryInHash("HashID", "Name", "张三");
                //client.SetEntryInHash("HashID", "Age", "24");
                //client.SetEntryInHash("HashID", "Sex", "男");
                //client.SetEntryInHash("HashID", "Address", "上海市XX号XX室");
    
                //List<string> HaskKey = client.GetHashKeys("HashID");
                //foreach (string key in HaskKey)
                //{
                //    Console.WriteLine("HashID--Key:{0}", key);
                //}
                
                //List<string> HaskValue = client.GetHashValues("HashID");
                //foreach (string value in HaskValue)
                //{
                //    Console.WriteLine("HashID--Value:{0}", value);
                //}
                
    
                //List<string> AllKey = client.GetAllKeys(); //获取所有的key。
                //foreach (string Key in AllKey)
                //{
                //    Console.WriteLine("AllKey--Key:{0}", Key);
                //}
                #endregion
    
                #region List
                /*
                 * list是一个链表结构,主要功能是push,pop,获取一个范围的所有的值等,操作中key理解为链表名字。 
                 * Redis的list类型其实就是一个每个子元素都是string类型的双向链表。我们可以通过push,pop操作从链表的头部或者尾部添加删除元素,
                 * 这样list既可以作为栈,又可以作为队列。Redis list的实现为一个双向链表,即可以支持反向查找和遍历,更方便操作,不过带来了部分额外的内存开销,
                 * Redis内部的很多实现,包括发送缓冲队列等也都是用的这个数据结构 
                 */
                //client.EnqueueItemOnList("QueueListId", "1.张三");  //入队
                //client.EnqueueItemOnList("QueueListId", "2.张四");
                //client.EnqueueItemOnList("QueueListId", "3.王五");
                //client.EnqueueItemOnList("QueueListId", "4.王麻子");
                //int q = client.GetListCount("QueueListId");
                //for (int i = 0; i < q; i++)
                //{                
                //    Console.WriteLine("QueueListId出队值:{0}", client.DequeueItemFromList("QueueListId"));   //出队(队列先进先出)
                //}
                         
                //client.PushItemToList("StackListId", "1.张三");  //入栈
                //client.PushItemToList("StackListId", "2.张四");
                //client.PushItemToList("StackListId", "3.王五");
                //client.PushItemToList("StackListId", "4.王麻子");
                //int p = client.GetListCount("StackListId");
                //for (int i = 0; i < p; i++)
                //{           
                //    Console.WriteLine("StackListId出栈值:{0}", client.PopItemFromList("StackListId"));   //出栈(栈先进后出)
                //}
               
                #endregion
    
                #region Set无序集合
                /*
                 它是string类型的无序集合。set是通过hash table实现的,添加,删除和查找,对集合我们可以取并集,交集,差集
                 */
                //client.AddItemToSet("Set1001", "小A");
                //client.AddItemToSet("Set1001", "小B");
                //client.AddItemToSet("Set1001", "小C");
                //client.AddItemToSet("Set1001", "小D");
                //HashSet<string> hastsetA = client.GetAllItemsFromSet("Set1001");
                //foreach (string item in hastsetA)
                //{
                //    Console.WriteLine("Set无序集合ValueA:{0}", item); //出来的结果是无须的
                //}
                
    
                //client.AddItemToSet("Set1002", "小K");
                //client.AddItemToSet("Set1002", "小C");
                //client.AddItemToSet("Set1002", "小A");
                //client.AddItemToSet("Set1002", "小J");
                //HashSet<string> hastsetB = client.GetAllItemsFromSet("Set1002");
                //foreach (string item in hastsetB)
                //{
                //    Console.WriteLine("Set无序集合ValueB:{0}", item); //出来的结果是无须的
                //}
                
    
                //HashSet<string> hashUnion = client.GetUnionFromSets(new string[] { "Set1001", "Set1002" });
                //foreach (string item in hashUnion)
                //{
                //    Console.WriteLine("求Set1001和Set1002的并集:{0}", item); //并集
                //}
    
                //HashSet<string> hashG = client.GetIntersectFromSets(new string[] { "Set1001", "Set1002" });
                //foreach (string item in hashG)
                //{
                //    Console.WriteLine("求Set1001和Set1002的交集:{0}", item);  //交集
                //}
    
                //HashSet<string> hashD = client.GetDifferencesFromSet("Set1001", new string[] { "Set1002" });  //[返回存在于第一个集合,但是不存在于其他集合的数据。差集]
                //foreach (string item in hashD)
                //{
                //    Console.WriteLine("求Set1001和Set1002的差集:{0}", item);  //差集
                //}
    
                #endregion
    
                #region  SetSorted 有序集合
                /*
                 sorted set 是set的一个升级版本,它在set的基础上增加了一个顺序的属性,这一属性在添加修改.元素的时候可以指定,
                 * 每次指定后,zset(表示有序集合)会自动重新按新的值调整顺序。可以理解为有列的表,一列存 value,一列存顺序。操作中key理解为zset的名字.
                 */
                client.AddItemToSortedSet("SetSorted1001", "1.刘仔");
                client.AddItemToSortedSet("SetSorted1001", "2.星仔");
                client.AddItemToSortedSet("SetSorted1001", "3.猪仔");
                List<string> listSetSorted = client.GetAllItemsFromSortedSet("SetSorted1001");
                foreach (string item in listSetSorted)
                {
                    Console.WriteLine("SetSorted有序集合{0}", item);
                }
                #endregion
            }
    

      

  • 相关阅读:
    [剑指Offer]59-队列的最大值(题目二待补)
    [Java学习]面向对象-package;内部类;UML图表示六种关系
    已安全化的ActiveX控件卸载时出现"DllUnregisterServer函数出错,错误代码:0x80070002"问题解决
    Win10 启动64位IE浏览器——修改注册表方法
    系统托盘弹出通知或气泡
    LPCTSTR 字符串获取其长度
    ActiveX控件获取不到对象属性或者方法的原因分析
    时钟周期 VS 机器周期
    VS2017 ATL创建ActiveX编程要点
    incremental linking(增量链接)的作用
  • 原文地址:https://www.cnblogs.com/wdw31210/p/9956842.html
Copyright © 2011-2022 走看看