自己写了一个RedisHelper,现贴出来,希望各位大神能够指正和优化。

using System;
using StackExchange.Redis;
using System.Configuration; namespace Common.Redis
{
public static partial class RedisHelper
{
private static readonly string ConnectString = ConfigurationManager.ConnectionStrings["RedisConnection"].ToString();
private static Lazy<ConnectionMultiplexer> _lazyConnection;
private static readonly Object MultiplexerLock = new Object();
private static readonly IDatabase Cache; static RedisHelper()
{
var conn = CreateManager.Value;
Cache = conn.GetDatabase(); //获取实例
} private static Lazy<ConnectionMultiplexer> GetManager(string connectionString = null)
{
if (string.IsNullOrEmpty(connectionString))
{
connectionString = GetDefaultConnectionString();
} return new Lazy<ConnectionMultiplexer>(() => ConnectionMultiplexer.Connect(connectionString));
} private static Lazy<ConnectionMultiplexer> CreateManager
{
get
{
if (_lazyConnection == null)
{
lock (MultiplexerLock)
{
if (_lazyConnection != null) return _lazyConnection; _lazyConnection = GetManager();
return _lazyConnection;
}
} return _lazyConnection;
}
} public static string GetDefaultConnectionString()
{
return ConnectString;
}
}
}

使用patial 修饰符,由于Redis中的数据类型操作不少,所以把它们单独分到一个文件。核心的,可优化的主要还是上面的代码。


使用的是StackExchange.Redis Redis 客户端。

连接字符串从配置文件 application web.config读取。配置如下:

  <connectionStrings>
<add name="RedisConnection" connectionString="10.13.11.101:6379,10.13.18.191:6379,keepAlive=180,allowAdmin=True,$CLIENT=,$CLUSTER=,$CONFIG=,$ECHO=,$INFO=,$PING=" />
</connectionStrings>

由于Redis的高速读写的特性,密码是很容易被破解的,所以最好还是部署在内网环境中。

使用 Lazy<ConnectionMultiplexer> 而不是 ConnectionMultiplexer,是可以按需延迟加载。参考文件:

http://blog.sina.com.cn/s/blog_537517170102w3ib.html

真正的操作方法在下面:

