当前位置: 代码网 > it编程>数据库>Redis > 解决redis启动的警告日志问题

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

2024年05月18日 Redis 我要评论
redis启动时,出现警告日志原因是redis缓存的数据过多,没有提前做好数据过期策略,导致超过物理机的实际内存。需要修改计算机内存策略(1)警告描述,不能设置tcp的堆积为511因为/proc/sy

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

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持代码网。

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com