利用servicestack连接redis

引言:作为少有的.net架构下的大型网站,stackoverflow今日发表了一篇文章,介绍了其技术体系,原文链接http://highscalability.com/blog/2011/3/3/stack-overflow-architecture-update-now-at-95-million-page-vi.html。从文中可以看到,该网站运用了redis作为其缓存层。而新浪微博早就已经大量使用redis。作为一个新兴的nosql数据库,redis既解决了memcached持久化的问题,又在性能上和传统的memcached+mysql不相上下。

1 redis安装与配置

目前redis在windows上的运行还不稳定,一般都是将其部署在linux服务器下,网上可以搜到很多安装教程,本文不再赘述http://www.oschina.net/question/12_18065

2下载servicestack.Redis

目前redis官方版本不支持.net直接进行连接,需要使用一些开源类库。目前最流行的就是ServiceStack.redis,github链接为https://github.com/ServiceStack/ServiceStack.Redis

点击页面右侧的DownLoad.Zip,下载后解压,在build\release\MonoDevelop\ServiceStack.Redis下找到所需要的四个dll

3 利用servicestack连接redis

新建一个VS project,引入以上四个dll,接下来我们就可以利用C#连接redis数据库了,一个最简单的例子:

4 目前servicestack.redis仍然在不断发展和改进中,所以一些方法描述并不是很清晰,所以提供一个已经封装好的类共大家使用,

redis的网络连接方式和传统的rdbms相似,一种是长连接,一种是连接池,此处使用长连接进行连接

强烈建议在使用之前阅读注释

  1 using System;
