使用WeihanLi.Redis操作Redis
WeihanLi.Redis
Intro
StackExchange.Redis 扩展,更简单的泛型操作,并提供一些的适用于业务场景中的扩展
基于 Redis 的五种数据类型扩展出了一些应用:
String
- Cache
- Counter
- Firewall
- RedLock
Hash
- Hash
- Dictonary
List
- List
Set
- Set
SortedSet
- SortedSet
- Rank
GetStarted
Install
Install from Nuget
Configuration 配置
RedisManager.AddRedisConfig(config =>
{
config.CachePrefix = "WeihanLi.Redis.UnitTest";
config.ChannelPrefix = "WeihanLi.Redis.UnitTest";
});
.net core 应用,还可以这样配置
serviceCollection.AddRedisConfig(config =>
{
config.CachePrefix = "WeihanLi.Redis.UnitTest";
config.ChannelPrefix = "WeihanLi.Redis.UnitTest";
config.EnableCompress = false;// disable compress
});
Basic usage 基本用法
Cache 缓存
缓存的基本操作主要是基于
RedisManager.CacheClient
缓存的基本操作定义在
ICacheClient
中,基本操作如下:var key = "test111";
var value = "Hello WeihanLi.Redis";
Assert.True(RedisManager.CacheClient.Set(key, value));
Assert.True(RedisManager.CacheClient.Exists(key));
Assert.Equal(value, RedisManager.CacheClient.Get(key));
Assert.True(RedisManager.CacheClient.Remove(key));
Assert.False(RedisManager.CacheClient.Exists(key));
RedisManager.CacheClient.GetOrSet(key, () => value, TimeSpan.FromSeconds(10));
Counter 计数器
var counterName = "counterTest";
var counterClient = RedisManager.GetCounterClient(counterName, TimeSpan.FromSeconds(60));
Assert.Equal(0, counterClient.Base);
Assert.Equal(0, counterClient.Count());
counterClient.Increase();
Assert.Equal(1, counterClient.Count());
counterClient.Increase(5);
Assert.Equal(6, counterClient.Count());
counterClient.Decrease(3);
Assert.Equal(3, counterClient.Count());
Assert.True(counterClient.Reset());
Assert.Equal(0, counterClient.Count());
Firewall 防火墙
var firewallName = "firewallTest";
var firewallClient = RedisManager.GetFirewallClient(firewallName, TimeSpan.FromSeconds(3));
Assert.True(firewallClient.Hit());
Assert.False(firewallClient.Hit());
await Task.Delay(TimeSpan.FromSeconds(3));
Assert.True(firewallClient.Hit());
RedLock Redis分布式锁
using (var client = RedisManager.GetRedLockClient("redLockTest"))
{
Assert.True(client.TryLock(TimeSpan.FromSeconds(10)));
using (var client1 = RedisManager.GetRedLockClient("redLockTest"))
{
Assert.False(client.TryLock(TimeSpan.FromSeconds(10)));
Assert.False(client1.Release());
}
Assert.True(client.Release());
} var key = Guid.NewGuid().ToString("N");
using (var client = RedisManager.GetRedLockClient(key))
{
Assert.True(client.TryLock(TimeSpan.FromSeconds(20)));
} using (var client = RedisManager.GetRedLockClient(key))
{
Assert.True(client.TryLock(TimeSpan.FromMinutes(3)));
Assert.True(client.Release());
}
Rank 排行榜
var rankClient = RedisManager.GetRankClient<string>("testRank");
Assert.Equal(0, rankClient.Length());
rankClient.Add("xiaoming", 100);
rankClient.Add("xiaohong", 95);
rankClient.Add("xiaowang", 96);
Assert.Equal(3, rankClient.Length());
Assert.Equal(100, rankClient.Score("xiaoming"));
var rank = rankClient.RangeByScore();
Assert.Equal("xiaohong", rank[0]);
rank = rankClient.RangeByScore(order: Order.Descending);
Assert.Equal("xiaoming", rank[0]);
var common = RedisManager.GetCommonRedisClient(RedisDataType.Rank);
Assert.True(common.KeyDelete("testRank"));
更多用法等你来发现...
Conatct
Contact me: weihanli@outlook.com
使用WeihanLi.Redis操作Redis的更多相关文章
- 使用Spring Data Redis操作Redis(集群版)
说明:请注意Spring Data Redis的版本以及Spring的版本!最新版本的Spring Data Redis已经去除Jedis的依赖包,需要自行引入,这个是个坑点.并且会与一些低版本的Sp ...
- Spring Boot使用Spring Data Redis操作Redis(单机/集群)
说明:Spring Boot简化了Spring Data Redis的引入,只要引入spring-boot-starter-data-redis之后会自动下载相应的Spring Data Redis和 ...
- 使用Spring Data Redis操作Redis(单机版)
说明:请注意Spring Data Redis的版本以及Spring的版本!最新版本的Spring Data Redis已经去除Jedis的依赖包,需要自行引入,这个是个坑点.并且会与一些低版本的Sp ...
- [Reprinted] 使用Spring Data Redis操作Redis(一) 很全面
Original Address: http://blog.csdn.net/albertfly/article/details/51494080
- 使用Python操作Redis
1. 安装pyredis 首先安装pip 1 2 3 4 5 6 7 8 <SHELL># apt-get install python-pip ...... <SHELL> ...
- Ubuntu 15.10 下Scala 操作Redis Cluster
1 前言 Redis Standalone,Redis Cluster的安装在前面介绍过,地址:http://www.cnblogs.com/liuchangchun/p/5063477.html,这 ...
- c# 使用protobuf格式操作 Redis
protobuf格式介绍 1.protobuf为goole定义的类似于json的数据格式.2.最终都需要序列化为二进制形式进行传输存储.3.相对于xml,json格式来说,序列化为二进制后占用空间更小 ...
- 使用Python操作Redis应用场景
1. 安装pyredis 首先安装pip 1 2 3 4 5 6 7 8 <SHELL># apt-get install python-pip ...... <SHELL> ...
- Python操作Redis、Memcache
今天主要介绍如何通过python来对Redis和memcache进行操作,下面开始今天的内容: 一.Memcached操作 Memcached是一个高性能的分布式内存对象缓存系统,用于动态Web ...
随机推荐
- Docker Win 10 安装
最近了解了一下Docker,不看不知道,一了解就完全被它给吸引住了.以往要装个环境,除了要准备一个Linux系统,然后在安装各种版本的类库,再安装我们需要各种应用服务(如Redis,Ngix,Mong ...
- Jenkins的安装
安装环境: 512M内存 10G硬盘空间 Java 8环境 先来创建jenkins的运行目录: mkdir /data/jenkins && cd /data/jenkins 下载je ...
- JavaScript的数组实现队列与堆栈的方法
一.队列和堆栈的简单介绍 1.1.队列的基本概念 队列:是一种支持先进先出(FIFO)的集合,即先被插入的数据,先被取出! 如下图所示: 1.2.堆栈的基本概念 堆栈:是一种支持后进先出(LIFO)的 ...
- poj1094-Sorting It All Out-拓扑排序
题意: 1).给你一些大写字母,共n个:大写字母间有m条关系: 2).举例:关系:A<B,意思就是A要排在B的前面(也就是说可能B排在A的前面 3).输出:有三种情况: 1.n个字母在前 i 条 ...
- 遗传算法详解(LINGO及MatlabGA工具箱求解实现)
遗传算法 1.前言 遗传算法是一种基于生物界自然群体遗传进化机制的自适应全局优化概率搜索算法.它与传统算法不同,不依赖梯度信息,而是通过模拟自然进化过程来搜索最优解. 例子:兔子的遗传进化 有人说,现 ...
- ES6 new syntax of let and const (one)
variable declarations : let, const,and block scope why we redefine the way about declarations? funct ...
- jdk 动态代理源码分析
闲来无事,撸撸源码 使用方法 直接看代码吧.. package com.test.demo.proxy; import java.lang.reflect.InvocationHandler; imp ...
- BAT 前端开发面试 —— 吐血总结
更好阅读,请移步这里 聊之前 最近暑期实习招聘已经开始,个人目前参加了腾讯和阿里的内推及百度的实习生招聘,在此总结一下 一是备忘.总结提升,二是希望给大家一些参考 其他面试及基础相关可以参考其他博文: ...
- [HNOI 2016]序列
Description 题库链接 给你一个长度为 \(n\) 的序列 \(A\) ,给出 \(q\) 组询问.每次询问 \([l,r]\) ,求该区间内所有的子序列中最小值的和. \(1\leq n, ...
- [Codeforces 448C]Painting Fence
Description Bizon the Champion isn't just attentive, he also is very hardworking. Bizon the Champion ...