缓存框架——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支持数据类型多,而且内存数据可以持久化,性能也不错,关于具体的技术选项分析,见下月吧。

版权声明:本文为博主原创文章,未经博主允许不得转载。

时间: 2024-08-13 10:20:37

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

Java缓存框架

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

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

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

java 开源缓存框架--转载

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

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

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

.NET缓存框架CacheManager---1、CacheManager的介绍

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

Smarge——基于HTML5 localStorage的key-value缓存框架

缓存是任何一个Web程序都需要重视的内容.受到Redis的启发,我想到开发一个基于HTML5 localStorage的key-value缓存框架,做了一些尝试之后,便有了Smarge这样一个产物. 大家都知道,HTML5的localStorage没有超时的机制,也不能存储数组和对象等类型,更没有命令空间等思想. 这些问题,在Smarge中都得到了解决. 项目地址:https://git.oschina.net/jiusem/Smarge.git 说明:Smarge1.0.js是完整的源代码,以

数据库历险记(三) | 缓存框架的连环炮

文章首发于微信公众号「陈树义」,专注于 Java 技术分享的社区.点击链接扫描二维码,与500位小伙伴一起共同进步.微信公众号二维码 http://p3npq6ecr.bkt.clouddn.com/blog/chenshuyi_gongzhonghao_guide_full.jpg 最近在思考数据库以及缓存的问题,发现这些知识点其实是有一点关联的,于是这篇文章通过一个连环提问的方式将这些知识点串联起来. 问:为什么要用 Memcached.Redis,直接用 MySQL 这些数据库不好吗? 答

缓存框架Guava Cache部分源码分析

在本地缓存中,最常用的就是OSCache和谷歌的Guava Cache.其中OSCache在07年就停止维护了,但它仍然被广泛的使用.谷歌的Guava Cache也是一个非常优秀的本地缓存,使用起来非常灵活,功能也十分强大,可以说是当前本地缓存中最优秀的缓存框架之一.之前我们分析了OSCache的部分源码,本篇就通过Guava Cache的部分源码,来分析一下Guava Cache的实现原理. 在分析之前,先弄清数据结构的使用.之前的文章提到,OSCache使用了一个扩展的HashTable,作

缓存框架OSCache部分源码分析

在并发量比较大的场景,如果采用直接访问数据库的方式,将会对数据库带来巨大的压力,严重的情况下可能会导致数据库不可用状态,并且时间的消耗也是不能容忍的.在这种情况下,一般采用缓存的方式.将经常访问的热点数据提前加载到内存中,这样能够大大降低数据库的压力. OSCache是一个开源的缓存框架,虽然现在已经停止维护了,但是对于OSCache的实现还是值得学习和借鉴的.下面通过OSCache的部分源码分析OSCache的设计思想. 缓存数据结构 通常缓存都是通过<K,V>这种数据结构存储,但缓存都是应