在使用Redis时,需要考虑服务器环境的优化,以确保Redis能够发挥最大的性能。
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
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
此参数是指:已完成三次握手的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 中国大陆许可协议 进行许可。 可自由转载、引用,但需署名作者且注明文章出处。