解决redis启动的警告日志问题

 更新时间:2024年01月26日 09:59:04   作者:KKang@  
这篇文章主要介绍了解决redis启动的警告日志问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

redis启动时,出现警告日志

原因是redis缓存的数据过多,没有提前做好数据过期策略,导致超过物理机的实际内存。

需要修改计算机内存策略

(1)警告描述,不能设置tcp的堆积为511

因为/proc/sys/net/core/somaxconn的值为128太低。

报错:

WARNING: The TCP backlog setting of 511 cannot be enforced because /proc/sys/net/core/somaxconn is set to the lower value of 128.

分析:

然后了解到/proc/sys/net/core/somaxconn为linux的内核参数,即linux每端扣可以监听的最大tcp数量。

解决方案:

修改linux系统参数,在里面增加net.core.somaxconn配置,注意:直接修改/proc/sys/net/core/somaxconn内,系统重启后会还原。

永久解决:vim /etc/sysctl.conf

net.ipv4.conf.default.accept_source_route = 1

立即生效:sysctl -p

(2)一台机器如果内存用完,在进行bgsave时,可能会报错

错误信息大概如下:

WARNING overcommit_memory is set to 0! Background save may fail under low memory condition.

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的bgsave命令时,redis会fork一个进程把redis中的内存数据写入磁盘。

这样的好处是,copy on write,有效的节省了内存占用。

但是,bgsave时,如果有数据变更,一样需要申请内存。

当申请内存时,如果发现内存不够,可能就会报上面的错误

vim /etc/sysctl.conf

net.core.somaxconn= 1024
sysctl vm.overcommit_memory=1
vm.overcommit_memory = 1

立即生效:sysctl -p

(3)使用的是透明大页,可能导致redis延迟和内存使用问题

WARNING you have Transparent Huge Pages (THP) support enabled in your kernel.

This will create latency and memory usage issues with Redis.

To fix this issue run the command ‘echo never > /sys/kernel/mm/transparent_hugepage/enabled’ as root, and add it to your /etc/rc.local in order to retain the setting after a reboot.

Redis must be restarted after THP is disabled.

临时解决方法:

echo never > /sys/kernel/mm/transparent_hugepage/enabled

永久解决方法:

将其写入/etc/rc.local文件中

if test -f /sys/kernel/mm/redhat_transparent_hugepage/enabled; 
then
echo never > /sys/kernel/mm/redhat_transparent_hugepage/enabled
fi

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Redis笔记点赞排行榜的实现示例

    Redis笔记点赞排行榜的实现示例

    探店笔记类似点评网站的评价,本文主要介绍了Redis笔记点赞排行榜的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-01-01
  • Redis简单动态字符串SDS的实现示例

    Redis简单动态字符串SDS的实现示例

    Redis没有直接复用C语言的字符串,而是新建了SDS,本文主要介绍了Redis简单动态字符串SDS的实现示例,具有一定的参考价值,感兴趣的可以了解一下
    2023-08-08
  • Redis数据库分布式设计方案介绍

    Redis数据库分布式设计方案介绍

    大家好,本篇文章主要讲的是Redis数据库分布式设计方案介绍,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下
    2022-01-01
  • Redis中常见的几种集群部署方案

    Redis中常见的几种集群部署方案

    本文主要介绍了Redis中常见的几种集群部署方案,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • Redis的六种底层数据结构(小结)

    Redis的六种底层数据结构(小结)

    本文主要介绍了Redis的六种底层数据结构,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-01-01
  • Redis数据类型string和Hash详解

    Redis数据类型string和Hash详解

    大家都知道Redis中有五大数据类型分别是String、List、Set、Hash和Zset,本文给大家分享Redis数据类型string和Hash的相关操作,感兴趣的朋友跟随小编一起看看吧
    2022-03-03
  • MyBatis缓存和二级缓存整合Redis的解决方案

    MyBatis缓存和二级缓存整合Redis的解决方案

    这篇文章主要介绍了MyBatis缓存和二级缓存整合Redis,将MyBatis缓存和二级缓存整合Redis,可以提高查询效率,同时也能保证数据的可靠性和一致性,需要的朋友可以参考下
    2023-07-07
  • 完美解决linux上启动redis后配置文件未生效的问题

    完美解决linux上启动redis后配置文件未生效的问题

    今天小编就为大家分享一篇完美解决linux上启动redis后配置文件未生效的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-05-05
  • 在redhat6.4安装redis集群【教程】

    在redhat6.4安装redis集群【教程】

    这篇文章主要介绍了在redhat6.4安装redis集群【教程】,需要的朋友可以参考下
    2016-05-05
  • Redis链表底层实现及生产实战

    Redis链表底层实现及生产实战

    Redis 的 List 是一个双向链表,链表中的每个节点都包含了一个字符串。是redis中最常用的数据结构之一,本文主要介绍了Redis链表底层实现及生产实战,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧
    2023-03-03

最新评论