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

 更新时间:2024年01月26日 09:59:04   作者:KKang@  
这篇文章主要介绍了解决redis启动的警告日志问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
(福利推荐:【腾讯云】服务器最新限时优惠活动,云服务器1核2G仅99元/年、2核4G仅768元/3年,立即抢购>>>:9i0i.cn/qcloud

(福利推荐:你还在原价购买阿里云服务器?现在阿里云0.8折限时抢购活动来啦!4核8G企业云服务器仅2998元/3年,立即抢购>>>:9i0i.cn/aliyun

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

总结

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

相关文章

  • RediSearch加RedisJSON大于Elasticsearch的搜索存储引擎

    RediSearch加RedisJSON大于Elasticsearch的搜索存储引擎

    这篇文章主要为大家介绍了RediSearch加RedisJSON大于Elasticsearch的王炸使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-07-07
  • Redis慢查询的实现

    Redis慢查询的实现

    本文主要介绍了Redis慢查询的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-07-07
  • Redis实现限流器的三种方法(小结)

    Redis实现限流器的三种方法(小结)

    本文主要介绍了Redis实现限流器的三种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-05-05
  • Redis分布式锁存在的问题(推荐)

    Redis分布式锁存在的问题(推荐)

    有很多基于Redis实现的分布式锁方案或者库,但是有些库并没有解决分布式环境下的一些问题陷阱,这篇文章主要介绍了Redis分布式锁存在的问题,需要的朋友可以参考下
    2022-12-12
  • Spring?Boot实战解决高并发数据入库之?Redis?缓存+MySQL?批量入库问题

    Spring?Boot实战解决高并发数据入库之?Redis?缓存+MySQL?批量入库问题

    这篇文章主要介绍了Spring?Boot实战解决高并发数据入库之?Redis?缓存+MySQL?批量入库问题,本文通过图文实例相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-02-02
  • odoo中使用redis实现缓存的步骤

    odoo中使用redis实现缓存的步骤

    这篇文章主要介绍了odoo中使用redis实现缓存的步骤,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-04-04
  • Linux系统下安装Redis数据库过程

    Linux系统下安装Redis数据库过程

    大家好,本篇文章主要讲的是Linux系统下安装Redis数据库过程,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下,方便下次浏览
    2021-12-12
  • Go语言操作RediSearch进行搜索方法示例详解

    Go语言操作RediSearch进行搜索方法示例详解

    这篇文章主要为大家介绍了Go语言操作RediSearch进行搜索方法示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-12-12
  • Redis中统计各种数据大小的方法

    Redis中统计各种数据大小的方法

    这篇文章主要介绍了Redis中统计各种数据大小的方法,本文使用PHP实现统计Redis内存占用比较大的键,需要的朋友可以参考下
    2015-03-03
  • 浅析Redis中String数据类型及其底层编码

    浅析Redis中String数据类型及其底层编码

    这篇文章主要介绍?Redis?中?String?数据类型及其底层编码,文中有详细的代码示例,对大家的工作及学习有一定的帮助,需要的朋友可以参考下
    2023-05-05

最新评论

?


http://www.vxiaotou.com