redis在.net架构中的应用(1)--使用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 (包含链接)
redis在.net架构中的应用(1)--使用servicestack连接redis(转)的更多相关文章
- redis在.net架构中的应用(1)--使用servicestack连接redis
引言:作为少有的.net架构下的大型网站,stackoverflow曾发表了一篇文章,介绍了其技术体系,原文链接http://highscalability.com/blog/2011/3/3/sta ...
- redis在.net架构中的应用(1)--利用servicestack连接redis
引言:作为少有的.net架构下的大型网站,stackoverflow曾发表了一篇文章,介绍了其技术体系,原文链接http://highscalability.com/blog/2011/3/3/sta ...
- redis在.net架构中的应用(2)--并发和原子操作不可兼得
在上一篇文章中,我主要向大家介绍了利用servicestack连接redis以及一些redis的基本数据类型,传送门 本文中,我将通过一个具体应用场景为大家介绍redis中的并发和原子操作 其中用到的 ...
- 利用servicestack连接redis
利用servicestack连接redis 引言:作为少有的.net架构下的大型网站,stackoverflow今日发表了一篇文章,介绍了其技术体系,原文链接http://highscalabilit ...
- 使用servicestack连接redis
引言:作为少有的.net架构下的大型网站,stackoverflow曾发表了一篇文章,介绍了其技术体系,原文链接http://highscalability.com/blog/2011/3/3/sta ...
- Redis数据库的初步认识(二)-C/C++连接redis数据库
1用C语言连接数据库,首先要安装c语言的数据库 在目录/redis- 4.0.1/deps下面执行sudo make/make install命令 在执行完之后可能执行ldconfig命令来更新连接符 ...
- Redis 高可用架构设计(转载)
转载自:https://mp.weixin.qq.com/s?__biz=MzA3NDcyMTQyNQ==&mid=2649263292&idx=1&sn=b170390684 ...
- Redis在WEB开发中的应用与实践
Redis在WEB开发中的应用与实践 一.Redis概述: Redis是一个功能强大.性能高效的开源数据结构服务器,Redis最典型的应用是NoSQL.但事实上Redis除了作为NoSQL数据库使用之 ...
- 连接Redis后执行命令错误 MISCONF Redis is configured to save RDB snapshots
今天在redis中执行setrange name 1 chun 命令时报了如下错误提示: (error) MISCONF Redis is configured to save RDB snapsho ...
随机推荐
- C++多继承
1.继承的三种方式: 公有继承(public),私有继承(private),保护继承(protected)三种继承方式的说明,如下表所示: 特征 公有继承 保护继承 私有继承 公有成员变成 派生类的公 ...
- 云主机-vps购买
Linode VPS主机 http://jingyan.baidu.com/article/676629972be5e054d41b846c.html Linode VPS可以说是世界上最好的VPS, ...
- unity, Animation crossfade需要两动画在时间上确实有交叠
unity现在播动画都用Animator了,但公司的老项用的还是Animation,今天遇到一个bug,是两个动画的衔接处不连贯. 最后发现是由于A动画已经播完之后B动画才开始播,而且还用了cross ...
- Q6: Binary Tree Preorder Traversal
问题描述 Given a binary tree, return the preorder traversal of its nodes' values. For example:Given bina ...
- 【转】Android中JNI的使用方法
Android中JNI的使用方法 首先看一下Android平台的框架图:(网上盗用) 可以看到Android上层的Application和ApplicationFramework都是使用Java编写, ...
- JavaScript中知而不全的this (转)
原文引自:http://www.cnblogs.com/snandy/p/4773184.html 都说 JavaScript 是一种很灵活的语言,这其实也可以说它是一个混乱的语言.它把函数式编程和面 ...
- eclipse项目持续报红解决
1.tomcat 同步,点击publish: 2.clear项目 3.项目报红,Maven --->UpdateProject 4.pom.xml需要更新,下载最新jar包,附图:
- 剑指offer系列30-----删除链表中重复的节点
[题目]在一个排序的链表中,存在重复的结点, * 请删除该链表中重复的结点,重复的结点不保留,返回链表头指针. * 例如,链表1->2->3->3->4->4->5 ...
- (转)如何在eclipse的配置文件里指定jdk路径
本文转载自:http://songguoliang.iteye.com/blog/1752519 运行eclipse时报如下错误: 在eclipse的配置文件里指定jdk路径,只需在eclipse的配 ...
- bzoj3136
Description 给定m个素数和Q个询问.每个询问有n个人,每次操作可以任意选择其中的一个素数p(素数可以重复使用),然后去掉剩余人数 mod p个人.对于每个询问,我们想知道,至少需要多少步操 ...