在.net中使用redis(StackExchange.Redis)
本文介绍如何在.net中使用redis
安装
代码使用
StackExchange.Redis基础使用
StackExchange.Redis中的事务
-
- 安装Chocolatey请看Chocolatey安装
- 安装redis
choco install redis-64 - 运行
redis-server.exe如果运行失败,设置环境变量SET PATH=%PATH%;"c:\Program Files\Redis" - 创建一个控制台程序,安装Nuget包
StackExchange.Redis
-
- 创建ConnectionMultiplexer实例
public class RedisConnectorHelper
{
private static Lazy<ConnectionMultiplexer> lazyConnection;
static RedisConnectorHelper ()
{
lazyConnection = new Lazy<ConnectionMultiplexer>(() =>
{
return ConnectionMultiplexer.Connect("localhost");
});
}
public static ConnectionMultiplexer Connection
{
get { return lazyConnection.Value; }
}
}
创建这个包含静态构造函数的类的目的,就是避免重复创建ConnectionMultiplexer提高性能和避免Azure限制
- 保存数据
public void SavaData()
{
IDatabase db = RedisConnectorHelper.Connection.GetDatabase();
Random rd = new Random();
for(int i = 0; i < 10000; i++)
{
int num = rd.Next();
db.StringSet($"Ye{i}", num);
}
}
- 读取数据
public void ReadData()
{
IDatabase db = RedisConnectorHelper.Connection.GetDatabase();
for(int i = 0; i < 10000; i++)
{
RedisValue value = db.StringGet($"Ye{i}");
Console.WriteLine(value);
}
Console.ReadKey();
}
-
- ConnectionMultiplexer类实例
ConnectionMultiplexer类实例最好只创建一次
ConnectionMultiplexer redis = ConnectionMultiplexer.Connect("localhost");
ConnectionMultiplexer类实现了IDisposable接口,你在不需要redis实例的时候可以手动释放他,但是我们一般不这么做,因为我们需要复用这个实例
- 使用redis数据库
获取数据库
写法一,不带数据
IDatabase db = redis.GetDatabase();
写法二,带自定义数据
int databaseNumber = 1;
object asyncState = 2;
IDatabase db = redis.GetDatabase();
使用数据库中的方法
db.StringAppend("YeJaiWei", "!");
await db.StringAppendAsync("YeJaiWei", "?");
可用的redis操作方法可以访问 https://redis.io/commands
- redis数据库的数据类型
Strings
Strings类型的数据,可以包含任何类型的数据,只要最终可以编码成二进制都行
db.StringSet("a", "你好吗");
b.StringGet("a")
Lists
list就是一个数组类似的结构,由string构成,使用方法如下
db.ListLeftPush("myList", "b"); // 如果不存在myList结构,那么创建一个名为myList的List集合,将值追加到最前面
RedisValue result = db.ListGetByIndex("myList", 0); // 根据索引获取结合中的值
还有很多其他的操作方法,请自行查阅
list最多的元素可以有4294967295个,访问list中的元素,两端的速度比中间的快
Sets
上面讲的list是有序的集合,可以通过索引访问,但是set是无序的,成员都是唯一的不重复,使用方式如下
db.SetAdd("mySet", "aaa"); // mySet不存在则创建
RedisValue[] result = db.SetMembers("mySet");
Hashes
Hashes顾名思义就是用来表示键值对对象的集合,可存储量非常大,可以有4294967295个键值对,使用方式如下
db.HashSet("myHash", "name", "yejiawei");
RedisValue result = db.HashGet("myHash", "name");
Sorted sets
此数据类型是redis最引以为傲的成果,作用是使用score将无序的set排个序,从最小的score到最大的score排序
成员都是唯一的,但是score可以是重复的,由于元素被score排序了,访问set中间的元素也是非常迅速的
db.SortedSetAdd("mySortedSet","aaa", 11);
RedisValue result = db.SortedSetScore("mySortedSet","aaa");
- redis中的pub/sub
使用pub/sub对开发分布式程序来说帮助很大,订阅和发布之间的通信是通过channel实现的
使用步骤如下
首先,创建Subscriber实例
ISubscriber sub = redis.GetSubscriber();
使用订阅者
sub.Subscribe("message", (channel, message) =>
{
Console.WriteLine(message);
});
使用发布者(这个发布者可以在其他的机器上面运行)
sub.Publish("message", "你好");
- 访问单个的服务器
有时候需要维护数据库,查看数据库相关的信息
查看redis里面连接的服务器端口号
EndPoint[] ep = redis.GetEndPoints();
创建Server实例
IServer server = redis.GetServer("localhost", 6379);
访问服务器信息
DateTime lastSaveTime = server.LastSave(); // 上次保存时间
- Fire-and-Forget模式的使用
有的方法会返回值,但是我们对这个值不感兴趣,那么我们可以不让它返回,可以提高性能
一个使用的例子
var test = db.StringIncrement("Ye1", 2, CommandFlags.FireAndForget); // 指定了此flag,int类型的都返回默认值0,string类型返回默认值null
var result = db.StringGet("Ye1");
-
写法一,事务写法
IDatabase db = ConnectionMultiplexer.Connect("localhost").GetDatabase();
ITransaction tran = db.CreateTransaction(); // 创建一个Transaction实例
tran.AddCondition(Condition.HashNotExists("YeTran", "Test")); // 给事务添加判断条件
tran.HashSetAsync("YeTran", "Test", "hahaha");
bool committed = tran.Execute(); // 执行事务
if(committed)
{
Console.WriteLine("存好了");
}else
{
Console.WriteLine("已经有了");
}
写法二,内置操作写法
IDatabase db = ConnectionMultiplexer.Connect("localhost").GetDatabase();
bool committed = db.HashSet("YeTran", "Test", "hahaha", When.NotExists);
if(committed)
{
Console.WriteLine("存好了");
}else
{
Console.WriteLine("已经有了");
}
在.net中使用redis(StackExchange.Redis)的更多相关文章
- EF+Redis(StackExchange.Redis)实现分布式锁,自测可行
电商平台 都会有抢购的情况,比如 1元抢购. 而抢购 最重要的 就是库存,很多情况下 库存处理不好,就会出现超卖现象. 本文将用redis为缓存,StackExchange 框架,消息队列方式 实现 ...
- StackExchange.Redis性能调优
大家经常出现同步调用Redis超时的问题,但改成异步之后发现错误非常少了,但却可能通过前后记日志之类的发现Redis命令非常慢. PS: 以后代码都在Windows bash中运行,StackExch ...
- 扩展 StackExchange.Redis 支持实体
一.StackExchange.Redis StackExchange.Redis是由Stack Overflow开发的C#语言Redis客户端,使用广泛,本文针对 StackExchange.Red ...
- (三)Redis for StackExchange.Redis
目录 (一)Redis for Windows正确打开方式 (二)Redis for 阿里云公网连接 (三)Redis for StackExchange.Redis StackExchange.Re ...
- RedisRepository封装—Redis发布订阅以及StackExchange.Redis中的使用
本文版权归博客园和作者本人吴双共同所有,转载请注明本Redis系列分享地址.http://www.cnblogs.com/tdws/tag/NoSql/ Redis Pub/Sub模式 基本介绍 Re ...
- StackExchange.Redis在net中使用
redis 官网https://redis.io redis 下载 进入下载页面 https://redis.io/download https://github.com/MicrosoftArc ...
- 在.net Core中使用StackExchange.Redis 2.0
StackExchange.Redis 2.0做了大量的改进包括使用了高性能的IO库System.IO.Pipelines来提升性能以及解决Timeouts问题, 但是在.net Core2.2之前为 ...
- 【Azure Redis 缓存】云服务Worker Role中调用StackExchange.Redis,遇见莫名异常(RedisConnectionException: UnableToConnect on xxx 或 No connection is available to service this operation: xxx)
问题描述 在Visual Studio 2019中,通过Cloud Service模板创建了一个Worker Role的角色,在角色中使用StackExchange.Redis来连接Redis.遇见了 ...
- Jexus~mono中使用StackExchange.redis的问题
在windows平台的vs里,添加包包时,可以选择StackExchange.redis,而如果你的应该程序需要部署到linux的mono环境上,使用这个StackExchange.redis是不行的 ...
随机推荐
- sqoop1.4.6 全量导入与增量导入 与使用技巧
全量导入: sqoop import --connect jdbc:mysql://192.168.0.144:3306/db_blog --username root --password 1234 ...
- 手机APP和微信小程序能否取代域名?
有人说现在App是主流,手机上装几个App就可以了,以后域名的重要性会越来越低,直至App完全取代域名的域名无用论.真的是这样吗? 关于这个话题已经有很多先人前辈探讨过,这次誉名网从另外一个角度给各位 ...
- vue.js计算属性 vs methods
计算属性:Vue.js 模板内的表达式非常便利,但是缺点就是只能用于简单的运算,如果模板中有太多的逻辑运算会让模板不堪重负且难以维护.恰恰计算属性可以处理复杂的逻辑运算,也就是说对于任何复杂逻辑你都应 ...
- 第一个Python程序hello.py提示出现File "<stdin>",line 1错误
写第一个Python程序hello.py,内容仅有一句,print 'hello world', 运行 Python hello.py 出错,提示: File "<stdin>& ...
- SQL Server 中WITH (NOLOCK)浅析(转)
概念介绍 开发人员喜欢在SQL脚本中使用WITH(NOLOCK), WITH(NOLOCK)其实是表提示(table_hint)中的一种.它等同于 READUNCOMMITTED . 具体的功能作用 ...
- zoj3229 有源汇上下界最大流
题意:有一个人每天给妹子拍照,每个妹子有最少拍照数,每天有最大拍照数,每天只能给某些特定的妹子拍照,求最大拍照数 题解:很容易看出来的有源汇上下界最大流,对于有源汇 的上下界最大流,我们按照无源汇的操 ...
- Mac开机启动
1. Finder打开资源库的LaunchAgents目录. 打开Finder,按⇧⌘G,输入 /Library/LaunchAgents/ 以及 ~/Library/LaunchAgents/ 2. ...
- 31 python下实现并发编程
一 背景知识 顾名思义,进程即正在执行的一个过程.进程是对正在运行程序的一个抽象. 进程的概念起源于操作系统,是操作系统最核心的概念,也是操作系统提供的最古老也是最重要的抽象概念之一.操作系统的其他所 ...
- 21 Python 异常处理
异常和错误 AttributeError 试图访问一个对象没有的树形,比如foo.x,但是fo ...
- hbase_异常_03_java.io.EOFException: Premature EOF: no length prefix available
一.异常现象 更改了hadoop的配置文件:core-site.xml 和 mapred-site.xml 之后,重启hadoop 和 hbase 之后,发现hbase日志中抛出了如下异常: ...