【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服务器中进行选举,选举的原则当然可以看它的官方文章,这与我们使用者没有什 ...
随机推荐
- 第八章、小节三keep-alive
主要缓存的是ajax中的json 我的路由中的内容被加载过一次,我就把路由中的内容放到内存中,下次再进入这个路由的时候,不需要重新加载页面,直接从内存中获取数据. 切换不同城市,调用不同城市数据 但是 ...
- 使用AtomicStampedReference<T>的大坑
//在初始化的时候会把引用和时间戳存到pair中 AtomicStampedReference<Integer> integerAtomicStampedReference = new A ...
- 问题描述:判断一个整数 n 是否为 2 的幂次方
一.2的幂次方的基本定义 什么样的数为2的幂次方?例如2^0=1,2^1=2,2^2=4……,符合公式2^n(n>=0)的数称为2的幂次方. 如何判断一个数是否为2的幂次方呢?基本思路:把一个数 ...
- 结题报告--hih0CoderP1041
题目:点此 描述 小Hi和小Ho准备国庆期间去A国旅游.A国的城际交通比较有特色:它共有n座城市(编号1-n):城市之间恰好有n-1条公路相连,形成一个树形公路网.小Hi计划从A国首都(1号城市)出发 ...
- wpf 菜单样式和绑定树形数据
前言 在wpf开发中,经常会使用到Menu和ContentMenu.但是原生的样式比较简陋,对于比较追求界面美好的人来说是十分不友好的.那么,这就涉及到对Menu的样式修改了.与此同时,我们还希望Me ...
- webStorm ctrl+L 跳转到指定行line eclipes快捷键
webStorm ctrl+L 跳转到指定行line eclipes快捷键
- Android开发走过的坑(持续更新)
1 华为 nova真机 打印不出Log 参考资料:http://www.apkbus.com/thread-585228-1-1.html 解决:针对权限问题,我们当然也可以解决的,华为手机在你的拨号 ...
- Django之CBV装饰器,跨站请求伪造,auth认证
CBV加装饰器 基于session实现登录 def login(request): if request.method == 'POST': username = request.POST.get(' ...
- 如何从零基础开始学习LoadRunner12(一)
如何从零基础开始学习LoadRunner12(一) 上一篇文章讲到了如何安装LR12的教程,这一篇文章来讲一下怎么利用LoadRunner自带的Sample来学习LoadRunner的基本使用. 首先 ...
- Hive数据倾斜的原因及主要解决方法
数据倾斜产生的原因 数据倾斜的原因很大部分是join倾斜和聚合倾斜两大类 Hive倾斜之group by聚合倾斜 原因: 分组的维度过少,每个维度的值过多,导致处理某值的reduce耗时很久: 对一些 ...