using System;
using System.Collections.Generic;
using System.Linq;
using ServiceStack.Text;
using StackExchange.Redis; namespace Common.Redis
{
public partial class RedisHelper
{
public const string DefaultOrder = "desc"; #region Keys
public static bool KeyExists(string key)
{
var bResult = Cache.KeyExists(key);
return bResult;
} public static bool SetExpire(string key, DateTime datetime)
{
return Cache.KeyExpire(key, datetime);
} public static bool SetExpire(string key, int timeout = )
{
return Cache.KeyExpire(key, DateTime.Now.AddSeconds(timeout));
} public static bool Set<T>(string key, T t, int timeout = )
{
var value = JsonSerializer.SerializeToString(t);
bool bResult = Cache.StringSet(key, value);
if (timeout > )
{
Cache.KeyExpire(key, DateTime.Now.AddSeconds(timeout));
}
return bResult;
} public static bool KeyDelete(string key)
{
return Cache.KeyDelete(key);
} public static bool KeyRename(string oldKey, string newKey)
{
return Cache.KeyRename(oldKey, newKey);
}
#endregion #region Hashes
public static bool IsExist(string hashId, string key)
{
return Cache.HashExists(hashId, key);
} public static bool SetHash<T>(string hashId, string key, T t)
{
var value = JsonSerializer.SerializeToString(t);
return Cache.HashSet(hashId, key, value);
} public static bool Remove(string hashId, string key)
{
return Cache.HashDelete(hashId, key);
} public static long StringIncrement(string hashId, string key, long value = )
{
return Cache.HashIncrement(hashId, key, value);
} public static T Get<T>(string hashId, string key)
{
string value = Cache.HashGet(hashId, key);
return JsonSerializer.DeserializeFromString<T>(value);
} public static long GetHashCount(string hashId)
{
var length = Cache.HashLength(hashId);
return length;
} public static string Get(string hashId, string key)
{
string value = Cache.HashGet(hashId, key).ToString();
return value;
} public static List<T> GetAll<T>(string hashId)
{
var result = new List<T>();
var list = Cache.HashGetAll(hashId).ToList();
if (list.Count > )
{
list.ForEach(x =>
{
var value = JsonSerializer.DeserializeFromString<T>(x.Value);
result.Add(value);
});
}
return result;
} public static List<string> GetAllFields(string hashId)
{
var result = new List<string>();
var list = Cache.HashKeys(hashId).ToList();
if (list.Count > )
{
list.ForEach(x =>
{
var value = JsonSerializer.DeserializeFromString<string>(x);
result.Add(value);
});
}
return result;
}
#endregion #region Sorted Sets
public static bool SortedSetItemIsExist(string setId, string item)
{
var value = GetItemScoreFromSortedSet(setId, item);
if (value != null)
{
return true;
}
return false;
} public static bool SortedSetAdd(string setId, string item, double score, int timeout = )
{
return Cache.SortedSetAdd(setId, item, score);
} public static List<string> GetSortedSetRangeByRank(string setId, long fromRank, long toRank, string order = DefaultOrder)
{
var result = new List<string>();
var list = Cache.SortedSetRangeByRank(setId, fromRank, toRank, order == Order.Descending.ToString().ToLower() ? Order.Descending : Order.Ascending).ToList();
if (list.Any())
{
list.ForEach(x =>
{
var value = JsonSerializer.DeserializeFromString<string>(x);
result.Add(value);
});
}
return result;
} public static Dictionary<string, double> GetSortedSetRangeByRankWithScores(string setId, long fromRank, long toRank, string order = DefaultOrder)
{
var result = new Dictionary<string, double>();
var list = Cache.SortedSetRangeByRankWithScores(setId, fromRank, toRank, order == Order.Descending.ToString().ToLower() ? Order.Descending : Order.Ascending).ToList();
if (list.Any())
{
list.ForEach(x =>
{
result.Add(x.Element, x.Score);
});
}
return result;
} public static List<string> GetSortedSetRangeByValue(string setId, long minValue, long maxValue)
{
var result = new List<string>();
var list = Cache.SortedSetRangeByValue(setId, minValue, maxValue).ToList();
if (list.Any())
{
list.ForEach(x =>
{
var value = JsonSerializer.DeserializeFromString<string>(x);
result.Add(value);
});
}
return result;
} public static long GetSortedSetLength(string setId)
{
return Cache.SortedSetLength(setId);
} public static long GetSortedSetLength(string setId, double minValue, double maxValue)
{
return Cache.SortedSetLength(setId, minValue, maxValue);
} public static long? GetItemRankFromSortedSet(string setId, string item, string order = DefaultOrder)
{
return Cache.SortedSetRank(setId, item, order == Order.Descending.ToString().ToLower() ? Order.Descending : Order.Ascending);
} public static double? GetItemScoreFromSortedSet(string setId, string item)
{
return Cache.SortedSetScore(setId, item);
} public static double SetSortedSetItemIncrement(string setId, string item, double score = )
{
return Cache.SortedSetIncrement(setId, item, score);
} public static double SortedSetItemDecrement(string setId, string item, double score = -)
{
return Cache.SortedSetDecrement(setId, item, score);
} public static bool RemoveItemFromSortedSet(string setId, string item)
{
return Cache.SortedSetRemove(setId, item);
} public static long RemoveByRankFromSortedSet(string setId, long fromRank, long toRank)
{
return Cache.SortedSetRemoveRangeByRank(setId, fromRank, toRank);
} public static long RemoveByScoreFromSortedSet(string setId, double minValue, double maxValue)
{
return Cache.SortedSetRemoveRangeByScore(setId, minValue, maxValue);
} public static long RemoveByLexFromSortedSet(string setId, int minValue, int maxValue)
{
//TODO: Don't know its meaning
//return Cache.SortedSetRemoveRangeByValue(setId, minValue, maxValue);
return ;
}
#endregion #region Lists public static long AddList<T>(string listId, T t)
{
var value = JsonSerializer.SerializeToString(t);
return Cache.ListLeftPush(listId, value);
} public static List<T> GetList<T>(string listId, long start = , long stop = -)
{
var result = new List<T>();
var list = Cache.ListRange(listId, start, stop).ToList();
if (list.Count > )
{
list.ForEach(x =>
{
var value = JsonSerializer.DeserializeFromString<T>(x);
result.Add(value);
});
}
return result;
}
#endregion #region Strings public static string Get(string key)
{
string value = Cache.StringGet(key);
return value;
} public static T StringGet<T>(string key)
{
string value = Cache.StringGet(key);
return JsonSerializer.DeserializeFromString<T>(value);
} public static double StringIncrement(string key, double value)
{
return Cache.StringIncrement(key, value);
} public static long StringAppend(string key, string value)
{
return Cache.StringAppend(value, value, CommandFlags.None);
}
#endregion
}
}

ILONEY

Redis 有五种常用数据类型,由于我实际中经常使用的是Hash,List,Sorted Set,String,故只我只贴出了上面我测试有限的方法出来,各位可自行补充。

