首页 > 数据库 >优化Redis缓存淘汰机制解决性能测试中报错率逐渐攀升问题

优化Redis缓存淘汰机制解决性能测试中报错率逐渐攀升问题

时间:2023-08-26 17:55:54浏览次数:46  
标签:缓存 登录 tokenid 过期 Redis 报错

在某个查询场景的性能测试过程中,遇到了一个问题:测试过程中报错率逐渐攀升。进一步检查后发现,在查询业务所在应用的后台日志和平台应用的后台日志中,都出现了用户登录相关的报错信息。经过排查分析,发现了问题的根源,并做出了解决方案。

问题描述

在测试过程中,发现报错率逐渐增加,并且在后台日志中出现以下错误信息:

查询业务应用后台日志:

2023-08-25 19:37:49.629 xxx-web [019c40515a0854f4,019c40515a0854f4] [http-nio-9900-exec-576] ERROR [BaseService.java:249] - 调用平台权限接口失败,基础资料调用平台权限数据查询接口失败!
com.ufgov.ma.exception.MaException: 基础资料调用平台权限数据查询接口失败!

被调用的平台应用后台日志:

用户未登录或会话过期!

排查过程

进行了以下排查步骤来找到问题的根源:

  1. 完成9750个用户登录,并登入Redis集群,使用命令keys userlogininfo:*查询。发现每个节点平均分配了3000多个用户的tokenid。
  2. 在执行业务压测时,观察到Redis缓存中的tokenid逐渐减少。
  3. 查看redis集群监控,内存达到上限。
  4. 检查Redis配置的缓存淘汰机制,发现设置为volatile-lru,即在设置了过期时间的键空间中,优先移除最近未使用的key。

问题分析

通过以上排查过程,初步得出以下结论和分析:

  • 用户登录时生成的tokenid被写入Redis缓存。
  • 在业务场景压测过程中,大量的业务要素写入Redis缓存,导致内存占用逐渐增加。
  • 当Redis达到内存上限时,根据缓存淘汰机制的设定,会删除最近未使用的key。
  • 这就导致了用户的tokenid被误删,从而引发了报错和用户登录失效的问题。

解决思路

基于以上问题分析,提出了以下解决思路:

  1. 将Redis配置的缓存淘汰机制设置为volatile-ttl,即在设置了过期时间的键空间中,具有更早过期时间的key优先移除。
  2. 调整tokenid的过期时间较长,同时将业务要素的过期时间调短。
  3. 进行再次压测,观察性能测试结果。

解决方案实施

按照上述解决思路进行实施:

  1. 将Redis配置的缓存淘汰机制设置为volatile-ttl
  2. 调整tokenid的过期时间为较长时间,例如86400秒(24小时),以确保用户登录信息在一定时间内不会被过期清理。
    #session的超时时间默认86400秒(登录超过1天必须重新登录)
    sessionTimeOut=86400
    #userLoginInfo的超时时间默认14400秒(没有操作超过4小时需要重新登录)
    userLoginInfoTimeOut=86400
  3. 同时,调整业务要素的过期时间为较短时间,以避免大量业务要素占用过多的内存资源(已设置为默认)。
  4. 再次进行性能测试,观察报错率和后台日志。

结果与总结

经过上述优化方案的实施,得到了以下结果和结论:

结果: 

  • 在再次执行压测后,我们观察到测试结果的报错率为0,并且应用后台日志中不再出现用户登录失效的报错信息,问题成功解决。

结论:

  • 在高并发场景下,Redis的内存资源可能会因为大量业务要素的写入而达到上限。
  • 使用缓存淘汰机制时,应根据业务需求调整设置,以确保重要数据的有效性和可用性。
  • 调整tokenid的过期时间和业务要素的过期时间,可以有效减少缓存清理过程中用户登录信息被误删除的情况。

通过本次经验,我们了解到在进行性能测试或高并发压力测试时,需要充分考虑缓存管理的影响,并针对具体业务场景进行优化。同时,通过正确的排查和分析,结合合理的解决思路和方案,我们能够有效地解决问题并提升系统的稳定性和性能表现。

标签:缓存,登录,tokenid,过期,Redis,报错
From: https://www.cnblogs.com/n00dle/p/17659182.html

