一.Redis基本认知

1.含义: REmote DIctionary Server(Redis) | 是一个key-value存储系统 
2.特性: 
2.1 持久化:可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用; 
2.2 支持丰富的数据类型,如:Strings, Lists, Hashes, Sets 及 Ordered Sets ; 
2.3 多个操作支持事务,任意单个操作都是原子性的,即要么成功执行要么失败完全不执行; 
2.4 丰富的特性:支持发布/订阅 , 通知 ,Key过期等 
3.常用命令 
3.1 Redis是一种基于客户端-服务端模型以及请求/响应协议的TCP服务,使用中Redis分为服务端(redis-server)和客户端(redis-cli); 
客户端是一个管理控制台,服务端负责redis的具体实现以及处理客户端的命令并提供服务;服务端启动时需要配置IP和端口。 
$redis-cli 连接本地Redis服务; 
$ redis-cli -h host -p port -a password 连接远程Redis服务

3.2 可通过 CONFIG 命令查看或设置配置项: 
CONFIG GET CONFIG_SETTING_NAME 
CONFIG SET CONFIG_SETTING_NAME NEW_CONFIG_VALUE

3.3 Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set:有序集合)。 
String(字符串):基本的类型,是二进制安全的,可以包含任何数据 
SET name “csdn” 
GET name 
Hash(哈希):key->多个filed->多个value。是一个键值(key=>value)对集合,是一个string类型的field和value的映射表。 
HMSET myhash field1 “Hello” field2 “World” 
HGET myhash field1 
List(列表):简单的字符串列表,按照插入顺序排序,可以添加一个元素到列表的头部(左边 l)或者尾部(右边 r)。 
lpush csdn “Hello” 
rpush csdn “World” 
lrange csdn 0 2 
Set(集合):string类型的无序集合,不允许重复的成员,通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。 
sadd csdn redis 
smembers csdn 
zset(sorted set:有序集合):是string类型元素的集合,但每个member都会关联一个double类型的score。redis正是通过分数来为集合中的成员进行从小到大的排序。 
zadd csdn 1 redis 
ZRANGE csdn 0 10 WITHSCORES

HyperLogLog结构:是用来做基数统计的算法,见菜鸟教程HyperLogLog

3.4 Redis的发布/订阅 
发布订阅(pub/sub)是一种消息通信模式:发送者(pub)发送消息,订阅者(sub)接收消息。 
Redis 客户端可以订阅任意数量的频道。 
使用命令:SUBSCRIBE redisChat 订阅频道(channel),频道由Redis服务端进行维护,其余客户端通过命令:PUBLISH redisChat “Message” 来向redisChat频道 发布消息。

3.5 事务 
Redis 事务可以一次执行多个命令, 并且带有以下三个特征: 
a. 批量操作在发送 EXEC 命令前被放入队列缓存。 
b.收到 EXEC 命令后进入事务执行,事务中任意命令执行失败,其余的命令依然被执行。也就是Redis的命令执行是原子性的,但 Redis 没有在事务上增加任何维持原子性的机制。 
c.在事务执行过程,其他客户端提交的命令请求不会插入到事务执行命令序列中。

一个事务从开始到执行会经历以下三个阶段: 
开始事务。 
命令入队。 
执行事务。

以命令MULTI开始一个事务,以命令EXEC触发一个事务。

3.6 Redis 数据备份策略的选择:完整备份(RDB)和增量备份(AOF) 
转发自Redis持久化存储(AOF与RDB两种模式)

二.在ASP.NET MVC中使用Redis

1.首先把Demo贴出来吧,有积分请移步CSDN下载,然后补充下载是百度云下载

Demo可以正常运行,但仍有许多不完善的地方,以后想起来再回来修改修改,截图如下: 

2.在.NET体系里,可以使用两个外部的DLL来模拟Redis-client,对Redis-server进行操作:一个是ServiceStack.Redis,另外一个是StackExchange.Redis。这两个包都可以在Nuget中搜索到。 
Demo中使用的是StackExchange.Redis。它的参考文档点这儿

