转自  :http://blog.csdn.net/qiujialongjjj/article/details/16945569

一、初步准备

Redis 是一个开源的使用ANSI C 语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value 数据库。Redis的出现,很大程度补偿了memcached这类key/value存储的不足,在部 分场合可以对关系数据库起到很好的补充作用。
本文主要讲述的是如何使用C#语言来进行Redis分布式缓存的程序编写。首先,需要从github下载最新的32/64位安装(下载地址),解压后根据自己机器的实际情况选择32位或者64位,例如:我机器是64位win7,于是将64bit下所有文件拷贝到D盘根目录下新建文件夹redis中,如图:
 
接下来我们需要在vs中新建一个Redis的测试Demo,并为其添加Redis程序包,如图:
 
至此,Redis分布式编程的准备工作已经完成,可以得到如下示例Demo效果图:

二、Redis服务

 在C# Redis实战(一)中我将所有文件拷贝到了D盘redis文件夹下,其中redis-server.exe即为其服务端程序,双击即开始运行,如图
           
 
可以将此服务设置为windows系统服务,下载Redis服务安装软件,安装即可。
安装完成在服务中找到此服务,将其设置为自动延迟启动即可。
再回到redis文件夹下,找到redis-cli.exe文件,它就是Redis客户端程序。打开,输入:set qiujialong 123
即在Redis中插入了一条key为qiujialong,value为123的数据,继续输入:get qiujialong
得到value保存的数据123。
 
 
如果想知道Redis中一共保存了多少条数据,则可以使用:keys * 来查询:
以上即为Redis服务的安装与它的基本操作,再下一篇文章中将讲述如何使用C#来完成Redis分布式缓存的开发。
 

三、程序配置

C# Redis实战(二)中我们安装好了Redis的系统服务,此时Redis服务已经运行。
现在我们需要让我们的程序能正确读取到Redis服务地址等一系列的配置信息,首先,需要在Web.config文件中添加如下信息:
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <!--
  3. 有关如何配置 ASP.NET 应用程序的详细信息,请访问
  4. http://go.microsoft.com/fwlink/?LinkId=169433
  5. -->
  6. <configuration>
  7. <configSections>
  8. <!-- For more information on Entity Framework configuration, visit http://go.microsoft.com/fwlink/?LinkID=237468 -->
  9. <section name="entityFramework" type="System.Data.Entity.Internal.ConfigFile.EntityFrameworkSection, EntityFramework, Version=5.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission="false" />
  10. <section name="RedisConfig" type="RedisDemo.RedisConfigInfo, RedisDemo"/>
  11. </configSections>
  12. <RedisConfig WriteServerList="127.0.0.1:6379" ReadServerList="127.0.0.1:6379" MaxWritePoolSize="60"
  13. MaxReadPoolSize="60" AutoStart="true" LocalCacheTime="180" RecordeLog="false">
  14. </RedisConfig>
  15. <connectionStrings>
  16. <add name="DefaultConnection" providerName="System.Data.SqlClient" connectionString="Data Source=(LocalDb)\v11.0;Initial Catalog=aspnet-RedisDemo-20131125110945;Integrated Security=SSPI;AttachDBFilename=|DataDirectory|\aspnet-RedisDemo-20131125110945.mdf" />
  17. </connectionStrings>
  18. </configuration>
有了以上信息还不够,还需要用C#代码来读取并且操作,获取Redis配置的程序如下:
  1. public static RedisConfigInfo GetConfig()
  2. {
  3. RedisConfigInfo section = (RedisConfigInfo)ConfigurationManager.GetSection("RedisConfig");
  4. return section;
  5. }
  6. public static RedisConfigInfo GetConfig(string sectionName)
  7. {
  8. RedisConfigInfo section = (RedisConfigInfo)ConfigurationManager.GetSection("RedisConfig");
  9. if (section == null)
  10. throw new ConfigurationErrorsException("Section " + sectionName + " is not found.");
  11. return section;
  12. }
