csredis 開源地址
續上篇
示例源碼
https://github.com/luoyunchong/dotnetcore-examples/tree/master/dotnet-core-redis
前提
- 安裝並配置好redis服務,可用。
- vs2017或vs2019或vscode
- .net core 2.2+ sdk
創建一個. NET Core WebAPI項目
想執行 . NET Core CLI命令行,要cd到csproj同級目錄中
dotnet add package CSRedisCore
#mvc分布式緩存注入
dotnet add package Caching.CSRedis
或
程序包管理控制台(Package Manager)中運行,選擇你的項目
Install-Package CSRedisCore
Install-Package Caching.CSRedis
普通模式
- appsettings.json配置項
{
"CsRedisConfig": {
"DefaultConnectString": "127.0.0.1:6379,password=,defaultDatabase=0,prefix=csredis-default-"
}
}
- Startup.cs中配置如下
public void ConfigureServices(IServiceCollection services)
{
// eg 1.單個redis實現 普通模式
//CSRedisClient csredis = new CSRedisClient("127.0.0.1:6379,password=,defaultDatabase=csredis,prefix=csredis-example");
//eg 2.單個redis,使用appsettings.json中的配置項
IConfigurationSection configurationSection = Configuration.GetSection("CsRedisConfig:DefaultConnectString");
CSRedisClient csredis = new CSRedisClient(configurationSection.Value);
//初始化 RedisHelper
RedisHelper.Initialization(csredis);
//注冊mvc分布式緩存
services.AddSingleton<IDistributedCache>(new CSRedisCache(RedisHelper.Instance));
...其他代碼
}
- ValuesController.cs
通過靜態方法調用,鍵為test1 ,value為前台傳來的值,緩存60s
獲取值Get方法, test1作為鍵,返回值給前台。60s后再獲取,將無法得到值。
// POST api/values
[HttpPost]
public void Post([FromBody] string value)
{
RedisHelper.Set("test1", value, 60);
}
// GET api/values
[HttpGet]
public ActionResult<string> Get()
{
return RedisHelper.Get("test1");
}
普通模式-控制台
class Program
{
static void Main(string[] args)
{
var csredis = new CSRedis.CSRedisClient("127.0.0.1:6379,password=,defaultDatabase=CsRedis,prefix=CsRedis_ConSole_Example");
RedisHelper.Initialization(csredis);
RedisHelper.Set("test1", "123123", 60);
string result = RedisHelper.Get("test1");
Console.WriteLine("key:test1,value:" + result);
Console.ReadKey();
}
}
哨兵模式
前提
- 了解哨兵模式的作用
- 並有一個可用的主(master)redis服務,二個從(slaver)服務,有三個哨兵監控。
- appsettings.json配置項
{
"CsRedisConfig": {
"SentinelConnectString": "mymaster,password=,prefix=csredis-example-",
"Sentinel": [
"127.0.0.1:26379",
"127.0.0.1:26380",
"127.0.0.1:26381"
]
}
}
- Startup.cs中配置如下
public void ConfigureServices(IServiceCollection services)
{
//eg.3 使用appsettings.json,哨兵模式
IConfigurationSection configurationSection = Configuration.GetSection("CsRedisConfig:SentinelConnectString");
string[] sentinelValues = Configuration.GetSection("CsRedisConfig:Sentinel").Get<string[]>();
CSRedisClient csredis = new CSRedisClient(configurationSection.Value, sentinelValues);
//初始化 RedisHelper
RedisHelper.Initialization(csredis);
//注冊mvc分布式緩存
services.AddSingleton<IDistributedCache>(new CSRedisCache(RedisHelper.Instance));
...其他代碼
}
- 使用緩存時與普通模式相同,不過關閉某一個redis服務,服務依舊可用,不過如果redis處於切換cluster過程,將會有短暫的失敗,不過一會就會恢復。
相關文章
- .NET Core開發者的福音之玩轉Redis的又一傻瓜式神器推薦 https://www.cnblogs.com/yilezhu/p/9947905.html
- 【由淺至深】redis 實現發布訂閱的幾種方式 https://www.cnblogs.com/kellynic/p/9952386.html
- 深入剖析Redis系列(四) - Redis數據結構與全局命令概述 https://juejin.im/post/5bb01064e51d453eb93d8028
RedisHelper 與redis-cli命令行保持一致的api,會使用redis相關命令,即會使用RedisHelper方法
配合redis-cli命令行
static void Main()
{
CSRedisClient csredis = new CSRedisClient("127.0.0.1:6379,password=,defaultDatabase=CsRedis,prefix=CsRedis_ConSole_Example");
RedisHelper.Initialization(csredis);
Test();
Console.ReadKey();
}
static void Test()
{
//1.set key value [ex seconds] [px milliseconds] [nx|xx]
//setex key seconds value #設定鍵的值,並指定此鍵值對應的 有效時間。
//setnx key value #鍵必須 不存在,才可以設置成功。如果鍵已經存在,返回 0。
RedisHelper.Set("redis-key", "just a string value", 50);//setex "redis-key" 50 "just a string value"
RedisHelper.Set("redis-key-class",DateTime.Now, 30);
//1.1.2. 獲取值
//get key
//如果要獲取的 鍵不存在,則返回 nil(空)。
string redisValue = RedisHelper.Get("redis-key");
Console.WriteLine($"setex redis-key 50 just a string value ,RedisHelper.Get()得到值如下:{redisValue}");
DateTime now = RedisHelper.Get<DateTime>("redis-key-class");
Console.WriteLine($"setex redis-key-class DateTime.Now,RedisHelper.Get()值如下{now}");
//1.1.3. 批量設置值
//mset key value [key value ...]
RedisHelper.MSet("a", "1", "b", "2", "c", "3","d","4");//等價於mset a 1 b 2 c 3 d 4
//1.1.4. 批量獲取值
//mget key [key ...]
string[] mgetValues = RedisHelper.MGet<string>("a", "b", "c","d");
Console.WriteLine($"mset a 1 b 2 c 3 d 4, RedisHelper.MGet()得到的值是");
foreach (var mgetValue in mgetValues)
{
Console.Write($"{mgetValue}、");
}
Console.WriteLine();
//1.1.5. 計數
//incr key
//incr 命令用於對值做 自增操作
//自增指定數字
long incr = RedisHelper.IncrBy("key");
Console.WriteLine($"incr key, incr得到的值是{incr}");
//設置自增數字的增量值
incr = RedisHelper.IncrBy("key",2);
Console.WriteLine($"再次incrby key 2, incr得到的值是{incr}");
incr = RedisHelper.IncrBy("key", -2);
Console.WriteLine($"再次decrby key -2, incr得到的值是{incr}");
//exists key
bool isExistsKey = RedisHelper.Exists("new-key");
Console.WriteLine($"exists key ,value:{isExistsKey}");
double incrByFloat=RedisHelper.IncrByFloat("key-float", 0.1);
Console.WriteLine($"incrbyfloat key-float 0.1,value:{incrByFloat}");
}