示例代码如下:

  1. private void test1()
  2. {
  3. //step-1: 设置Redis链接
  4. ConnectionMultiplexer redis = ConnectionMultiplexer.Connect("localhost");
  5. //ConnectionMultiplexer redis = ConnectionMultiplexer.Connect("server1:6379,server2:6379");
  6. string config = redis.Configuration;
  7. //step-2: Accessing a redis database 连接到Redis数据库
  8. IDatabase db = redis.GetDatabase();
  9. //step-3: 通过db使用Redis API (http://redis.io/commands)
  10. db.StringSet("mykey", "myvalue",new TimeSpan(0,10,0),When.Always,CommandFlags.None);
  11. string value = string.Empty;
  12. if (db.KeyExists("mykey"))
  13. {
  14. value = db.StringGet("mykey");
  15. }
  16. }
  17. private void test2()
  18. {
  19. //step-1: 设置Redis链接
  20. ConnectionMultiplexer redis = ConnectionMultiplexer.Connect("localhost");
  21. //step-2: 创建连接到特定服务的 PUB/SUB 连接
  22. ISubscriber sub = redis.GetSubscriber();
  23. //step-3: 订阅频道,并处于监听状态,接受消息并处理
  24. string result = string.Empty;
  25. sub.Subscribe("messages", (channel, message) =>{
  26. result = string.Format("Channel:{0} ; Message:{1} .", channel.ToString(), message);
  27. });
  28. }
  29. private void test3()
  30. {
  31. //step-1: 设置Redis链接
  32. ConnectionMultiplexer redis = ConnectionMultiplexer.Connect("localhost");
  33. //step-2: 创建连接到特定服务的 PUB/SUB 连接
  34. ISubscriber sub = redis.GetSubscriber();
  35. //step-3: 在另一个进程或是机器上,发布消息
  36. sub.Publish("messages", "hello");
  37. }

详情可以看Demo里面的RedisHelper。

三.Redis更新策略探究

1.单台服务器下如何保持与数据库的数据一致 
2.多台服务器下如何使用分布式缓存

哈哈 这一部分还没怎么实际操作过,所以留待以后有了实操经验了再来更新。