相关文章

  • IPV6配置redis
    一、全局单播地址(2000::/3)redis.conf配置IPV6bind::正常启动即可redis-cli--clustercreate--cluster-replicas0ipv6地址:6379ipv6地址:6389ipv6地址:6399二、链路本地地址(FE80::/10)redis.conf可以配置链路本地地址bindipv6链路本地地址%eth0但是创建集群的时候就会......
  • ubuntu安装go和redis
    ubuntu系统怎么安装go的redis 要在Ubuntu系统上安装Go语言的Redis驱动,可以按照以下步骤进行操作:首先,确保已经安装了Go语言和Redis。可以使用以下命令检查是否已经安装了Go语言:Copygoversion如果未安装Go语言,请使用以下命令安装:Copysudoaptupdates......
  • 启动mysql数据库时报错unknown variable 'rpl_semi_sync_slave_enabled=1'
    问题描述:启动mysql数据库时报错unknownvariable'rpl_semi_sync_slave_enabled=1'.数据库:mysql5.7.21系统:rhel7.31、异常重现--启动数据库[mysql@mysql-leo-slavedata]$/usr/local/mysql/bin/mysqld_safe--defaults-file=/home/mysql/etc/my.cnf&--告警信息2023-08-......
  • 使用filebeat监听异常日志发送redis
    使用场景:自定义监听日志关键字符,第一时间发现生产问题,实测从服务打出异常日志到redis监听到日志延迟在5s左右适用于:服务机器数有限的情况,目前全部采用手动部署的方式,一、在目标机器上部署filebeat官网下载filebeathttps://artifacts.elastic.co/downloads/beats/filebeat/......
  • 法医奇遇记:蛋糕店与HTTP缓存协议
    爱情这个词绝对不是虚幻的、精神的,而是客观的、物质的,是一系列化学反应的结果,每一次爱情的发生都分为三个阶段,而每一个阶段都受制于特定激素的影响而发生。第一个阶段的重要激素叫苯基乙胺,是一种大脑分泌的神经兴奋剂,当你对一个人产生意乱神迷的感觉时,爱情的萌芽就发生了,而第一种......
  • 报错ValueError: Can't find 'adapter_config.json'
    前言在做组内2030项目时,我具体做的一个工作是对大模型进行LoRA微调,在整个过程中有许多坑,其中有些值得记录的问题,于是便产生了这篇博客。问题我在得到微调好的模型后,需要对模型进行性能测评。在加载模型时,遇到如下报错ValueError:Can'tfind'adapter_config.json'补充:报错......
  • redis的五大数据类型
    String(字符串)string是redis最基本的类型,你可以理解成与Memcached一模一样的类型,一个key对应一个value。string类型是二进制安全的。意思是redis的string可以包含任何数据。比如jpg图片或者序列化的对象。string类型是Redis最基本的数据类型,一个redis中字符串value最多可以是512M......
  • 【python】使用ddddocr模块报错处理:AttributeError: module 'PIL.Image' has no attri
    安装pipinstallddddocr安装特别慢,几kb每秒,而且容易超时报错使用清华源下载:pipinstall-ihttps://pypi.tuna.tsinghua.edu.cn/simpleddddocr使用img_url="https://user.wangxiao.cn/apis//common/getImageCaptcha"img_resp=session.post(img_url)......
  • Redis——急速安装并设置自启(CentOS)
    现状对于开发人员来说,部署服务器环境并不是一个高频操作。所以就导致绝大部分开发人员不会花太多时间去学习记忆,而是直接百度(有一些同学可能连链接都懒得收藏)。所以到了部署环境的时候就头疼,甚至是抗拒。除了每次都要折腾个把小时(甚至更久)以外,还会觉得:我是开发不是运维,为什么要搞这......
  • Redis安装说明
    Redis安装说明大多数企业都是基于Linux服务器来部署项目,而且Redis官方也没有提供Windows版本的安装包。因此课程中我们会基于Linux系统来安装Redis.此处选择的Linux版本为CentOS7.Redis的官方网站地址:https://redis.io/1.单机安装Redis1.1.安装Redis依赖Redis是基于C语言编......