2 using System.Collections.Generic;
3 using System.Linq;
4 using System.Text;
5 using System.Threading.Tasks;
6 using ServiceStack.Redis;
7 namespace TestRedis
8 {
9 class RedisHelper:IDisposable
10 {
11 /*copyright@2013 All Rights Reserved
12 * Author:Mars
13 * Date:2013.08.27
14 * QQ:258248340
15 * servicestack.redis为github中的开源项目
16 * redis是一个典型的k/v型数据库
17 * redis共支持五种类型的数据 string,list,hash,set,sortedset
18 *
19 * string是最简单的字符串类型
20 *
21 * list是字符串列表,其内部是用双向链表实现的,因此在获取/设置数据时可以支持正负索引
22 * 也可以将其当做堆栈结构使用
23 *
24 * hash类型是一种字典结构,也是最接近RDBMS的数据类型,其存储了字段和字段值的映射,但字段值只能是
25 * 字符串类型,散列类型适合存储对象,建议使用对象类别和ID构成键名,使用字段表示对象属性,字
26 * 段值存储属性值,例如:car:2 price 500 ,car:2 color black,用redis命令设置散列时,命令格式
27 * 如下:HSET key field value,即key,字段名,字段值
28 *
29 * set是一种集合类型,redis中可以对集合进行交集,并集和互斥运算
30 *
31 * sorted set是在集合的基础上为每个元素关联了一个“分数”,我们能够
32 * 获得分数最高的前N个元素,获得指定分数范围内的元素,元素是不同的,但是"分数"可以是相同的
33 * set是用散列表和跳跃表实现的,获取数据的速度平均为o(log(N))
34 *
35 * 需要注意的是,redis所有数据类型都不支持嵌套
36 * redis中一般不区分插入和更新操作,只是命令的返回值不同
37 * 在插入key时,如果不存在,将会自动创建
38 *
39 * 在实际生产环境中,由于多线程并发的关系,建议使用连接池,本类只是用于测试简单的数据类型
40 */
41
42 /*
43 * 以下方法为基本的设置数据和取数据
44 */
45 private static RedisClient redisCli = null;
46 /// <summary>
47 /// 建立redis长连接
48 /// </summary>
49 /// 将此处的IP换为自己的redis实例IP,如果设有密码,第三个参数为密码,string 类型
50 public static void CreateClient(string hostIP,int port,string keyword)
51 {
52 if (redisCli == null)
53 {
54 redisCli = new RedisClient(hostIP, port, keyword);
55 }
56
57 }
58 public static void CreateClient(string hostIP, int port)
59 {
60 if (redisCli == null)
61 {
62 redisCli = new RedisClient(hostIP, port);
63 }
64
65 }
66 //private static RedisClient redisCli = new RedisClient("192.168.101.165", 6379, "123456");
67 /// <summary>
68 /// 获取key,返回string格式
69 /// </summary>
70 /// <param name="key"></param>
71 /// <returns></returns>
72 public static string getValueString(string key)
73 {
74
75 string value = redisCli.GetValue(key);
76 return value;
77
78
79 }
80 /// <summary>
81 /// 获取key,返回byte[]格式
82 /// </summary>
83 /// <param name="key"></param>
84 /// <returns></returns>
85 public static byte[] getValueByte(string key)
86 {
87 byte[] value = redisCli.Get(key);
88 return value;
89 }
90 /// <summary>
91 /// 获得某个hash型key下的所有字段
92 /// </summary>
93 /// <param name="hashId"></param>
94 /// <returns></returns>
95 public static List<string> GetHashFields(string hashId)
96 {
97 List<string> hashFields = redisCli.GetHashKeys(hashId);
98 return hashFields;
99 }
100 /// <summary>
101 /// 获得某个hash型key下的所有值
102 /// </summary>
103 /// <param name="hashId"></param>
104 /// <returns></returns>
105 public static List<string> GetHashValues(string hashId)
106 {
107 List<string> hashValues = redisCli.GetHashKeys(hashId);
108 return hashValues;
109 }
110 /// <summary>
111 /// 获得hash型key某个字段的值
112 /// </summary>
113 /// <param name="key"></param>
114 /// <param name="field"></param>
115 public static string GetHashField(string key, string field)
116 {
117 string value = redisCli.GetValueFromHash(key, field);
118 return value;
119 }
120 /// <summary>
121 /// 设置hash型key某个字段的值
122 /// </summary>
123 /// <param name="key"></param>
124 /// <param name="field"></param>
125 /// <param name="value"></param>
126 public static void SetHashField(string key, string field, string value)
127 {
128 redisCli.SetEntryInHash(key, field, value);
129 }
130 /// <summary>
131 ///使某个字段增加
132 /// </summary>
133 /// <param name="key"></param>
134 /// <param name="field"></param>
135 /// <returns></returns>
136 public static void SetHashIncr(string key, string field, long incre)
137 {
138 redisCli.IncrementValueInHash(key, field, incre);
139
140 }
141 /// <summary>
142 /// 向list类型数据添加成员,向列表底部(右侧)添加
143 /// </summary>
144 /// <param name="Item"></param>
145 /// <param name="list"></param>
146 public static void AddItemToListRight(string list, string item)
147 {
148 redisCli.AddItemToList(list, item);
149 }
150 /// <summary>
151 /// 向list类型数据添加成员,向列表顶部(左侧)添加
152 /// </summary>
153 /// <param name="list"></param>
154 /// <param name="item"></param>
155 public static void AddItemToListLeft(string list, string item)
156 {
157 redisCli.LPush(list, Encoding.Default.GetBytes(item));
158 }
159 /// <summary>
160 /// 从list类型数据读取所有成员
161 /// </summary>
162 public static List<string> GetAllItems(string list)
163 {
164 List<string> listMembers = redisCli.GetAllItemsFromList(list);
165 return listMembers;
166 }
167 /// <summary>
168 /// 从list类型数据指定索引处获取数据,支持正索引和负索引
169 /// </summary>
170 /// <param name="list"></param>
171 /// <returns></returns>
172 public static string GetItemFromList(string list, int index)
173 {
174 string item = redisCli.GetItemFromList(list, index);
175 return item;
176 }
177 /// <summary>
178 /// 向列表底部(右侧)批量添加数据
179 /// </summary>
180 /// <param name="list"></param>
181 /// <param name="values"></param>
182 public static void GetRangeToList(string list, List<string> values)
183 {
184 redisCli.AddRangeToList(list, values);
185 }
186 /// <summary>
187 /// 向集合中添加数据
188 /// </summary>
189 /// <param name="item"></param>
190 /// <param name="set"></param>
191 public static void GetItemToSet(string item, string set)
192 {
193 redisCli.AddItemToSet(item, set);
194 }
195 /// <summary>
196 /// 获得集合中所有数据
197 /// </summary>
198 /// <param name="set"></param>
199 /// <returns></returns>
200 public static HashSet<string> GetAllItemsFromSet(string set)
201 {
202 HashSet<string> items = redisCli.GetAllItemsFromSet(set);
203 return items;
204 }
205 /// <summary>
206 /// 获取fromSet集合和其他集合不同的数据
207 /// </summary>
208 /// <param name="fromSet"></param>
209 /// <param name="toSet"></param>
210 /// <returns></returns>
211 public static HashSet<string> GetSetDiff(string fromSet, params string[] toSet)
212 {
213 HashSet<string> diff = redisCli.GetDifferencesFromSet(fromSet, toSet);
214 return diff;
215 }
216 /// <summary>
217 /// 获得所有集合的并集
218 /// </summary>
219 /// <param name="set"></param>
220 /// <returns></returns>
221 public static HashSet<string> GetSetUnion(params string[] set)
222 {
223 HashSet<string> union = redisCli.GetUnionFromSets(set);
224 return union;
225 }
226 /// <summary>
227 /// 获得所有集合的交集
228 /// </summary>
229 /// <param name="set"></param>
230 /// <returns></returns>
231 public static HashSet<string> GetSetInter(params string[] set)
232 {
233 HashSet<string> inter = redisCli.GetIntersectFromSets(set);
234 return inter;
235 }
236 /// <summary>
237 /// 向有序集合中添加元素
238 /// </summary>
239 /// <param name="set"></param>
240 /// <param name="value"></param>
241 /// <param name="score"></param>
242 public static void AddItemToSortedSet(string set,string value,long score)
243 {
244 redisCli.AddItemToSortedSet(set,value,score);
245 }
246 /// <summary>
247 /// 获得某个值在有序集合中的排名,按分数的降序排列
248 /// </summary>
249 /// <param name="set"></param>
250 /// <param name="value"></param>
251 /// <returns></returns>
252 public static int GetItemIndexInSortedSetDesc(string set, string value)
253 {
254 int index = redisCli.GetItemIndexInSortedSetDesc(set, value);
255 return index;
256 }
257 /// <summary>
258 /// 获得某个值在有序集合中的排名,按分数的升序排列
259 /// </summary>
260 /// <param name="set"></param>
261 /// <param name="value"></param>
262 /// <returns></returns>
263 public static int GetItemIndexInSortedSet(string set, string value)
264 {
265 int index = redisCli.GetItemIndexInSortedSet(set, value);
266 return index;
267 }
268 /// <summary>
269 /// 获得有序集合中某个值得分数
270 /// </summary>
271 /// <param name="set"></param>
272 /// <param name="value"></param>
273 /// <returns></returns>
274 public static double GetItemScoreInSortedSet(string set, string value)
275 {
276 double score = redisCli.GetItemScoreInSortedSet(set, value);
277 return score;
278 }
279 /// <summary>
280 /// 获得有序集合中,某个排名范围的所有值
281 /// </summary>
282 /// <param name="set"></param>
283 /// <param name="beginRank"></param>
284 /// <param name="endRank"></param>
285 /// <returns></returns>
286 public static List<string> GetRangeFromSortedSet(string set,int beginRank, int endRank)
287 {
288 List<string> valueList=redisCli.GetRangeFromSortedSet(set,beginRank,endRank);
289 return valueList;
290 }
291 /// <summary>
292 /// 获得有序集合中,某个分数范围内的所有值,升序
293 /// </summary>
294 /// <param name="set"></param>
295 /// <param name="beginScore"></param>
296 /// <param name="endScore"></param>
297 /// <returns></returns>
298 public static List<string> GetRangeFromSortedSet(string set, double beginScore, double endScore)
299 {
300 List<string> valueList = redisCli.GetRangeFromSortedSetByHighestScore(set, beginScore, endScore);
301 return valueList;
302 }
303 /// <summary>
304 /// 获得有序集合中,某个分数范围内的所有值,降序
305 /// </summary>
306 /// <param name="set"></param>
307 /// <param name="beginScore"></param>
308 /// <param name="endScore"></param>
309 /// <returns></returns>
310 public static List<string> GetRangeFromSortedSetDesc(string set, double beginScore, double endScore)
311 {
312 List<string> vlaueList=redisCli.GetRangeFromSortedSetByLowestScore(set,beginScore,endScore);
313 return vlaueList;
314 }
315 public void Dispose()
316 {
317 redisCli.Dispose();
318 }
319
320 }
321 }