在ASP.NET MVC中使用Redis的更多相关文章

  1. 最新 .NET Core 中 WebSocket的使用 在Asp.Net MVC 中 WebSocket的使用 .NET Core 中 SignalR的使用

    ASP.NET MVC 中使用WebSocket 笔记 1.采用控制器的方法 这个只写建立链接的方法的核心方法 1.1 踩坑 网上都是直接 传个异步方法 直接接受链接 自己尝试了好多次链接是打开的,到 ...

  2. 2.ASP.NET MVC 中使用Crystal Report水晶报表

    上一篇,介绍了怎么导出Excel文件,这篇文章介绍在ASP.NET MVC中使用水晶报表. 项目源码下载:https://github.com/caofangsheng93/CrystalReport ...

  3. 关于 ASP.NET MVC 中的视图生成

    在 ASP.NET MVC 中,我们将前端的呈现划分为三个独立的部分来实现,Controller 用来控制用户的操作,View 用来控制呈现的内容,Model 用来表示处理的数据. 从控制器到视图 通 ...

  4. 在Asp.Net MVC 中配置 Serilog

    Serilog 是一种非常简便记录log 的处理方式,使用Serilog可以生成本地的text文件, 也可以通过 Seq 来在Web界面中查看具体的log内容. 接下来就简单的介绍一下在Asp.Net ...

  5. 如何在 ASP.NET MVC 中集成 AngularJS(3)

    今天来为大家介绍如何在 ASP.NET MVC 中集成 AngularJS 的最后一部分内容. 调试路由表 - HTML 缓存清除 就在我以为示例应用程序完成之后,我意识到,我必须提供两个版本的路由表 ...

  6. 如何在 ASP.NET MVC 中集成 AngularJS(2)

    在如何在 ASP.NET MVC 中集成 AngularJS(1)中,我们介绍了 ASP.NET MVC 捆绑和压缩.应用程序版本自动刷新和工程构建等内容. 下面介绍如何在 ASP.NET MVC 中 ...

  7. 《Entity Framework 6 Recipes》中文翻译系列 (20) -----第四章 ASP.NET MVC中使用实体框架之在MVC中构建一个CRUD示例

    翻译的初衷以及为什么选择<Entity Framework 6 Recipes>来学习,请看本系列开篇 第四章  ASP.NET MVC中使用实体框架 ASP.NET是一个免费的Web框架 ...

  8. asp.net mvc 中 一种简单的 URL 重写

    asp.net mvc 中 一种简单的 URL 重写 Intro 在项目中想增加一个公告的功能,但是又不想直接用默认带的那种路由,感觉好low逼,想弄成那种伪静态化的路由 (别问我为什么不直接静态化, ...

  9. 在 ASP.NET MVC 中充分利用 WebGrid (microsoft 官方示例)

    在 ASP.NET MVC 中充分利用 WebGrid https://msdn.microsoft.com/zh-cn/magazine/hh288075.aspx Stuart Leeks 下载代 ...

随机推荐

  1. 自己用HashMap来模拟一个Session缓存(简易版)

    本文记录:Hibernate中一级缓存的特点. 一级缓存的细节什么操作会向一 1.级缓存放入数据 save,update,saveOrUpdate,load,get,list,iterate,lock ...

  2. mapreduce中文乱码,已解决

    问题: mapreduce中文乱码 原因: 再用Hadoop处理数据的时候,发现输出的时候,总是会出现乱码,这是因为Hadoop在设计编码的时候,是写死的.默认是UTF-8,所以当你处理的文件编码格式 ...

  3. 通过示例学习JavaScript闭包

    译者按: 在上一篇博客,我们通过实现一个计数器,了解了如何使用闭包(Closure),这篇博客将提供一些代码示例,帮助大家理解闭包. 原文: JavaScript Closures for Dummi ...

  4. laravel 数据库操作(表、字段)

    1)创建表(make:migration create),例如创建 articles php artisan make:migration create_articles_table --create ...

  5. 1970年// iPhone “变砖”后可继续正常使用的解决方案

    0.解决方案 说话先说重点,“变砖”后的iphone怎么正常使用. 拆开后盖,给电源和处理器之间断下电就OK了. 1.事件来源 对于iPhone和iPad,把时间手动设置到1970年5月以前会出现“变 ...

  6. angular 时间戳转换(星期过滤器)

    {{(value.time+'000' | date:'yyyy-MM-dd HH:mm:ss') : '/'}} .filter('getWeek', function() { return fun ...

  7. JS之innerHTML,innerText,outerHTML,textContent的用法与区别

    示例html代码: <div id="test"> <span style="color:red">test1</span> ...

  8. GIS开发之数据查询

    在GIS开发之我们经常会用到属性查询和空间查询,特别是在数据量比较大的时候,如何提高查询效率成为一个问题 1.属性查询 对于属性查询,除了必要的建索引之外,我们还应该考虑使用字段缓存:减少查询字段,减 ...

  9. 浅谈Android 混淆和加固

    混淆: 针对项目代码,代码混淆通常将代码中的各种元素(变量.函数.类名等)改为无意义的名字,使得阅读的人无法通过名称猜测其用途,增大反编译者的理解难度. 虽然代码混淆可以提高反编译的门槛,但是对开发者 ...

  10. 章节四、2-Switch语句

    package introduction5; public class SwitchDemo { //switch用于固定值的判断,如星期.人的性别 //if用于判断区间.范围,能够用switch进行 ...