环境准备

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. linux4.1.36 2440 启用 RTC 支持

    /drivers/rtc/rtc-s3c.c822行static struct platform_driver s3c_rtc_driver = {    .probe        = s3c_rt ...

  2. Python自定义模块

    自定义模块 自定义模块(也就是私人订制),我们要自定义模块,首先就要知道什么是模块 一个函数封装一个功能,比如现在有一个软件,不可能将所有程序都写入一个文件,所以咱们应该分文件,组织结构要好,代码不冗 ...

  3. MAC下安装Fiddler抓包工具

    需求 我们都知道在Mac电脑下面有一个非常好的抓包工具:Charles.但是这个只能抓代理的数据包.但是有时候想要调试本地网卡的数据库 Charles 就没办法了.就想到了在windows下面的一个F ...

  4. 小程序中内容审核功能的使用(后台使用thinkPHP5.1)

    本文包含文本和图片的检测 //接收要检测的文本内容并调用检测方法 public function textCheck(Request $request){ //内容安全识别 $data['conten ...

  5. 分布式——吞吐量巨强、Hbase的承载者 LSMT

    本文始发于个人公众号:TechFlow,原创不易,求个关注 今天是分布式系统的第九篇文章. 今天给大家分享的内容是LSM树,它的英文是Log-structed Merge-tree.看着有些发怵,但其 ...

  6. java猜数游戏(新手记录每天的作业)

    //导入包 import java.util.Scanner;import java.util.Random; //定义一个类 public class Zcs{ //公共静态的主方法 public ...

  7. 「newbee-mall新蜂商城开源啦」GitHub 上最热门的 Spring Boot 项目,我也要做一次靓仔!

    没有一个冬天不可逾越,也没有一个春天不会到来. 介绍一下新蜂商城的近况,同时,新蜂商城 Vue 版本目前也在开发中,在这篇文章里我也向大家公布一下新蜂商城 Vue 版本的开发进度,和大家同步一下,在不 ...

  8. 几十万学费总结出来的Ddos攻击防护经验!

    本人从事网络安全行业十余年年.有十年被骗经验.被骗了很多回(都说能防300G,500G,买完就防不住了),本文当然重点给大家说明,ddos攻击是什么,中小企业如何防护,用到成本等. 言归正传 首先我们 ...

  9. [IROS 2018]Semantic Mapping with Simultaneous Object Detection and Localization

      论文地址:https://arxiv.org/abs/1810.11525   论文视频:https://www.youtube.com/watch?v=W-6ViSlrrZg​www.youtu ...

  10. 【洛谷P1801】黑匣子——优先队列

    题目链接 一道有点意思的题目 我们可以维护两个优先队列:pqmin和pqmax 其中 pqmin 是小根堆, pqmax 是大根堆 每次 add 一个数字,则将数字推入到 pqmin 中 每次 get ...