Mécanisme d'expiration du cache redis et d'élimination de la mémoire

Gundy. 2021-11-25 17:40:40
canisme expiration du cache redis

ExpirékeyComment gérer?

C'est réglé.expireDekeyCache expiré,Mais la mémoire du serveur est encore occupée,C'est parce queredisDeux politiques de suppression basées sur
redisIl y a deux stratégies:

  1. (Initiative)Suppression programmée
    • Les contrôles aléatoires programmés expirentkey,Nettoyage et suppression en cas d'expiration.(Le nombre de contrôles par seconde est deredis.confDanshzConfiguration)
  2. (Passif)Retrait inerte
    • Lorsque le client demande unkeyQuand,AlorsredisJe vais vérifier ça.keyExpire - t - il?,Si elle expire,Supprimer,Puis unnil.Cette stratégie est juste pourcpuPlutôt amical,Il n'y aura pas beaucoup de pertes,Mais l'utilisation de la mémoire sera plus élevée.

Alors...,Bien quekeyC'est trop tard.,Mais tant qu'il n'est pasredisNettoyage,Donc la mémoire est toujours occupée.

Donc si la mémoire estRedisEt si l'utilisation du cache est lente?

La mémoire est pleine.,Le disque dur peut être utilisé,Pour sauver,Mais ça n'a pas de sens,Parce que le disque dur n'a pas de mémoire rapide,Ça affecteredisPerformance.
Alors...,Quand la mémoire est pleine,redisUn mécanisme d'élimination du cache est fourni:MEMORY MANAGEMENT

maxmemory:Lorsque l'utilisation de la mémoire atteint,Puis commencer à nettoyer le cache

* noeviction:L'ancien cache n'expire jamais,Le nouveau cache ne peut pas être défini,Erreur retournée
* allkeys-lru:Effacer l'ancien cache le moins utilisé,Puis sauvegardez le nouveau cache(Recommandé)
* allkeys-random: Supprimer au hasard dans tous les caches (Non recommandé)
* volatile-lru: Dans ces paramètres expire Dans le cache avec un délai d'expiration ,Effacer l'ancien cache le moins utilisé,Puis sauvegardez le nouveau cache
* volatile-random: Dans ces paramètres expire Dans le cache avec un délai d'expiration , Suppression aléatoire du cache
* volatile-ttl: Dans ces paramètres expire Dans le cache avec un délai d'expiration ,Supprimer l'expiration imminente`
Copier le Code
版权声明
本文为[Gundy.]所创,转载请带上原文链接,感谢
https://javamana.com/2021/11/20211125174038326a.html

  1. http://lx.gongxuanwang.com/sszt/32.htm
  2. 回顾我两个月面试阿里,携程,小红书,美团,网易等等(Java岗)
  3. JavaScript高级程序设计读后感(一)之零碎知识点查漏补缺
  4. http://lx.gongxuanwang.com/sszt/7.htm
  5. #yyds干货盘点#设计模式之【工厂模式】
  6. Java * SpringBoot实现万能文件在线预览,已开源,真香
  7. Redis | 第4章 Redis中的数据库《Redis设计与实现》
  8. Redis | 第4章 Redis中的数据库《Redis设计与实现》
  9. 关于centos docker版本过低导致 is not a valid repository/tag: invalid reference format
  10. Redis 源码简洁剖析 02 - SDS 字符串
  11. 回顧我兩個月面試阿裏,攜程,小紅書,美團,網易等等(Java崗)
  12. Rétrospectivement, j'ai passé deux mois à interviewer Ali, ctrip, Little Red Book, meituan, NetEase, etc. (Java post)
  13. Docker + webhook Automation Deployment Front End Project
  14. Java技术之Spring、Hibernate框架整合方法
  15. http://lx.gongxuanwang.com/sszt/32.htm
  16. 亚马逊自己的 Linux 发行版现在完全基于 Fedora 了
  17. Redis 源码简洁剖析 02 - SDS 字符串
  18. Java技術之Spring、Hibernate框架整合方法
  19. Méthode d'intégration des cadres de printemps et d'hibernation de la technologie Java
  20. Redis source Concise Analysis 02 - SDS String
  21. La distribution Linux d'Amazon est maintenant entièrement basée sur Fedora
  22. org.springframework.web.bind.MissingServletRequestParameterException
  23. Built in constraints and functions of MySQL Foundation (2)
  24. Basic operation of MySQL Foundation (I)
  25. Introduction to Java zero foundation 3: Java data types
  26. 从零开始搭建EasyDarwin环境——Linux系统开发环境搭建Golang
  27. Redis source Concise Analysis 02 - SDS String
  28. Construire l'environnement easydarwin à partir de zéro - - construire l'environnement de développement du système Linux golang
  29. javaweb代码是正确的,但是第一行代码就报错了
  30. **** | Java | 后端开挂:3行代码写出8个接口
  31. Java || 看了大二学长写的代码,我竟开始默默的模仿了。。。
  32. Java | 手把手教你实现一个抽奖系统(Java版)
  33. Java | Manuel pour vous apprendre à mettre en œuvre un système de loterie (version Java)
  34. Java | | après avoir lu le Code que j'ai écrit en deuxième année, j'ai commencé à imiter silencieusement...
  35. Java | back - end Pending: 3 - line Code write 8 Interfaces
  36. Le Code Web Java est correct, mais la première ligne de code est incorrecte
  37. Android网络编程之Http通信
  38. Android網絡編程之Http通信
  39. Http communication for Android Network Programming
  40. 数据结构实验八 领会图的两种主要储存结构和图的基本运算算法设计
  41. Hibernate数据校验简介
  42. The story of spring
  43. Il a dépensé 270 000 yuans pour soulever Xiaopeng p7 et a parcouru 3 627 km. Le propriétaire du véhicule a partagé 6 avantages et inconvénients.
  44. 阿里蚂蚁花呗团队面试题:spring+分布式+jvm+session+redis
  45. 【Java入门100例】14.字符串排序——compareTo()
  46. 【Java入门100例】13.修改文件扩展名——字符串替换
  47. Leetcode 79. Word Search [C + + / java detailed problem]
  48. Introduction à la vérification des données hibernantes
  49. Expérience de la structure des données
  50. Spring cloud gateway practice 2: more routing configuration methods
  51. Java network programming - summary overview
  52. 基于语法树的 Java 代码自动化插桩
  53. 云原生 Spring Boot 应用配置 Prometheus + Grafana 监控(保姆级)
  54. Spring cloud gateway practice 2: more routing configuration methods
  55. Jenkins file one line of code to deploy. Net program to k8s
  56. Java network programming - summary overview
  57. Cloud Native Spring Boot application configuration Prometheus + grafana Monitoring (baby - sitter)
  58. Insertion automatique de code Java basée sur l'Arbre syntaxique
  59. Le SUV phare de Xiaopeng, Xiaopeng G9, a fait ses débuts au salon de l'automobile et s'est tenu en position C dans la nouvelle force?
  60. Docker 从入门到实践系列四 - Docker 容器编排利器 Docker Compose