Redis管理类代码:
  1. /// <summary>
  2. /// redis配置文件信息
  3. /// </summary>
  4. private static RedisConfigInfo redisConfigInfo = RedisConfigInfo.GetConfig();
  5. private static PooledRedisClientManager prcm;
  6. /// <summary>
  7. /// 静态构造方法,初始化链接池管理对象
  8. /// </summary>
  9. static RedisManager()
  10. {
  11. CreateManager();
  12. }
  13. /// <summary>
  14. /// 创建链接池管理对象
  15. /// </summary>
  16. private static void CreateManager()
  17. {
  18. string[] writeServerList = SplitString(redisConfigInfo.WriteServerList, ",");
  19. string[] readServerList = SplitString(redisConfigInfo.ReadServerList, ",");
  20. prcm = new PooledRedisClientManager(readServerList, writeServerList,
  21. new RedisClientManagerConfig
  22. {
  23. MaxWritePoolSize = redisConfigInfo.MaxWritePoolSize,
  24. MaxReadPoolSize = redisConfigInfo.MaxReadPoolSize,
  25. AutoStart = redisConfigInfo.AutoStart,
  26. });
  27. }
  28. private static string[] SplitString(string strSource, string split)
  29. {
  30. return strSource.Split(split.ToArray());
  31. }
  32. /// <summary>
  33. /// 客户端缓存操作对象
  34. /// </summary>
  35. public static IRedisClient GetClient()
  36. {
  37. if (prcm == null)
  38. CreateManager();
  39. return prcm.GetClient();
  40. }
  41. 四、写入数据

    C# Redis实战(三)中我们已经配置好了web.config程序,并且能通过C#代码来读取和管理以上配置信息。
    接下来,就可以进行Redis的数据写入了。Redis中可以用Store和StoreAll分别保存单条和多条数据,C#中具体代码如下:
     
    1、保存多条数据
    1. protected void btnOpenDB_Click(object sender, EventArgs e)
    2. {
    3. //System.Diagnostics.Process.Start("D:\\redis\\redis-server.exe");
    4. //lblShow.Text = "Redis已经打开!";
    5. using (var redisClient = RedisManager.GetClient())
    6. {
    7. var user = redisClient.GetTypedClient<User>();
    8. if (user.GetAll().Count > 0)
    9. user.DeleteAll();
    10. var qiujialong = new User
    11. {
    12. Id = user.GetNextSequence(),
    13. Name = "qiujialong",
    14. Job = new Job { Position = ".NET" }
    15. };
    16. var chenxingxing = new User
    17. {
    18. Id = user.GetNextSequence(),
    19. Name = "chenxingxing",
    20. Job = new Job { Position = ".NET" }
    21. };
    22. var luwei = new User
    23. {
    24. Id = user.GetNextSequence(),
    25. Name = "luwei",
    26. Job = new Job { Position = ".NET" }
    27. };
    28. var zhourui = new User
    29. {
    30. Id = user.GetNextSequence(),
    31. Name = "zhourui",
    32. Job = new Job { Position = "Java" }
    33. };
    34. var userToStore = new List<User> { qiujialong, chenxingxing, luwei, zhourui };
    35. user.StoreAll(userToStore);
    36. lblShow.Text = "目前共有:" + user.GetAll().Count.ToString() + "人!";
    37. }
    38. }
    2、保存单条数据
    1. protected void btnInsert_Click(object sender, EventArgs e)
    2. {
    3. if (!string.IsNullOrEmpty(txtName.Text) && !string.IsNullOrEmpty(txtPosition.Text))
    4. {
    5. using (var redisClient = RedisManager.GetClient())
    6. {
    7. var user = redisClient.GetTypedClient<User>();
    8. var newUser = new User
    9. {
    10. Id = user.GetNextSequence(),
    11. Name = txtName.Text,
    12. Job = new Job { Position = txtPosition.Text }
    13. };
    14. user.Store(newUser);
    15. if (user.GetAll().Count > 0)
    16. {
    17. var htmlStr = string.Empty;
    18. foreach (var u in user.GetAll())
    19. {
    20. htmlStr += "<li>ID=" + u.Id + "  姓名:" + u.Name + "  所在部门:" + u.Job.Position + "</li>";
    21. }
    22. lblPeople.Text = htmlStr;
    23. }
    24. lblShow.Text = "目前共有:" + user.GetAll().Count.ToString() + "人!";
    25. }
    26. }
    27. }
    效果图:

