Redis 在linux下的性能优化

redis 运维 · ez · 于 3个月前 发布 · 347 次阅读

优化服务器环境

在使用Redis时,需要考虑服务器环境的优化,以确保Redis能够发挥最大的性能。

1. 提高文件描述符的限制

Redis使用文件描述符(file descriptor)来管理客户端的连接。默认情况下,Linux系统为每个进程分配了一个最大文件描述符数的限制,通常为1024。如果Redis连接数超过该限制,Redis服务器将无法接受更多的客户端连接。为了避免这种情况,需要提高文件描述符的限制。

查看最大打开文件数:

 ulimit -n

临时调整可以使用以下命令

 ulimit -n 65535

在Linux系统中,可以通过修改/etc/security/limits.conf文件来修改文件描述符的限制。例如,以下配置将文件描述符限制提高到65535:

* soft noproc 10240
* hard noproc 10240
* soft nofile 65535
* hard nofile 65535 

打开系统配置文件 vim /etc/systemd/system.conf 找到参数,进行修改,一般是注释掉的,去掉注释,修改相应的值。

DefaultLimitNOFILE=65535:524288

需要注意的是需要重启生效,如果Redis运行在systemd管理的服务中,还需要对systemd中的文件描述符限制进行修改。可以通过以下命令查看当前的文件描述符限制:

sudo systemctl show redis@default.service | grep LimitNOFILE

如果需要修改,可以在systemd服务/usr/lib/systemd/system/redis.service添加LimitNOFILE配置,例如:

[Unit]
Description=Redis persistent key-value database
After=network.target

[Service]
ExecStart=/usr/bin/redis-server /etc/redis.conf --supervised systemd
ExecStop=/usr/libexec/redis-shutdown
Type=notify
User=redis
Group=redis
RuntimeDirectory=redis
RuntimeDirectoryMode=0755
LimitNOFILE=65535 # 增加配置参数

[Install]
WantedBy=multi-user.target

2. 配置Linux内核参数

Redis对Linux内核参数有一些要求,例如需要开启transparent huge pages(THP)和关闭overcommit_memory。可以通过以下命令查看当前的THP配置:

cat /sys/kernel/mm/transparent_hugepage/enabled

如果返回值为[always] madvise never,说明THP已经开启。如果返回值为[always] madvise [never],说明只有THP的madvise部分开启了。如果THP没有开启,可以通过以下命永久开启,到/etc/rc.d/rc.local文件中添加以下配置:

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

为了使其生效,要给rc.local文件加权限

chmod +x /etc/rc.d/rc.local

需要注意的是,在某些情况下,THP会影响Redis的性能。如果遇到性能问题,可以尝试禁用THP。

另外,Redis需要关闭overcommit_memory,否则可能会导致内存不足的错误。可以将此命令添加到/etc/sysctl.conf文件中,以便永久生效。

vm.overcommit_memory=1

3、增大TCP队列的值

此参数是指:已完成三次握手的TCP连接队列,默认值511,但是Linux系统内核参数socket最大连接的值默认是128,对应文件/proc/sys/net/core/somaxconn,当系统并发量大且客户端连接缓慢时,应该将两个值进行参考设置。

建议将/proc/sys/net/core/somaxconn的值设置为2048, 如果重启生效,需要在/etc/sysctl.conf中设置: net.core.somaxconn = 2048 执行sysctl -p生效

查看系统当前参数:

cat /proc/sys/net/core/somaxconn

本文由 ez 创作,采用 知识共享署名 3.0 中国大陆许可协议 进行许可。 可自由转载、引用,但需署名作者且注明文章出处。

共收到 0 条回复
没有找到数据。
添加回复 (需要登录)
需要 登录 后方可回复, 如果你还没有账号请点击这里 注册