【Redis】集群NetCore实战
环境准备
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实战的更多相关文章
- redis 集群配置实战
文章转载自:http://hot66hot.iteye.com/blog/2050676 最近研究Redis-cluster,正好搭建了一个环境,遇到了很多坑,系统的总结下,等到redis3 rele ...
- Docker | redis集群部署实战
前面已经简单熟悉过redis的下载安装使用,今天接着部署redis集群(cluster),简单体会一下redis集群的高可用特性. 环境准备 Redis是C语言开发,安装Redis需要先将Redis的 ...
- redis 集群热备自动切换sentinel配置实战
---恢复内容开始--- Redis SentinelSentinel(哨兵)是用于监控redis集群中Master状态的工具,其已经被集成在redis2.4+的版本中一.Sentinel作用:1): ...
- redis集群实战
一.说明 redis 3.0集群功能出来已经有一段时间了,目前最新稳定版是3.0.5,我了解到已经有很多互联网公司在生产环境使用,比如唯品会.美团等等,刚好公司有个新项目,预估的量单机redis无法满 ...
- Redis项目实战---应用及理论(二)---Redis集群原理
一. Redis官方推荐集群方案:Redis Cluster 适用于redis3.0以后版本, redis cluster 是redis官方提供的分布式解决方案,在3.0版本后推出的,有 ...
- 支撑微博亿级社交平台,小白也能玩转Redis集群(实战篇)
上篇文章<支撑微博亿级社交平台,小白也能玩转Redis集群(原理篇)>介绍了Redis集群相关原理,这篇文章将介绍Redis Cluster集群的搭建.配置,运维.扩容等具体操作 集群搭建 ...
- 5000+字硬核干货!Redis 分布式集群部署实战
原理: Redis集群采用一致性哈希槽的方式将集群中每个主节点都分配一定的哈希槽,对写入的数据进行哈希后分配到某个主节点进行存储. 集群使用公式(CRC16 key)& 16384计算键key ...
- redis集群在线迁移第二篇(redis迁移后调整主从关系,停掉14机器上的所有从节点)-实战二
变更需求为: 1.调整主从关系,所有节点都调整到10.129.51.30机器上 2.停掉10.128.51.14上的所有redis,14机器关机 14机器下线迁移至新机房,这段时间将不能提供服务. 当 ...
- Redis集群~StackExchange.redis连接Sentinel服务器并订阅相关事件(原创)
回到目录 对于redis-sentinel我在之前的文章中已经说过,它是一个仲裁者,当主master挂了后,它将在所有slave服务器中进行选举,选举的原则当然可以看它的官方文章,这与我们使用者没有什 ...
随机推荐
- 如何搭建自己的SpringBoot源码调试环境?--SpringBoot源码(一)
1 前言 这是SpringBoot2.1源码分析专题的第一篇文章,主要讲如何来搭建我们的源码阅读调试环境.如果有经验的小伙伴们可以略过此篇文章. 2 环境安装要求 IntelliJ IDEA JDK1 ...
- 【.net core】电商平台升级之微服务架构应用实战
一.前言 这篇文章本来是继续分享IdentityServer4 的相关文章,由于之前有博友问我关于微服务相关的问题,我就先跳过IdentityServer4的分享,进行微服务相关的技术学习和分享.微服 ...
- 还记得第一个看到的Flutter组件吗?
注意:无特殊说明,Flutter版本及Dart版本如下: Flutter版本: 1.12.13+hotfix.5 Dart版本: 2.7.0 MaterialApp 在学习Flutter的过程中我们第 ...
- emWin模拟器Visual Studio开发时无法printf打印的问题
1.emWin模拟器 为了方便用户学习evWin框架,Segger设计了一个PC仿真的工具,可以测试绝大部分GUI的功能,除了方便使用者学习之外,还可以加速项目开发进度.毕竟在PC上用Visual S ...
- Natas13 Writeup(文件上传,绕过图片签名检测)
Natas13: 与上一关页面类似,还是文件上传,只是多了提示“出于安全原因,我们现在仅接受图像文件!”.源码如下 function genRandomString() { $length = 10; ...
- Java 借助poi操作PDF工具类
一直以来说写一个关于Java操作PDF的工具类,也没有时间去写,今天抽空写一个简单的工具类,拥有PDF中 换行,字体大小,字体设置,字体颜色,首行缩进,居中,居左,居右,增加新一页等功能,如果需要 ...
- 居家办公之后,鹅厂小哥发现Web开发竟能助力身体健康!
疫情特殊时期,各企业.学校纷纷启用远程办公和学习的方式,在办公期间,除了要完成日常工作安排,还要照顾自身的饮食起居,在高强度的工作节奏和缺少运动锻炼的情况之下,如何及早发现健康隐患,快乐办公?且看鹅厂 ...
- ysoserial分析【一】 之 Apache Commons Collections
目录 前言 基础知识 Transformer 利用InvokerTransformer造成命令执行 Map TransformedMap LazyMap AnnotationInvocationHan ...
- Vue中使用echarts,ajax请求的远程数据赋值给图表不刷新的问题和解决办法
问题: vue-cli搭建的项目,在mounted钩子函数里面创建echarts图表,本地模拟数据可以正常显示,但是当将ajax请求的远程数据赋值给图表时,图表并不会刷新. 解决办法: 刚开始以为是v ...
- 分布式专题——详解Google levelDB底层原理
本文始发于个人公众号:TechFlow,原创不易,求个关注 今天是分布式专题的第10篇文章,我们继续来聊聊LSMT这个数据结构. LSMT是一个在分布式系统当中应用非常广泛,并且原理直观简单的数据结构 ...