1.前言

  a.Redis是一个开源,先进的key-value(键/值对)存储,并且勇于构建高性能,可扩展的Web应用程序的完美解决方案

  b.Redis和Memcached的对比

    b.1 Redis数据库完全在内存中,使用磁盘仅用于持久性

    b.2 相比较许多键值对存储,redis拥有更加丰富的数据类型,

Redis提供的五种数据类型: string(字符串)、hash(哈希表) list(双向队列)、set(集合)和zset(有序集合)

    b.3 Redis可以将数据复制到任意数量的从服务器

  c.Redis拥有的优势

    c.1 Redis的执行响应速度非常快

    c.2 支持丰富的数据类型

    c.3 原子性,保证了如果两个客户端同事访问的Redis服务器将获得更新后的值

    c.4 多功能实用工具,Redis是一个多实用的工具,可以在多个用例如缓存,消息,队列实用,任何短暂的数据,应用程序。

  d.Github下载地址:https://github.com/kencery/Common/tree/master/KenceryCommonMethod/%E7%BC%93%E5%AD%98

  e.Redis学习:http://www.redis.io/

// 源文件头信息:
// <copyright file="RedisHelper.cs">
// Copyright(c)2014-2034 Kencery.All rights reserved.
// 个人博客:http://www.cnblogs.com/hanyinglong
// 创建人:韩迎龙(kencery)
// 创建时间:2015-8-18
// </copyright> using System;
using System.Collections.Generic;
using System.Configuration;
using ServiceStack.Redis; namespace KenceryCommonMethod
{
/// <summary>
/// Redis缓存读取设置 封装
/// <auther>
/// <name>Kencery</name>
/// <date>2015-8-18</date>
/// </auther>
/// </summary>
public static class RedisHelper
{
/// <summary>
/// 创建Redis连接池管理对象(添加ServiceStack.Interfaces.dll、ServiceStack.Redis.dll)
/// </summary>
/// <param name="readWriteHosts">只写服务器</param>
/// <param name="readOnlyHosts">只读服务器</param>
/// <returns></returns>
private static PooledRedisClientManager CreateRedisManager(IEnumerable<string> readWriteHosts,
IEnumerable<string> readOnlyHosts)
{
//支持读写分离,均衡负载
return new PooledRedisClientManager(readWriteHosts, readOnlyHosts, new RedisClientManagerConfig
{
MaxWritePoolSize = , //“写”链接池数
MaxReadPoolSize = , //“读”链接池数
AutoStart = true,
});
} /// <summary>
/// 调用CreateRedisManager方法,创建连接池管理对象,Redis服务器地址在配置文件中配置(创建只读,只写连接池)
/// <add key="RedisHosts" value="127.0.0.1:6379" />
/// </summary>
private static readonly PooledRedisClientManager Prcm = CreateRedisManager(
ConfigurationManager.AppSettings["Hosts"].Split(",".ToCharArray(), StringSplitOptions.RemoveEmptyEntries),
ConfigurationManager.AppSettings["Hosts"].Split(",".ToCharArray(), StringSplitOptions.RemoveEmptyEntries)); /// <summary>
/// 给缓存中添加数据,使用:RedisHelper.Set(key,值(需要存放的值));
/// </summary>
/// <typeparam name="T">缓存类型</typeparam>
/// <param name="key">键</param>
/// <param name="val">值</param>
public static void Set<T>(string key, T val)
{
using (IRedisClient rdc = Prcm.GetClient())
{
rdc.Set<T>(key, val);
}
} /// <summary>
/// 读取缓存中的数据,使用:var result=RedisHelper.Get<T>(key);
/// </summary>
/// <typeparam name="T">返回读取的数据</typeparam>
/// <param name="key">键</param>
/// <returns></returns>
public static T Get<T>(string key) where T : class
{
using (IRedisClient rdc = Prcm.GetReadOnlyClient())
{
return rdc.Get<T>(key);
}
} /// <summary>
/// 删除缓存中的数据,使用 RedisHelper.Remove(key);
/// </summary>
/// <param name="key">键</param>
public static void Remove(string key)
{
using (IRedisClient rdc = Prcm.GetClient())
{
rdc.Remove(key);
}
} /// <summary>
/// 缓存中是否包含查询的键数据,使用 var isTrue=RedisHelper.ContainsKey(key);
/// </summary>
/// <param name="key">键</param>
/// <returns>如果包含,返回true,否则返回false</returns>
public static bool ContainsKey(string key)
{
using (IRedisClient rdc = Prcm.GetReadOnlyClient())
{
return rdc.ContainsKey(key);
}
} /// <summary>
/// 给缓存中添加Object对象,使用:RedisHelper.Add(key,值(需要存放的值))
/// </summary>
/// <param name="key">键</param>
/// <param name="value">值</param>
public static void Add(string key, object value)
{
using (IRedisClient rdc = Prcm.GetClient())
{
if (!rdc.ContainsKey(key))
{
rdc.Add(key, value, DateTime.Now.AddMinutes());
}
else
{
rdc.Set(key, value);
}
}
} /// <summary>
/// 根据key刷新缓存中的数据信息,使用:RedisHelper.RefreshCache(key)
/// </summary>
/// <typeparam name="T">缓存类型</typeparam>
/// <param name="key">键</param>
public static void RefreshCache<T>(string key) where T : class
{
using (IRedisClient rdc = Prcm.GetClient())
{
var value = rdc.Get<T>(key);
rdc.Remove(key);
rdc.Set<T>(key, value);
}
} /// <summary>
/// 根据key集合信息读取缓存中的键值对,返回字典形式的数据存放,使用:RedisHelper.GetList(keys);
/// </summary>
/// <param name="keys">key集合</param>
/// <returns>返回字典集合</returns>
public static Dictionary<string, string> GetList(List<string> keys)
{
using (IRedisClient rdc = Prcm.GetReadOnlyClient())
{
return rdc.GetValuesMap<string>(keys);
}
} /// <summary>
/// 将字典集合添加到缓存中,使用:RedisHelper.Set(values);
/// </summary>
/// <param name="values">字典集合信息</param>
public static void Set(Dictionary<string, string> values)
{
using (IRedisClient rdc = Prcm.GetReadOnlyClient())
{
rdc.SetAll(values);
}
} }
}

