环境准备

1. Redis集群(Windows集群搭建

启动Redis集群,给每个节点加上Title

start "Redis - 6379" /min redis-server.exe redis..conf
start "Redis - 6380" /min redis-server.exe redis..conf
start "Redis - 6381" /min redis-server.exe redis..conf
start "Redis - 6382" /min redis-server.exe redis..conf
start "Redis - 6383" /min redis-server.exe redis..conf
start "Redis - 6384" /min redis-server.exe redis..conf

2. 安装StackExchange.Redis包

dotnet add package StackExchange.Redis

连接Redis

var configString = "127.0.0.1:6379";
var options = ConfigurationOptions.Parse(configString);
options.ReconnectRetryPolicy = new ExponentialRetry();
var client = ConnectionMultiplexer.Connect(options);

这里只需要提供一个节点就能访问整个集群

ConnectionMultiplexer 连接Redis可以使用ConfigurationOptions,或者直接字符串初始化(里面实现也是调用ConfigurationOptions.Parse转换)

这里要说一下是他的重连重试机制,在第一次创建连接的时候,StackExchange.Redis会创建一个心跳检测

internal static IDisposable Create(ConnectionMultiplexer connection)
{
var token = new TimerToken(connection);
var timer = new Timer(Heartbeat, token, MillisecondsPerHeartbeat, MillisecondsPerHeartbeat);
token.SetTimer(timer);
return timer;
}

使用System.Threading.Timer每秒钟检查一次。

StackExchange.Redis 实现两种重试策略,当然我们也可以实现自己的重现策略,实现IReconnectRetryPolicy接口

  • ExponentialRetry(指数)

   根据指定时间,根据重试次数不断增大随机数范围

  • LinearRetry(线性)

   根据指定时间固定时间间隔重试

常用数据结构操作

字符串(String)操作

static void RedisStringOperation(ConnectionMultiplexer client)
{
var db = client.GetDatabase(); //单个Key操作
db.StringSet("Key", "Wilson");
Console.WriteLine($"Get Key : {db.StringGet("Key")}"); db.StringSet("Nums", );
db.StringIncrement("Nums");
Console.WriteLine($"Get Nums : {db.StringGet("Nums")}"); db.StringDecrement("Nums");
Console.WriteLine($"Get Nums : {db.StringGet("Nums")}"); //多个Key操作
db.StringSet(new KeyValuePair<RedisKey, RedisValue>[]
{
new KeyValuePair<RedisKey, RedisValue>("{user}Name","Wilson"),
new KeyValuePair<RedisKey, RedisValue>("{user}Age",)
}); foreach (var value in db.StringGet(new RedisKey[] { "{user}Name", "{user}Age" }))
{
Console.WriteLine($"{value}");
}
}

哈希(Hash)操作

static void RedisHashOperation(ConnectionMultiplexer client)
{
var db = client.GetDatabase(); db.HashSet("person", "name", "Wilson");
Console.WriteLine(db.HashGet("person", "name")); db.HashSet("person", new HashEntry[]
{
new HashEntry("name","Wilson"),
new HashEntry("sex",)
});
Console.WriteLine(string.Join("\n", db.HashGet("person", new RedisValue[] { "name", "sex" }))); Console.WriteLine(string.Join("\n", db.HashGetAll("person")));
}

列表(List) 操作

static void RedisListOperation(ConnectionMultiplexer client)
{
var db = client.GetDatabase(); db.ListLeftPush("list", );
db.ListLeftPush("list", );
db.ListLeftPush("list", );
db.ListRightPush("list", );
db.ListRightPush("list", ); Console.WriteLine(db.ListLeftPop("list"));
Console.WriteLine(db.ListRightPop("list"));
Console.WriteLine(string.Join("\t", db.ListRange("list", , )));
Console.WriteLine(db.ListLength("list"));
}

集合(Set)

static void RedisSetOperation(ConnectionMultiplexer client)
{
var db = client.GetDatabase(); db.SetAdd("user", "Wilson");
db.SetAdd("user", "Wilson");
db.SetAdd("user", "Alice"); Console.WriteLine(db.SetLength("user"));
Console.WriteLine(db.SetPop("user"));
Console.WriteLine(string.Join("\n", db.SetMembers("user")));
}

有序集合(Sorted Set)

static void RedisSortedSetOperation(ConnectionMultiplexer client)
{
var db = client.GetDatabase(); db.KeyDelete("user"); db.SortedSetAdd("user", "Wilson", );
db.SortedSetAdd("user", "Alice", );
db.SortedSetAdd("user", "Trenary", );
db.SortedSetAdd("user", "Nixon", ); Console.WriteLine(db.SortedSetLength("user"));
Console.WriteLine(db.SortedSetRemove("user", "Wilson"));
Console.WriteLine(string.Join("\n", db.SortedSetRangeByRank("user", , )));
}

转发请标明出处:https://www.cnblogs.com/WilsonPan/p/12677478.html

示例代码: https://github.com/WilsonPan/Net.Demos/tree/master/Demo.RedisCluster

【Redis】集群NetCore实战的更多相关文章

  1. redis 集群配置实战

    文章转载自:http://hot66hot.iteye.com/blog/2050676 最近研究Redis-cluster,正好搭建了一个环境,遇到了很多坑,系统的总结下,等到redis3 rele ...

  2. Docker | redis集群部署实战

    前面已经简单熟悉过redis的下载安装使用,今天接着部署redis集群(cluster),简单体会一下redis集群的高可用特性. 环境准备 Redis是C语言开发,安装Redis需要先将Redis的 ...

  3. redis 集群热备自动切换sentinel配置实战

    ---恢复内容开始--- Redis SentinelSentinel(哨兵)是用于监控redis集群中Master状态的工具,其已经被集成在redis2.4+的版本中一.Sentinel作用:1): ...

  4. redis集群实战

    一.说明 redis 3.0集群功能出来已经有一段时间了,目前最新稳定版是3.0.5,我了解到已经有很多互联网公司在生产环境使用,比如唯品会.美团等等,刚好公司有个新项目,预估的量单机redis无法满 ...

  5. Redis项目实战---应用及理论(二)---Redis集群原理

    一. Redis官方推荐集群方案:Redis Cluster 适用于redis3.0以后版本,        redis cluster 是redis官方提供的分布式解决方案,在3.0版本后推出的,有 ...

  6. 支撑微博亿级社交平台,小白也能玩转Redis集群(实战篇)

    上篇文章<支撑微博亿级社交平台,小白也能玩转Redis集群(原理篇)>介绍了Redis集群相关原理,这篇文章将介绍Redis Cluster集群的搭建.配置,运维.扩容等具体操作 集群搭建 ...

  7. 5000+字硬核干货!Redis 分布式集群部署实战

    原理: Redis集群采用一致性哈希槽的方式将集群中每个主节点都分配一定的哈希槽,对写入的数据进行哈希后分配到某个主节点进行存储. 集群使用公式(CRC16 key)& 16384计算键key ...

  8. redis集群在线迁移第二篇(redis迁移后调整主从关系,停掉14机器上的所有从节点)-实战二

    变更需求为: 1.调整主从关系,所有节点都调整到10.129.51.30机器上 2.停掉10.128.51.14上的所有redis,14机器关机 14机器下线迁移至新机房,这段时间将不能提供服务. 当 ...

  9. Redis集群~StackExchange.redis连接Sentinel服务器并订阅相关事件(原创)

    回到目录 对于redis-sentinel我在之前的文章中已经说过,它是一个仲裁者,当主master挂了后,它将在所有slave服务器中进行选举,选举的原则当然可以看它的官方文章,这与我们使用者没有什 ...

