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

普通模式

  1. appsettings.json配置项
{
"CsRedisConfig": {
"DefaultConnectString": "127.0.0.1:6379,password=,defaultDatabase=0,prefix=csredis-default-"
}
}
  1. 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)); ...其他代码 }
  1. 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)服务,有三个哨兵监控。
  1. 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"
]
}
}
  1. 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)); ...其他代码
}
  1. 使用缓存时与普通模式相同,不过关闭某一个redis服务,服务依旧可用,不过如果redis处于切换cluster过程,将会有短暂的失败,不过一会就会恢复。

相关文章

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}");
}

csredis-in-asp.net core理论实战-哨兵模式-使用示例的更多相关文章

  1. csredis-in-asp.net core理论实战-主从配置、哨兵模式

    csredis GitHub https://github.com/2881099/csredis 看了github上的开源项目,上面真的只是单纯的使用文档,可能对于我这种人(菜鸟)就不太友好, 我知 ...

  2. Asp.Net Core 项目实战之权限管理系统(4) 依赖注入、仓储、服务的多项目分层实现

    0 Asp.Net Core 项目实战之权限管理系统(0) 无中生有 1 Asp.Net Core 项目实战之权限管理系统(1) 使用AdminLTE搭建前端 2 Asp.Net Core 项目实战之 ...

  3. Asp.Net Core 项目实战之权限管理系统(0) 无中生有

    0 Asp.Net Core 项目实战之权限管理系统(0) 无中生有 1 Asp.Net Core 项目实战之权限管理系统(1) 使用AdminLTE搭建前端 2 Asp.Net Core 项目实战之 ...

  4. Asp.Net Core 项目实战之权限管理系统(1) 使用AdminLTE搭建前端

    0 Asp.Net Core 项目实战之权限管理系统(0) 无中生有 1 Asp.Net Core 项目实战之权限管理系统(1) 使用AdminLTE搭建前端 2 Asp.Net Core 项目实战之 ...

  5. Asp.Net Core 项目实战之权限管理系统(2) 功能及实体设计

    0 Asp.Net Core 项目实战之权限管理系统(0) 无中生有 1 Asp.Net Core 项目实战之权限管理系统(1) 使用AdminLTE搭建前端 2 Asp.Net Core 项目实战之 ...

  6. Asp.Net Core 项目实战之权限管理系统(3) 通过EntityFramework Core使用PostgreSQL

    0 Asp.Net Core 项目实战之权限管理系统(0) 无中生有 1 Asp.Net Core 项目实战之权限管理系统(1) 使用AdminLTE搭建前端 2 Asp.Net Core 项目实战之 ...

  7. Asp.Net Core 项目实战之权限管理系统(5) 用户登录

    0 Asp.Net Core 项目实战之权限管理系统(0) 无中生有 1 Asp.Net Core 项目实战之权限管理系统(1) 使用AdminLTE搭建前端 2 Asp.Net Core 项目实战之 ...

  8. Asp.Net Core 项目实战之权限管理系统(6) 功能管理

    0 Asp.Net Core 项目实战之权限管理系统(0) 无中生有 1 Asp.Net Core 项目实战之权限管理系统(1) 使用AdminLTE搭建前端 2 Asp.Net Core 项目实战之 ...

  9. Asp.Net Core 项目实战之权限管理系统(7) 组织机构、角色、用户权限

    0 Asp.Net Core 项目实战之权限管理系统(0) 无中生有 1 Asp.Net Core 项目实战之权限管理系统(1) 使用AdminLTE搭建前端 2 Asp.Net Core 项目实战之 ...

随机推荐

  1. Nginx报400 Bad Request

    本地遇到此问题,关闭浏览器,重新运行代码即可

  2. Golang通过反射拼接一个结构体所有字段

    golang通过反射拼接一个结构体所有字段 需求 将一个结构体所有字段以"|"连接拼接成字符串 golang 不同类型拼接成string使用Sprintf比较麻烦,如果一个结构体有 ...

  3. .NetCore使用Docker安装ElasticSearch、Kibana 记录日志

    前言 最近园子里看到一篇<.Net Core with 微服务 - Elastic APM> 的文章(主要用于对接口的调用链.性能进行监控),非常实用,这里讲解.NetCore将日志写入E ...

  4. github push pull error port 443: Timed out

    最近github只有开代理才能打开,但是即使能打开,进行push或者pull会经常报类似error port 443: Timed out的错误,网上搜了很久才找到解决办法. 首先要查询当前本机使用的 ...

  5. python用random模块模拟抽奖逻辑(print修改end参数使打印结果不分行)

    import random   #引入random模块,运用random函数list_one=["10081","10082","10083" ...

  6. 对volatile的理解--从JMM以及单例模式剖析

    请谈谈你对volatile的理解 1.volitale是Java虚拟机提供的一种轻量级的同步机制 三大特性1.1保证可见性 1.2不保证原子性 1.3禁止指令重排 首先保证可见性 1.1 可见性 概念 ...

  7. MySQL忘记密码怎么办-MySQL修改密码(亲测可用)

    前言: 最近要用到本地的MySQL,结果把密码忘记了. ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using pas ...

  8. Docker:docker安装部署jenkins

    Docker安装步骤请转到:https://www.cnblogs.com/nhdlb/p/11262527.html 查看docker的jenkins镜像版本 #查看jenkins版本命令 dock ...

  9. 18 shell 重定向以及文件描述符

    1.对重定向的理解 2.硬件设备和文件描述符 文件描述符到底是什么 3.Linux Shell 输出重定向 4.Linux Shell 输入重定向 5.结合Linux文件描述符谈重定向 6.Shell ...

  10. 因为它,我差点删库跑路:js防抖与节流

    前言 前端踩雷:短时间内重复提交导致数据重复. 对于前端大佬来说,防抖和节流的技术应用都是基本操作.对于"兼职"前端开发的来说,这些都是需要躺平的坑. 我们今天就来盘一盘js防抖与 ...