C# Redis实战的更多相关文章

  1. Redis实战阅读笔记——开始

    Redis实战这本书,看完以后最大的不是redis本身的东西,而是作者面对实际问题的分析而给出的设计方案,可以看成NoSql设计的应用.个人从这方面收获很多,至于Redis本身的东西,这个就花一两个小 ...

  2. Redis实战阅读笔记——第一章

    Redis 实战 中文版 的20-21页看的人郁闷死了,最后看英文版才明白意思,哎,我理解能力差成这样了 其中,图 1-12 有错误,草,这个是英文版的错--应该是group:programming

  3. redis实战(01)_redis安装

    早就想对redis进行实战操作了,最近看了一些视频和参考书籍,总结总结一下,redis实战内容: 实战前先对redis做一个大概的认识: 现在开始安装redis了... redis的安装下载地址 ht ...

  4. C# Redis实战(二) [转]

    二.Redis服务  在C# Redis实战(一)中我将所有文件拷贝到了D盘redis文件夹下,其中redis-server.exe即为其服务端程序,双击即开始运行,如图               ...

  5. (转)国内外三个不同领域巨头分享的Redis实战经验及使用场景

    随着应用对高性能需求的增加,NoSQL逐渐在各大名企的系统架构中生根发芽.这里我们将为大家分享社交巨头新浪微博.传媒巨头Viacom及图片分享领域佼佼者Pinterest带来的Redis实践,首先我们 ...

  6. Redis实战

    大约一年多前,公司同事开始使用Redis,不清楚是配置,还是版本的问题,当时的Redis经常在使用一段时间后,连接爆满且不释放.印象中,Redis 2.4.8以下的版本由于设计上的主从库同步问题,就会 ...

  7. Redis实战之Redis + Jedis

    用Memcached,对于缓存对象大小有要求,单个对象不得大于1MB,且不支持复杂的数据类型,譬如SET 等.基于这些限制,有必要考虑Redis! 相关链接: Redis实战 Redis实战之Redi ...

  8. Redis实战之征服 Redis + Jedis + Spring (一)

    Redis + Jedis + Spring (一)—— 配置&常规操作(GET SET DEL)接着需要快速的调研下基于Spring框架下的Redis操作. 相关链接: Redis实战 Re ...

  9. Redis实战之征服 Redis + Jedis + Spring (二)

    不得不说,用哈希操作来存对象,有点自讨苦吃! 不过,既然吃了苦,也做个记录,也许以后API升级后,能好用些呢?! 或许,是我的理解不对,没有真正的理解哈希表. 相关链接: Redis实战 Redis实 ...

随机推荐

  1. MySQL锁系列3 MDL锁

    http://www.cnblogs.com/xpchild/p/3790139.html   MySQL为了保护数据字典元数据,使用了metadata lock,即MDL锁,保证在并发的情况下,结构 ...

  2. Metadata Lock原理3

      http://blog.itpub.net/26515977/viewspace-1208250/   腾讯工程师 随着5.5.3引入MDL,更多的Query被“Waiting for table ...

  3. 关于Service常驻内存不被清理的解决方法.

    众所周知, Service是跑后台的. 但是有些Rom厂商把一键清理做的真是太好用了, 以至于一键清理变成了一种习惯, Service已经变的不再是Service了. 那为什么像诸如360, 微信, ...

  4. 1020. Tree Traversals (25)

    the problem is from pat,which website is http://pat.zju.edu.cn/contests/pat-a-practise/1020 and the ...

  5. 《Java程序员面试宝典》读书笔记1

    今天读书发现一个很有趣的问题 请问以下程序会输出什么? public   class   Test2   {  public   static   void   main(String[]   arg ...

  6. SQlServer2008 之 定时执行sql语句作业的制定

    1.打开[SQL Server Management Studio],在[对象资源管理器]列表中选择[SQL Server 代理]: 2.鼠标右击[SQL Server 代理],选择[启动(S)],如 ...

  7. Python 2.x and 3.x String VS Bytes

    In Python 3 unicode strings are the 'regular strings' (str) and byte strings are separate objects. L ...

  8. 通过 Session 操纵对象

    Session 接口是 Hibernate 向应用程序提供的操纵数据库的最主要的接口, 它提供了基本的保存, 更新, 删除和加载 Java 对象的方法. Session 具有一个缓存, 位于缓存中的对 ...

  9. [课程相关]homework-05

    零.准备工作 队伍成员:梁杰,夏天晗,谢祖三. 周五晚上吃完饭,我们就开始了讨论. 这次的要求是写服务器,客户端以及游戏结果动态显示.很明显是三个部分,我们也就顺其自然, 一人一个部分.我负责服务器, ...

  10. Hill Climber and Random Walk