缓存框架——Redis(一)

一,服务端的安装

        服务端我用的是redis64-2.6.12.1,版本比较低,因为2.8的都安不上,可能是因为自己电脑是windows的原因吧。

        解压完成之后,

    进入到这个文件夹里面,输入:redis-server.exe redis.conf,服务开启成功之后,会这样子:

          

    

         

二,客户端程序的安装

           与memcached一样,我们也可以通过cmd的方式操作缓存,在客户端程序里面,可以使用dll.

                   在。net项目里面,我使用的是ServiceStack.Redis.3.9.29.0。

                  

三,简单Demo示例

                      

             

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

using ServiceStack.Common;
using ServiceStack.ServiceInterface;
using ServiceStack.Redis;
using ServiceStack.Text;

namespace TestRedis
{
    class Program
    {
        static RedisClient Redis = new RedisClient("127.0.0.1", 6379);

        static void Main(string[] args)
        {
            //将字符列表添加到redis
            List<string> storeMembers = new List<string>{"one","two","three" };
            storeMembers.ForEach(x=>Redis.AddItemToList("addItemToList",x));

            //得到指定的key所对应的value集合
            var members = Redis.GetAllItemsFromList("addItemToList");
            members.ForEach(s=>Console.WriteLine("addItemToList:"+s));

            //获取指定索引位置数据
            var item = Redis.GetItemFromList("addItemToList",2);
            Console.WriteLine(item);

            //移除数据
            var list = Redis.Lists["addItemToList"];
            list.Clear();//清空
            list.Remove("two");//移除指定键值

            //存储对象(json序列化方法)它比object序列化方法效率高
            Redis.Set<UserInfo>("userInfo", new UserInfo() { UserName="lhc",Age=12});
            UserInfo userInfo = Redis.Get<UserInfo>("userInfo");
            Console.WriteLine("name="+userInfo.UserName+";age="+userInfo.Age);

            //存储值类型数据
            Redis.Set<int>("my_age", 12);
            int age = Redis.Get<int>("my_age");
            Console.WriteLine("age=" + age);

            //object序列化方式存储
            var ser = new ServiceStack.Redis.Support.ObjectSerializer();
            bool result=Redis.Set<byte[]>("userInfo2",ser.Serialize(new UserInfo(){UserName="pbc",Age=27}));
            UserInfo userInfo2=ser.Deserialize(Redis.Get<byte[]>("userInfo2")) as UserInfo;
            Console.WriteLine("name="+userInfo2.UserName+";age="+userInfo2.Age);

            //也支持列表
            List<UserInfo> userInfoList = new List<UserInfo> {
                new UserInfo{UserName="lhccc",Age=22},
                new UserInfo{UserName="bcss",Age=100}
            };
            Redis.Set<byte[]>("UserInfoList_serialize", ser.Serialize(userInfoList));
            List<UserInfo> userList = ser.Deserialize(Redis.Get<byte[]>("UserInfoList_serialize")) as List<UserInfo>;
            userList.ForEach(
                u => {
                    Console.WriteLine("name="+u.UserName+";age="+u.Age);
                }
                );

            Console.ReadKey();

        }
    }
}

           

                个人感觉,redis比memcached支持数据类型多,而且内存数据可以持久化,性能也不错,关于具体的技术选项分析,见下月吧。

   

时间: 2025-01-01 15:48:50

缓存框架——Redis(一)的相关文章

分布式缓存技术redis学习系列----深入理解Spring Redis的使用

关于spring redis框架的使用,网上的例子很多很多.但是在自己最近一段时间的使用中,发现这些教程都是入门教程,包括很多的使用方法,与spring redis丰富的api大相径庭,真是浪费了这么优秀的一个框架. Spring-data-redis为spring-data模块中对redis的支持部分,简称为"SDR",提供了基于jedis客户端API的高度封装以及与spring容器的整合,事实上jedis客户端已经足够简单和轻量级,而spring-data-redis反而具有&qu

JAVA 开源缓存框架

  JBossCache/TreeCache  JBossCache是一个复制的事务处理缓存,它允许你缓存企业级应用数据来更好的改善性能.缓存数据被自动复制,让你轻松进行Jboss服务器之间的集群工作.JBossCache能够通过Jboss应用服务或其他J2EE容器来运行一个Mbean服务,当然,它也能独立运行. JBossCache包括两个模块:TreeCache和TreeCacheAOP. TreeCache --是一个树形结构复制的事务处理缓存. TreeCacheAOP --是一个"面向

