C#连接redis出现下面错误解决方案
客户端报错如下:
StackExchange.Redis.RedisConnectionException: No connection is available to service this operation: EXISTS UserSysData_1016644; SocketFailure on 192.172.0.128:6379/Interactive, origin: CheckForStaleConnection, input-buffer: 0, outstanding: 3, last-read: 1s ago, last-write: 0s ago, unanswered-write: 1s ago, keep-alive: 60s, pending: 0, state: ConnectedEstablished, in: 0, ar: 0, last-heartbeat: 0s ago, last-mbeat: 0s ago, global: 0s ago, mgr: RecordConnectionFailed_ReportFailure, err: never; IOCP: (Busy=1,Free=999,Min=8,Max=1000), WORKER: (Busy=3,Free=32764,Min=8,Max=32767), Local-CPU: n/a —> StackExchange.Redis.RedisConnectionException: SocketFailure on 192.172.0.128:6379/Interactive, origin: CheckForStaleConnection, input-buffer: 0, outstanding: 3, last-read: 1s ago, last-write: 0s ago, unanswered-write: 1s ago, keep-alive: 60s, pending: 0, state: ConnectedEstablished, in: 0, ar: 0, last-heartbeat: 0s ago, last-mbeat: 0s ago, global: 0s ago, mgr: RecordConnectionFailed_ReportFailure, err: never
— 内部异常堆栈跟踪的结尾 —
1.此时查看redis内存使用情况
大家可以看到, user_momory_human=used_memory_peak_human 指标。这样代表峰值的时候redis内存已经不够用了,导致服务往内存插入数据插不进去,报上述错误。
为什么会有这么大的数据量 一个是没有设置数据过期时间,二是生产的确有这么大的数据量,我们此时临时解决方案:增加redis最大内存 命令: config set maxmemory 25G ,临时增大为25G,重启客户端程序,此时程序不报错了。后期可能会根据业务情况,设置不同的key过期时间不同,这样redis压力也不会大。
关于如何在项目中正确使用redis,参考我的另一篇文章 https://blog.csdn.net/Z__Sheng/article/details/100177644
2.redis命令详解
下面是介绍命令信息:来自菜鸟教程:
server : 一般 Redis 服务器信息,包含以下域:
redis_version : Redis 服务器版本
redis_git_sha1 : Git SHA1
redis_git_dirty : Git dirty flag
os : Redis 服务器的宿主操作系统
arch_bits : 架构(32 或 64 位)
multiplexing_api : Redis 所