Redis- 内核的分配内存限制的警告“WARNING Memory overcommit must be enabled!”

文章目录

      • 问题描述
      • 报错原因
      • 影响
      • 解决方案
      • 注意事项

问题描述

[root@redisxxx]# redis-sentinel ./sentinel.conf

19638:X 01 Nov 2024 16:57:27.180 # WARNING Memory overcommit must be enabled! Without it, background save or replication may fail under low memory condition. Being disabled, it can also cause failures without low memory condition, see https://github.com/jemalloc/jemalloc/issues/1328. To fix this issue add ‘vm.overcommit_memory = 1’ to /etc/sysctl.conf and then reboot or run the command ‘sysctl vm.overcommit_memory=1’ for this to take effect.

[root@redisxxx]# redis-server ./redis.conf

19638:X 01 Oct 2024 16:57:27.180 # WARNING Memory overcommit must be enabled! Without it, a background save or replication may fail under low memory condition. Being disabled, it can also cause failures without low memory condition, see https://github.com/jemalloc/jemalloc/issues/1328. To fix this issue add ‘vm.overcommit_memory = 1’ to /etc/sysctl.conf and then reboot or run the command ‘sysctl vm.overcommit_memory=1’ for this to take effect.

这个报错信息是Redis一些服务启动时的一个警告,它指出了操作系统内存管理配置的一个问题。具体来说,这个警告涉及到Linux内核的vm.overcommit_memory参数。

报错原因

vm.overcommit_memory是Linux内核的一个参数,用来控制内核如何处理内存分配请求。如果这个参数被设置为0(默认值),内核会尝试预测应用程序的内存需求,并在分配内存时进行限制,以防止单个应用程序或进程使用过多的内存导致系统OOM(Out of Memory)。但是,这种预测并不总是准确的,可能会导致即使系统有足够的内存,应用程序也无法分配到足够的内存,特别是对于像Redis这样的内存密集型应用。

影响

vm.overcommit_memory被设置为0时,可能会在以下情况下导致问题:

  • 内存充足的情况:即使系统有足够的内存,Redis的背景保存(RDB持久化)或复制操作也可能失败,因为内核预测这些操作会使用过多的内存。
  • 内存不足的情况:在内存资源紧张的情况下,这种限制更加明显,可能导致Redis操作失败。

解决方案

为了解决这个问题,建议将vm.overcommit_memory设置为1。这个设置告诉内核允许进程分配内存,即使它超过了物理内存的限制。这样做的前提是系统有足够的交换空间(swap),因为当物理内存不足时,Linux会使用交换空间。

以下是如何设置vm.overcommit_memory的步骤:

  1. 临时设置
    在命令行中运行以下命令,临时设置vm.overcommit_memory为1:

    sysctl vm.overcommit_memory=1
    
  2. 永久设置
    要使这个设置永久生效,需要编辑/etc/sysctl.conf文件,并添加或修改以下行:

    vm.overcommit_memory = 1
    

    然后,运行sysctl -p使配置生效。

  3. 重启
    另一种使设置永久生效的方法是重启系统。

注意事项

  • 性能影响:设置vm.overcommit_memory = 1可能会增加系统OOM的风险,特别是在没有足够交换空间的情况下。因此,需要确保系统有足够的交换空间来处理额外的内存需求。
  • 监控:即使设置了vm.overcommit_memory = 1,也应该监控系统的内存使用情况,确保不会出现内存不足的情况。

通过上述步骤,可以解决Redis服务启动时的这个警告,并提高Redis在低内存条件下的稳定性和可靠性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/2709.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

儿童安全座椅行业全面深入分析

儿童安全座椅就是一种专为不同体重(或年龄段)的儿童设计,将孩子束缚在安全座椅内,能有效提高儿童乘车安全的座椅。欧洲强制性执行标准ECE R44/03的定义是:能够固定到机动车辆上,带有ISOFIX接口、LATCH接口的…

算法笔记:Day-09(初始动态规划)

509. 斐波那契数 斐波那契数 (通常用 F(n) 表示)形成的序列称为 斐波那契数列 。该数列由 0 和 1 开始,后面的每一项数字都是前面两项数字的和。也就是: F(0) 0,F(1) 1 F(n) F(n - 1) F(n - 2),其中 …

HTTP和HTTPS 的作用和应用场景 (python 爬虫简单入门)

HTTP和HTTPS HTTP HTTP协议(HyperText Transfer Protocol,超文本传输协议):是一种发布和接收 HTML页面的方法。 HTTP的端口号为80 HTTPS HTTPS(Hypertext Transfer Protocol over Secure Socket Layer)…

Java多线程编程(三)一>详解synchronized, 死锁,wait和notify

目录: 一.synchronized 的使用: 二. 常见死锁情况: 三 .如何避免死锁: 四.wait和notify 一.synchronized 的使用: 我们知道synchronized锁具有互斥的特点: synchronized 会起到互斥效果, 某个线程…

linux入门——“初识make”

make是linux中的自动化构建工具,一般来说系统会自带make,如果没有,那么可以使用命令“sudo apt install -y make”来安装。 1.初识make make使用的前提是维护makefile/Makefile文件,需要在自己的目录下自己创建。 我在此目录下创…

【K8S系列】Kubernetes 中 Pod 无法通过 Service 名称访问服务的 DNS 解析失败问题【已解决】