请教一下C#有哪些缓存框架?

问题描述 最近做一个winform项目,里面有大量的数据字典记录.如果客户端每次请求,字典数据都从数据库里获取,这样效率上都有一定影响.能不能在服务端缓存这些数据,用到的时候直接从缓存里取.因为才转过来做C#,之前一直做java开发.对c#了解不是太多.请问一下c#有没有类似JAVA的ehcache这样的缓存框架?或者大家都用什么解决方案来进行缓存? 解决方案 解决方案二:一直都用redis,偶尔也用一些类似key-value结构的数据库解决方案三: 解决方案四:刚才找了看了ehcache一下,

C#开发微信门户及应用(48) - 在微信框架中整合CacheManager 缓存框架

 在我们的很多框架或者项目应用中,缓存在一定程度上可以提高程序的响应速度,以及减轻服务器的承载压力,因此在一些地方我们都考虑引入缓存模块,这篇随笔介绍使用开源缓存框架CacheManager来实现数据的缓存,在微信开发框架中,我们有一些常用的处理也需要应用到缓存,因此本随笔以微信框架为例介绍缓存的实际使用,实际上,在我们很多框架中,如混合式开发框架.Web开发框架.Bootstrap开发框架中,这个模块都是通用的. 1.框架的缓存设计 在我们的微信开发框架中,缓存作为数据库和对外接口之间的一个分

.NET缓存框架CacheManager在混合式开发框架中的应用(1)-CacheManager的介绍和使用

在我们开发的很多分布式项目里面(如基于WCF服务.Web API服务方式),由于数据提供涉及到数据库的相关操作,如果客户端的并发数量超过一定的数量,那么数据库的请求处理则以爆发式增长,如果数据库服务器无法快速处理这些并发请求,那么将会增加客户端的请求时间,严重者可能导致数据库服务或者应用服务直接瘫痪.缓存方案就是为这个而诞生,随着缓存的引入,可以把数据库的IO耗时操作,转换为内存数据的快速响应操作,或者把整个页面缓存到缓存系统里面.缓存框架在各个平台里面都有很多的实现,基本上多数是采用分布式缓存

Objective-C的缓存框架EGOCache在iOS App开发中的使用_IOS

EGOCache简介 EGOCache is a simple, thread-safe key value cache store. It has native support for NSString, UI/NSImage, and NSData, but can store anything that implements <NSCoding>. All cached items expire after the timeout, which by default, is one da

使用Memcached、Spring AOP构建数据库前端缓存框架

上回说到Memcahed的安装及java客户端的使用,现在我们使用memcached.Spring AOP技术来构建一个数据库的缓存框架. 数据库访问可能是很多网站的瓶颈.动不动就连接池耗尽.内存溢出等.前面已经讲到如果我们的网站是一个分布式的大型站点,那么使用memcached实现数据库的前端缓存是个很不错的选择:但如果网站本身足够小只有一个服务器,甚至是vps的那种,不推荐使用memcached,使用Hibernate或者Mybatis框架自带的缓存系统就行了. 一.开启memcached服

写自己的缓存框架,JAD-CACHE架构设计篇

在之前一篇<写一个自己的通用缓存框架,以同时支持ehcache.mecache以及springcache注解等等>博文中,列出了自己的通用缓存框架需要实现在的大致功能总结如下: 1.提供统一的缓存操作api: 2.支持同时使用多种缓存实现: 3.提供灵活的配置: 4.需要防止缓存穿透: 5.需要可以灵活指定缓存存活时间: 6.需要任意控制缓存的停用或启用. 目前这个框架的编码部分已完成,并取名为JAD-CACHE,取这个名字的原因是因为它是我的个人的JAD项目的一部分,JAD项目是本人用业余时

MyBatis的一级缓存和二级缓存 以及 mybatis和ehcache缓存框架整合

查询缓存 缓存的意义 将用户经常查询的数据放在缓存(内存)中,用户去查询数据就不用从磁盘上(关系型数据库数据文件)查询,从缓存中查询,从而提高查询效率,解决了高并发系统的性能问题. 基本由此图可以看出,我们在每一层都需要相应的缓存. mybatis持久层缓存 mybatis提供一级缓存和二级缓存 mybatis一级缓存是一个SqlSession级别,sqlsession只能访问自己的一级缓存的数据,二级缓存是跨sqlSession,是mapper级别的缓存,对于mapper级别的缓存不同的sql