本文就到这里,在接下来,我会跟大家讨论redis中的连接池、锁、线程安全、分布式等机制。

作者:Mars

出处:http://www.cnblogs.com/marsblog/

本文基于署名-非商业性使用 3.0中国大陆许可协议发布,欢迎转载,演绎或用于商业目的,但是必须保留本文的署名 Mars (包含链接)

 
 
 
标签: redisc#nosql

利用servicestack连接redis的更多相关文章

  1. redis在.net架构中的应用(1)--利用servicestack连接redis

    引言:作为少有的.net架构下的大型网站,stackoverflow曾发表了一篇文章,介绍了其技术体系,原文链接http://highscalability.com/blog/2011/3/3/sta ...

  2. redis在.net架构中的应用(1)--使用servicestack连接redis(转)

    引言:作为少有的.net架构下的大型网站,stackoverflow曾发表了一篇文章,介绍了其技术体系,原文链接http://highscalability.com/blog/2011/3/3/sta ...

  3. redis在.net架构中的应用(1)--使用servicestack连接redis

    引言:作为少有的.net架构下的大型网站,stackoverflow曾发表了一篇文章,介绍了其技术体系,原文链接http://highscalability.com/blog/2011/3/3/sta ...

  4. 使用servicestack连接redis

    引言:作为少有的.net架构下的大型网站,stackoverflow曾发表了一篇文章,介绍了其技术体系,原文链接http://highscalability.com/blog/2011/3/3/sta ...

  5. Redis Desktop Manager 利用ssh连接 Redis

    需开启6379端口,如果不设置密码,就忽略1,2步骤 第一步: 第二步: 第三步: 第四步: 第五步:

  6. Java学习,利用IDEA开发工具连接redis

    Idea连接redis及Jedis数据操作 注意是否开启了redis服务!!! 1.打开虚拟机终端,查看虚拟机防火墙是否关闭 查看防火墙当前状态命令: $sudo ufw status 我的是默认关闭 ...

  7. windows下Redis安装及利用java操作Redis

    一.windows下Redis安装 1.Redis下载 下载地址:https://github.com/MicrosoftArchive/redis 打开下载地址后,选择版本 然后选择压缩包 下载 R ...

  8. laravel项目利用twemproxy部署redis集群的完整步骤

    Twemproxy是一个代理服务器,可以通过它减少Memcached或Redis服务器所打开的连接数.下面这篇文章主要给大家介绍了关于laravel项目利用twemproxy部署redis集群的相关资 ...

  9. spring boot 利用redisson实现redis的分布式锁

    原文:http://liaoke0123.iteye.com/blog/2375469 利用redis实现分布式锁,网上搜索的大部分是使用java jedis实现的. redis官方推荐的分布式锁实现 ...

