【Azure Redis 缓存】C#程序是否有对应的方式来优化并缩短由于 Redis 维护造成的不可访问的时间
问题描述
C#程序是否有对应的方式来优化并缩短由于 Redis 维护造成的不可访问的时间?
Redis维护说明:
Redis 服务维护时,会把副本节点提升为主节点,且旧主节点关闭现有连接时,这个时候,原有客户端的所有连接都将断开,并通过客户端Retry机制马上连接到新的主节点,这个过程被称为故障转移。
计划的故障转移发生在两个不同的时间:
- 系统更新,例如 Redis 修补或 OS 升级。
 - 管理操作,例如缩放和重新启动。
 正常情况下,故障转移的时间在1秒左右完成,如果出现异常,则需要10-15秒完成。
但是,并不是所有的客户端都能在发生故障转移后马上恢复连接,所以就需要考虑冲客户端代码,配置方面来优化此种情况所带来的后果。
问题解答
在Azure官方文档中,C# 连接Redis的客户端工具为 StackExchange.Redis, 文章中对它有比较详细的说明:
- 在极少数情况下,Stackexchange.redis 在连接中断后无法重新连接。 在这些情况下,重新启动客户端或创建新的 
ConnectionMultiplexer可解决此问题。 建议使用单一实例ConnectionMultiplexer模式,同时允许应用定期强制重新连接。 ConnectionMultiplexer的用户必须处理因处置该类的旧实例而可能发生的任何ObjectDisposedException错误。- 针对 
RedisConnectionExceptions和RedisSocketExceptions调用ForceReconnectAsync()。 也可以针对RedisTimeoutExceptions调用ForceReconnectAsync(),但前提是你使用大量的ReconnectMinInterval和ReconnectErrorThreshold。 否则,建立新连接可能会导致超时的服务器发生连锁故障,因为服务器已过载。 
Demo参考:https://github.com/Azure-Samples/azure-cache-redis-samples/tree/main/quickstart/dotnet-core
【Azure Redis 缓存】C#程序是否有对应的方式来优化并缩短由于 Redis 维护造成的不可访问的时间的更多相关文章
- Windows Azure Redis 缓存服务
		
8月20日,Windows Azure (中国版)开始提供Redis缓存服务,比较国际版的Microsoft Azure晚了差不多一年的时间.说实话,微软真不应该将这个重要的功能delay这么长时间, ...
 - ABP从入门到精通(3):aspnet-zero-core 使用Redis缓存
		
一.Redis是什么? redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合).zset ...
 - Redis缓存相关问题总结
		
使用缓存是系统性能优化的第一黄金法则. 缓存的设计和使用对一个系统的性能至关重要,平时接触到项目无论多少也都会在某些层面用到缓存,比如用HashMap实现,Ehcache,memcached.redi ...
 - Redis缓存的设计、性能、应用与数据集群同步
		
Redis缓存的设计.性能.应用与数据集群同步 http://youzhixueyuan.com/design-performance-and-application-of-redis-cache.h ...
 - SpringBoot缓存管理(二) 整合Redis缓存实现
		
SpringBoot支持的缓存组件 在SpringBoot中,数据的缓存管理存储依赖于Spring框架中cache相关的org.springframework.cache.Cache和org.spri ...
 - 4-11 CS后台项目-4 及 Redis缓存数据
		
使用Redis缓存数据 使用Redis可以提高查询效率,一定程度上可以减轻数据库服务器的压力,从而保护了数据库. 通常,应用Redis的场景有: 高频查询,例如:热搜列表.秒杀 改变频率低的数据,例如 ...
 - spring boot redis缓存JedisPool使用
		
spring boot redis缓存JedisPool使用 添加依赖pom.xml中添加如下依赖 <!-- Spring Boot Redis --> <dependency> ...
 - 使用redis缓存数据需要注意的问题以及个人的一些思考和理解
		
之前我有博客也尝试过使用redis,在实际的项目中确实作用挺大的.至少对于数据的频繁读取来说都起着至关重要的作用. 但是随着技术的学习,慢慢的业务要复杂起来,以后也许会用到redis集群,所以在这边查 ...
 - SpringBoot集成Redis分布式锁以及Redis缓存
		
https://blog.csdn.net/qq_26525215/article/details/79182687 集成Redis 首先在pom.xml中加入需要的redis依赖和缓存依赖 < ...
 - Redis缓存雪崩、缓存穿透、缓存击穿、缓存降级、缓存预热、缓存更新
		
Redis缓存能够有效地加速应用的读写速度,就DB来说,Redis成绩已经很惊人了,且不说memcachedb和Tokyo Cabinet之流,就说原版的memcached,速度似乎也只能达到这个级别 ...
 
随机推荐
- Linux KVM网络处理过程
			
Linux KVM网络处理过程 总体解决方法 本次遇到的问题是KVM的网桥处理不小心导致系统无法连接.处理简要总结: 进入机房,给IPMI插上网线, 开机点 Del 进入bios 设置IMPI的地址 ...
 - 深度解析C#数组对象池ArrayPool<T>底层原理
			
提到池化技术,很多同学可能都不会感到陌生,因为无论是在我们的项目中,还是在学习的过程的过程,都会接触到池化技术.池化技术旨在提高资源的重复使用和系统性能,在.NET中包含以下几种常用的池化技术. (1 ...
 - 学到一个编码技巧:用重复写入代替if判断,减少程序分支
			
作者:张富春(ahfuzhang),转载时请注明作者和引用链接,谢谢! cnblogs博客 zhihu Github 公众号:一本正经的瞎扯 近期阅读了rust标准库的hashbrown库(也就是一个 ...
 - 各大安卓模拟器的adb端口和使用对比
			
在手游开发中,经常会使用模拟器来进行adb调试,本文列出了市面上主流模拟器的adb端口和使用对比. 模拟器ADB端口 市面上常见的模拟器连接ADB的端口列表: 网易MuMu模拟器 7555 夜神安卓模 ...
 - MeshFilter mesh vs sharedMesh
			
MeshFilter有两个属性mesh和sharedMesh,从官方文档和实际使用来说说这两者的区别 MeshFilter文档 Unity的MeshFilter文档:https://docs.unit ...
 - vim 从嫌弃到依赖(19)——替换
			
之前讨论了关于在vim中使用正则表达式的相关知识能方便的进行搜索,现在在之前的基础之上继续来讨论如何进行替换操作. substitute 简介 substitute 允许我们先查找一段文本并用新的文本 ...
 - 手撕Vue-实现计算属性
			
前言 经过上一篇的学习, 完成了将数据代理到了 Nue 的实例上方,这个我们已经撕完了.接下来要实现的是计算属性,计算属性的实现原理是通过 Object.defineProperty() 来实现的,我 ...
 - TienChin-课程管理-课程更新接口
			
更改包名 将之前的 entity 更改为 domain: 将之前的 validator 包当中的校验分组接口移动到 common 模块当中,因为其它模块也需要使用就放到公共当中进行存储. 更改完毕之后 ...
 - Rsync+Inotify 实现数据同步
			
Rsync 是UNIX及类UNIX-Like平台下一款强大的数据镜像备份软件,它不像FTP或其他文件传输服务那样需要进行全备份,Rsync 可以根据数据的变化进行差异备份,从而减少数据流量,提高工作效 ...
 - 【题解】U388218 数数
			
数数 题目描述 给定 n 个不超过 1.5×10⁹ 的自然数.求这些自然数各自出现的次数,并按照自然数从小到大的顺序输出统计结果. 输入格式 输入的第 1 行是整数 n ,表示自然数的个数. 第 2 ...