在 Kubernetes 中,Service 提供了一种稳定的方式,通过名称访问一组 Pod。当其他 Pod 无法通过 Service 名称访问服务,并且出现 DNS 解析失败时,通常会导致应用无法正常工作。本文将详细分析此问题的常见原因及其解决方案。 一、问…

关于分布式事务,你知道多少?如何落地?

很多人估计会说,我在项目中完全没有涉及到过分布式事务,而面试官老喜欢问,真TM烦! 本文就来聊聊分布式事务,有哪些方案和实现。文章有点长,可以先收藏,有时间了慢慢看。 什么是事务?…

SIwave:释放 Resonant Mode Solver 的强大功能

SIwave 是一种电源完整性和信号完整性工具。本文的重点是 Resonant 模式求解器。 进行谐振计算的主要原因是确定 Powerplane 中 Cap 去耦的最佳位置。Powerplane 的大小由最大预期电流和允许的最大电压降决定。然而,即使是最好的设计也没有足够的电容来将宽带频谱的…

【VS+QT】联合开发踩坑记录

0. 写在前面 因为目前在做自动化产线集成软件开发相关的工作,需要用到QT,所以选择了VS联合开发,方便调试。学习QT的过程中也踩了很多坑,在此记录一下,提供给各位参考。 1. 环境配置 Win11Visual Studio 2019Qt 5.12…

【LeetCode】每日一题 2024_11_1 超级饮料的最大强化能量(DP)

前言 每天和你一起刷 LeetCode 每日一题~ LeetCode 启动! 题目:超级饮料的最大强化能量 代码与解题思路 先读题: 题目给了两个数组,长度为 n,题目要求在 n 个小时内选择饮料,一个小时可以选一瓶&#x…

IBM服务器修改IMM的IP方法

服务器设备:IBM x3550 M4 Server IMM默认IP地址:192.168.70.125 用户名:USERID 密码:PASSW0RD(注意是零0) 1.服务器开机按F1进入BIOS界面 2.进入System Settings 3.进入Integrated Management Module 4.…

【MATLAB代码】一维UKF的IMM,模型有CV和CA

目录 ​编辑 代码介绍 主要功能 UKF 更新函数 总结 代码介绍 这段 MATLAB 代码实现了一维无迹卡尔曼滤波(UKF)与交互多模型(IMM)结合的算法,旨在对非线性动态系统进行状态估计。代码中的模型包括恒速&#xff08…

Java对象、类、接口——针对实习面试

目录 Java对象、类、接口你知道类和对象的区别吗?抽象类和接口有什么共同点?抽象类和接口有什么区别?说一下面向对象的三大特征及其特点?你知道Java中方法重载和重写的区别吗?静态成员和非静态成员有什么区别&#xff…

Solana链上的Pump狙击机器人与跟单机器人的工作原理及盈利模式

随着加密货币市场的快速发展,越来越多的投资者和开发者开始关注Solana链上的自动化交易工具。尤其是Pump狙击机器人和跟单机器人,这两种工具为用户提供了在市场波动中获取利润的机会。本文将深入分析这两种机器人的工作原理及其盈利模式。 一、Pump狙击机…

Vue全栈开发旅游网项目(6)-接口开发

1.景点详情接口开发 1.设计响应数据结构 文件地址:sight/serializers.py 创建类: class SightDetailSerializers(BaseSerializer):#景点详情def to_dict(self):obj self.objreturn {id: obj.id,name: obj.name,desc: obj.desc,img: obj.banner_img.…

Flutter学习笔记(二)------ 第一个flutter项目

一、Dart语法 dart语法较为简单,学过python和c后发现大同小异。不过多介绍 1.函数可变参数 可以类比*args, **kwargs,与之不同的是dart中,*args **kwargs不能同时存在 void a(int a, [float x, double b0.0]) {//do something... }a(10, …

MySQL-如果你在添加外键时忘加约束名,如何找到系统默认的约束名

问题 在你添加约束的时候,一般都会为其取名以方便后期的修改,但是如果你忘记了呢,如何找到系统默认的约束名 解决方法 -- 查找约束名 SELECTCONSTRAINT_NAME FROMINFORMATION_SCHEMA.KEY_COLUMN_USAGE WHERETABLE_NAME emp ANDREFERENCED_T…

2-Ubuntu/Windows系统启动盘制作

学习目标: 掌握使用Win32DiskImager、Rufus等工具制作系统启动盘的基本步骤。独立将ISO镜像文件写入USB闪存驱动器,确保在需要时顺利安装或修复系统。通过学习如何选择正确的源文件和目标驱动器,理解启动盘的使用场景和注意事项,…

上云管理之Git/GitHub/GitLab 详解(一)

上云管理之Git/GitHub/GitLab 详解(一) 引言1. GIT软件安装2.初始化配置与提交代码2.1. 初始化配置2.2 本地仓库代码提交2.2.1 初始化仓库并提交代码2.2.2 再次提交已修改的代码2.2.3 文件夹层次结构代码提交 2.3 GIT 的文件状态 3.GIT 分支3.1. 分支的切换与删除3.…

【UltraVNC】使用反向连接方式-部署私有远程工具(简版)

一、简要介绍 反向连接:客户电脑发起连接到维修工程师电脑。 场景:计算机A 无公网IP ,计算机B无公网IP,AB直接进行远程的行为。 核心:借助中继方式 二、安装环境和安装包 中继器服务:linux系统安装包&…