Redis:高性能文件缓存key-value储存的更多相关文章

  1. 高性能文件缓存key-value存储—Redis

    1.高性能文件缓存key-value存储-Memcached 2.ASP.NET HttpRuntime.Cache缓存类使用总结 备注:三篇博文结合阅读,简单理解并且使用,如果想深入学习,请多参考文 ...

  2. 高性能文件缓存key-value存储—Memcached

    1.高性能文件缓存key-value存储—Redis 2.ASP.NET HttpRuntime.Cache缓存类使用总结 备注:三篇博文结合阅读,简单理解并且使用,如果想深入学习,请多参考文章中给出 ...

  3. 知乎技术分享:从单机到2000万QPS并发的Redis高性能缓存实践之路

    本文来自知乎官方技术团队的“知乎技术专栏”,感谢原作者陈鹏的无私分享. 1.引言 知乎存储平台团队基于开源Redis 组件打造的知乎 Redis 平台,经过不断的研发迭代,目前已经形成了一整套完整自动 ...

  4. 构建高性能数据库缓存之redis主从复制

    一.什么是redis主从复制? 主从复制,当用户往Master端写入数据时,通过Redis Sync机制将数据文件发送至Slave,Slave也会执行相同的操作确保数据一致:且实现Redis的主从复制 ...

  5. 从单机到2000万 QPS 并发的 Redis 高性能缓存实践之路

    1.引言 知乎存储平台团队基于开源Redis 组件打造的知乎 Redis 平台,经过不断的研发迭代,目前已经形成了一整套完整自动化运维服务体系,提供很多强大的功能.本文作者陈鹏是该系统的负责人,本次文 ...

  6. 构建高性能数据库缓存之redis(二)

    一.概述 在构建高性能数据库缓存之redis(一)这篇文档中,阐述了Redis数据库(key/value)的特点.功能以及简单的配置过程,相信阅读过这篇文档的朋友,对Redis数据库会有一点的了解,此 ...

  7. 本地测试读取redis和普通文件缓存的速度,redis慢一倍?

    重新测试了,换成了Linux服务器,php5.6,512内存.连续读取1千次不同的文件(每个文件41KB),redis也是1千个不同的key,文件缓存还是比redis快! 但是,但是,后来我换成连续读 ...

  8. redis删除单个key和多个key,ssdb会落地导致重启redis无法清除缓存

    redis删除单个key和多个key,ssdb会落地导致重启redis无法清除缓存,需要针对单个key进行删除 删除单个:del key 删除多个:redis-cli -a pass(密码) keys ...

  9. 高性能Web服务器Nginx的配置与部署研究(12)应用模块之Memcached做文件缓存时压缩引起的问题

    在上一篇文章中,提到的Nginx的Memcached模块应用场景,主要是作为文件缓存.然后就发现了一个问题,当以字节数组方式缓存较大的文件时,缓存数据会被压缩,从而在读取的时候出现问题. (本文欢迎转 ...

随机推荐

  1. 并行【parallel】和并发【concurrency】线程是并发还是并行,进程是并发还是并行

    线程是并发,进程是并行:进程之间相互独立,是系统分配资源的最小单位,同一个线程中的所有线程共享资源. 并行,同一时刻多个任务同时在运行. 并发,在同一时间内隔内多个任务都在运行,但是都不会在同一时刻同 ...

  2. placeholder兼容性问题

    由于placeholder是H5新属性,IE9及以下都不支持 解决办法:给input添加一个背景图,背景图里面添加placeholder内容,当焦点落在输入框中,背景图隐藏,即可做出类似的效果 代码: ...

  3. HTTPS双向认证+USB硬件加密锁(加密狗)配置

    环境:  Ubuntu14.04,apache2.4.7, openssl1.0.1f 安装apache2 apt-get install apache2 -y 一般openssl默认已经安装 开启a ...

  4. JAVA多线程Thread与Runnable

    一.Runnable Runnable为一个之包含一个run方法的接口 public class MyRunnable implements Runnable{ @Override //表示:预示重写 ...

  5. CodeForces - 1101D:GCD Counting (树分治)

    You are given a tree consisting of n vertices. A number is written on each vertex; the number on ver ...

  6. 51Nod 1007:正整数分组(01背包)

    1007 正整数分组  基准时间限制:1 秒 空间限制:131072 KB 分值: 10 难度:2级算法题  收藏  关注 将一堆正整数分为2组,要求2组的和相差最小. 例如:1 2 3 4 5,将1 ...

  7. c++输入输出流加速器

      发现同样是cin,cout,其他大佬(orz)的耗时短很多.看了他们的代码,我发现他们加了一个很神奇的匿名函数(Lambda捕获)提高了cin,cout效率,因此去百度了解了一下.以下是大佬所使用 ...

  8. Linux定时任务计划

    Linux定时任务计划 在使用Linux系统时,我们有时会需要让系统在某个时间去执行特定的任务,这时就需要去了解Linux提供的定时任务功能 种类 Linux的定时任务分为两种:单一型和循环型 单一型 ...

  9. [Wannafly挑战赛28][B msc和mcc][预处理+枚举]

    链接:https://ac.nowcoder.com/acm/contest/217/B来源:牛客网 msc和mcc 题目描述 msc和mcc是一对好朋友,有一天他们得到了一个长度为n的字符串s. 这 ...

  10. json/pickle模块(序列化)

    什么叫序列化? 序列化是指把内存里的数据类型转变成字符串,以使其能存储到硬盘或通过网络传输到远程,因为硬盘或网络传输时只能接受bytes 为什么要序列化? 你打游戏过程中,打累了,停下来,关掉游戏.想 ...