随机推荐

  1. vue项目npm run dev 报错Uncaught SyntaxError: Unexpected token <

    目前代码所处位置是micro分支,该分支是从dev分支直接拉下来进行npm run dev的,而dev分支是可以正常运行的,网上的诸多解释是babel转义时候报错,其实对比可见,两个分支不同的地方应该 ...

  2. oracle根据特定字符拆分字符串的方法

    清洗数据需要将某个字段内以空格分隔的字符串拆分成多行单个的字符串,百度了很多种方法大概归结起来也就这几种方法最为有效,现在把贴出来: 第一种: select regexp_substr('1 2 3' ...

  3. 关于form表单:hover没有修改表单子元素样式

    原来在写todolist的时候遇到的一个问题 是关于form表单的hover属性设置背景颜色 想要实现的效果如下: 但是一开始直接给form加hover选择器的时候是这样: 可以看到这样子直接加会使得 ...

  4. Java中将文件夹复制到另一个文件夹

    文件夹的拷贝*** public static void copyDir(String sourcePath, String newPath) { File start = new File(sour ...

  5. HashMap底层源码剖析

    HashMap底层源码剖析 一.HashMap底层用到的数据结构 数组+单向链表+红黑树 数组:数组每一项都是一个链表,其实就是数组和链表的结合体 单向链表:当法神hash碰撞时,首先会找到数组对应位 ...

  6. 《前端之路》- TypeScript(二) 函数篇

    目录 一.定义函数方法 二.定义函数传参 三.可选传参 四.默认传参 五.传递剩余参数 六.函数重载 七.箭头函数 八.总结 一.定义函数方法 在 es5 中定时函数的方法有 命名函数和函数表达式(匿 ...

  7. 一起了解 .Net Foundation 项目 No.20

    .Net 基金会中包含有很多优秀的项目,今天就和笔者一起了解一下其中的一些优秀作品吧. 中文介绍 中文介绍内容翻译自英文介绍,主要采用意译.如与原文存在出入,请以原文为准. System.Drawin ...

  8. mysql5.7 ERROR 1045 (28000): Access denied for user解决方法

    https://blog.csdn.net/csy2961903/article/details/51345401  参考此文注意指名数据库mysql.user

  9. Kafka的面试题

    1.Kafka的设计是什么样的呢?Kafka将消息以topic为单位进行归纳将向Kafka topic发布消息的程序成为producers.将预订topics并消费消息的程序成为consumer.Ka ...

  10. Java14来了!Switch竟如此简单?Lombok也不需要了?来使用Idea配置Java14的开发环境吧!

    Java 14 在 2020.3.17 日发布正式版了,但现在很多公司还在使用 Java 7 或 Java 8,每当看到 Java 又发布新版本心里就慌得一匹.不过此版本并不是 LTS (长期支持版) ...