简介
Redis,全称 Remote Dictionary Server(远程字典服务器) ,全开源基于C语言开发,是高性能的(key/value)分布式内存数据库,基于内存运行并支持持久化的NoSQL数据库,是当前最热门的NoSQL数据库之一,也被人们称为数据结构服务器。
环境准备
操作系统
[root@had-test ~]# cat /etc/redhat-release
CentOS Linux release 7.5.1804 (Core)
redis6版本的下载连接: http://download.redis.io/releases/redis-6.0.3.tar.gz
创建redis目录,将redis的安装包下载到这个 目录
[root@had-test ~]# cd /opt/
[root@had-test opt]# mkdir redis #将redis的安装包下载到这个目录
安装依赖
yum -y install gcc gcc-c++ make tcl #测试需要依赖tcl
编译安装需要gcc5.3以上,可以用gcc -v 命令查看当前版本号,使用下面的命令升级到gcc9.1:
yum -y install centos-release-scl
yum -y install devtoolset-9-gcc devtoolset-9-gcc-c++ devtoolset-9-binutils
#scl命令启用只是临时的,新开的会话默认还是原gcc版本。
scl enable devtoolset-9 bash
#如果要长期使用gcc 9.1的话执行下面的命令即可:
echo -e "
source /opt/rh/devtoolset-9/enable" >>/etc/profile
编译安装
[root@redis-1 redis]# tar xf redis-6.0.3.tar.gz
[root@redis-1 redis]# ls
redis-6.0.3 redis-6.0.3.tar.gz
[root@redis-1 redis]# mv redis-6.0.3 redis
[root@redis-1 redis]# ls
redis redis-6.0.3.tar.gz
[root@redis-1 redis]# cd redis/
[root@redis-1 redis]# make
[root@redis-1 redis]#make install PREFIX=/opt/redis6 #安装指定目录
#如果编译出错之后再编译可以先执行命令删除之前的编译文件
make distclean
编译完了可以执行命令测试
make test
配置启动
进入到安装的目录/opt/redis6下 将源码中的redis.conf文件 复制到redis6的bin目录下并修改配置
mkdir /opt/redis6/data
cp /opt/redis/redis/redis.conf /opt//redis6/bin/
vim /opt/redis6/bin/redis.conf
#daemonize no 改为yes,开启后台运行,默认是前台运行
daemonize yes
#把这一行注释,监听所有IP
#bind 127.0.0.1
#protected-mode yes 如果改为no,则是关闭保护模式,这种模式下不能配置系统服务,建议还是开启
protected-mode yes
#requirpass,保护模式开启的时候要配置密码或者bind ip
requirepass 123456
#修改本参数,指定数据目录
dir /opt/redis6/data
#修改本参数,指定日志目录
logfile /opt//redis6/redis_6379.log
启动redis
编写启动脚本
vim /lib/systemd/system/redis.service
[Unit]
Description=Redis
After=network.target
[Service]
Type=forking
PIDFile=/var/run/redis_6379.pid
ExecStart=/opt/redis6/bin/redis-server /opt/redis6/bin/redis.conf
ExecReload=/bin/kill -s HUP $MAINPID
ExecStop=/bin/kill -s QUIT $MAINPID
PrivateTmp=true
[Install]
WantedBy=multi-user.target
使用systemctl命令
# 重载服务
systemctl daemon-reload
# 开机自启
systemctl enable redis
# 启动
systemctl start redis
# 重启
systemctl restart redis
# 停止
systemctl stop redis
# 查看状态
systemctl status redis
# 关闭开机启动
systemctl disable redis
使用Redis Desktop Manager连接Redis
下载安装redis desktop manager:
Github: https://github.com/uglide/RedisDesktopManager
官网: https://redisdesktop.com/
配置防火墙,嫌麻烦直接关闭即可:
#查看防火墙状态
systemctl status firewalld
#关闭防火墙
service firewalld stop
#开启防火墙
service firewalld start
#单独开6379端口
firewall-cmd --permanent --add-port=6379
tcpfirewall-cmd --reload
由于上面的配置我们已经开启了所有IP的监听,因此可以直接连接:
关闭保护模式且无密码模式:
开启保护模式设置密码,以systemctl命令启动和开机自启:
注:redis6之后支持多线程,使用redis6的io多线程的好处?
1,reddis6把多线程用在哪里?
redis运行的瓶颈,通常不在cpu,而在内存和网络I/O
Redis 6 对多线程的启用,主要用在处理网络I/O,
流程就是:把监听到的网络的事件,分发给work thread做处理,
在处理完之后,由主线程负责执行。
说明:这是我们要注意的地方:
redis6对于命令的执行仍然是由主线程执行,
也就是象以前使用的原子性的命令如rpush/lua脚本仍然具有原子性,
不会因为多线程的引入也失效。
2,性能提升显著:
Redis读写网络的 read/write 系统调用在 执行期间占用了大部分 CPU 时间,
所以把网络读写做成多线程的方式对性能会有很大提升,
根据测试,在 4个线程 IO 时,性能相比单线程提高一倍,
是redis6中的最可观的性能提升
3.什么情况适宜启用io多线程?
来自官方配置文件的说明:
默认情况多线程是disabled,当server有至少4个核心或更多时可以启用,
至少留下一个备用的核心。
当设置为多于8个线程时,不会用明显的性能提升
建议当确实遇到性能问题时而且redis的实例能占用cpu时间的一大部分时
再启用threaded I/O,这样会比较有效,
否则没有启用这个功能的必要。
下面是多线程的配置方法:
配置指令一
#io-threads: 启用的io线程数量
io-threads 4
这个值设置为多少?
根据配置文件的说明:
如果你的server有4个核心,尝试把这个值设置为3
如果有8个核心,尝试把这个值设置为6
但这个值不建议超过8
配置指令二:
#读请求也使用io线程
io-threads-do-reads yes
设置为yes即可,配置文件中的说明:
当I/O threads被启用时,线程仅用于写,
如果需要把读数据和协议解析也启用线程,
则需要把io-threads-do-reads也设置为yes
作者认为对读请求启用io-threads得到的帮助不算太多
redis配置多线程注意事项
1.在redis运行时通过config set 来使用线程的配置指令不会生效,
当SSL启用时,多线程也不会生效
2,如果使用redis-benchmark测试redis的速度 ,
需要确认redis-benchmark是多线程模式,
使用 --threads选项来匹配redis的线程数量,
否则不会看到性能有明显提升