最好自己新建一个文件,这样会比较符合开放-封闭 原则。

最后附上我为了学习Redis最常访问的站点:

Redis 官网:http://redis.io/

StackExchange.Redis 的github文档:

https://github.com/StackExchange/StackExchange.Redis

Stackoverflow 站点:

http://stackoverflow.com/search?q=Redis

RedisHelper in C#的更多相关文章

  1. Basic Tutorials of Redis(9) -First Edition RedisHelper

    After learning the basic opreation of Redis,we should take some time to summarize the usage. And I w ...

  2. C# Azure 存储-分布式缓存Redis工具类 RedisHelper

    using System; using System.Collections.Generic; using Newtonsoft.Json; using StackExchange.Redis; na ...

  3. Asp.Net Core 2.0 项目实战(6)Redis配置、封装帮助类RedisHelper及使用实例

    本文目录 1. 摘要 2. Redis配置 3. RedisHelper 4.使用实例 5. 总结 1.  摘要 由于內存存取速度远高于磁盘读取的特性,为了程序效率提高性能,通常会把常用的不常变动的数 ...

  4. [C#] 使用 StackExchange.Redis 封装属于自己的 RedisHelper

    使用 StackExchange.Redis 封装属于自己的 RedisHelper 目录 核心类 ConnectionMultiplexer 字符串(String) 哈希(Hash) 列表(List ...

  5. RedisHelper帮助类

    using Newtonsoft.Json; using RedLockNet.SERedis; using RedLockNet.SERedis.Configuration; using Stack ...

  6. 使用 StackExchange.Redis 封装属于自己的 RedisHelper

    目录 核心类 ConnectionMultiplexer 字符串(String) 哈希(Hash) 列表(List) 有序集合(sorted set) Key 操作 发布订阅 其他 简介 目前 .NE ...

  7. RedisHelper (C#)

    <add key="RedisServers" value="172.20.2.90:9379,password=Aa+123456789" /> ...

  8. RedisHelper Redis帮助类

    using StackExchange.Redis; using System; using System.Collections.Generic; using System.IO; using Sy ...

  9. Redis:RedisHelper(5)

    /// <summary> /// Redis 助手 /// </summary> public class RedisHelper { /// <summary> ...

随机推荐

  1. VoIP常见编码的带宽计算

    voip带宽计算VOIP计算方法与所选用的编码方法有关,而与哪个厂家的没有什么关系,公式如下: 带宽=包长度×每秒包数=包长度×(1/打包周期)=(Ethernet头+IP头+UDP头+RTP头+有效 ...

  2. JVM调优总结(这个总结得比较全面)

    堆大小设置 JVM 中最大堆大小有三方面限制:相关操作系统的数据模型(32-bt还是64-bit)限制:系统的可用虚拟内存限制:系统的可用物理内存限制.32位系统下,一般限制在1.5G~2G:64为操 ...

  3. Java-API-POI:POI 笔记

    ylbtech-Java-API-POI:POI 笔记 1. 笔记一返回顶部 1. 1,POI对JDK版本支持及XLSX (2017-04-01 13:51:39)对JDK6的支持,最后版本是POI- ...

  4. click 模块使用方法说明

    !/usr/bin/env python -- coding: utf-8 -- import click @click.command() @click.option('--count', defa ...

  5. 九 assign和subscribe

    1 subscribe:  自动安排分区, 通过group自动重新的负载均衡: 关于Group的实验: 如果auto commit = true, 重新启动进程,如果是同样的groupID,从上次co ...

  6. 阶段性总结(PHP-JSON)

    PHP JSON 本节我们将为大家介绍如何使用 PHP 语言来编码和解码 JSON 对象. 在没有json编码和解码之前,我们 html前台 和 PHP后台 之间的数据传输只能用字符串的方式传输. 但 ...

  7. 分析java类的初始化契机

    分析java类的静态成员变量初始化先于非静态成员变量   依上图中当class字节码文件被jvm虚拟机加载到内存中依次经过 连接 验证:对字节码进行验证 准备:给静态变量分配内存并赋予变量类型各自的默 ...

  8. 优化笔记: jxrsfxrxx_D_20140916.gz

    表的重复扫描.   ----------------------------------想进一步研究,继续往下看------------------------------ 1.       所有相似 ...

  9. ceph---luminous 块存储(RBD)搭建

    1. 创建pool 创建存储池: ceph osd pool create {pool-name} {pg-num} [{pgp-num}] [replicated] [crush-ruleset-n ...

  10. Web(Easy UI)

    HTML菜鸟教程 http://www.runoob.com/html/html-tables.html EasyUI combobox下拉多选框的实现 https://www.cnblogs.com ...