随机推荐

  1. SVN提交忽略*.class、.classpath、.mymetadata、.project、.settings、.myeclipse和其他非版本控制文件

    1.忽略*.class 在TortoiseSVN -->setting(设定)--规设置 watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQveHVrZTY ...

  2. windows phone8.1:Xml,Json序列化和反序列化

    原文:windows phone8.1:Xml,Json序列化和反序列化 小梦本例主要实现以下四点内容: 将Car对象序列化为xml 将Car对象序列化为Json 将xml反序列化为Car对象 将js ...

  3. vim插件管理器vundle

    安装:  git clone http://github.com/gmarik/vundle.git ~/.vim/bundle/vundle set nocompatible " be i ...

  4. 直读Innodb datafile

    这两天有空翻了翻大神写的<innodb存储引擎>,手痒亲身实践.由于此书出版了有段时日,没有用其推荐的python工具,通过点滴推敲,略微发现其中冰山一角的奥秘.对于今后对于一些问题查证或 ...

  5. 我所理解的Spring AOP的基本概念

    Spring AOP中的概念晦涩难懂,读官方文档更是像读天书,看了非常多样例后,写一些自己理解的一些spring的概念.要理解面向切面编程,要首先理解代理模式和动态代理模式. 如果一个OA系统中的一个 ...

  6. mvc中动态给一个Model类的属性设置验证

    原文:mvc中动态给一个Model类的属性设置验证 在mvc中有自带的验证机制,比如如果某个字段的类型是数字或者日期,那么用户在输入汉字或者英文字符时,那么编译器会自动验证并提示用户格式不正确,不过这 ...

  7. ORACLE 中极易混淆的几个 NAME 的分析和总结

    我们知道,Oracle中的各种NAME会在我们的各个配置文件里常常出现,大致有下面这些: 在init.ora中有DB_NAME,INSTANCE_NAME,SERVICE_NAME 配置DG的时候,为 ...

  8. Asp.Net MVC4 + Oracle + EasyUI + Bootstrap

    Asp.Net MVC4 + Oracle + EasyUI + Bootstrap --操作数据和验证 本文链接:http://www.cnblogs.com/likeli/p/4234238.ht ...

  9. JDK-windows7环境变量配置-亲测版本 以及HelloWorld

    1.下载并安装jdk,假设安装1.6.0_45版本到C:\Program Files\Java,则安装完毕后,目录结构为: C:\PROGRAM FILES\JAVA├─jdk1.6.0_45│ ├─ ...

  10. JS模板引擎:tppl

    全球最快的JS模板引擎:tppl 废话不多说,先上测试: 亲测请访问:[在线测试地址]单次结果不一定准确,请多测几次. tppl 的编译渲染速度是著名的 jQuery 作者 John Resig 开发 ...