redis安装步骤
代码语言:javascript复制# 安装gcc
yuminstallgcc
# 把下载好的redis‐5.0.3.tar.gz放在/usr/local文件夹下,并解压 wgethttp://download.redis.io/releases/redis‐5.0.3.tar.gz tarxzfredis‐5.0.3.tar.gz
cdredis‐5.0.3
# 进入到解压好的redis‐5.0.3目录下,进行编译与安装 make
# 修改配置:修改redis-conf文件
daemonizeyes#后台启动
protected‐modeno#关闭保护模式,开启的话,只有本机才可以访问redis
# 需要注释掉bind
#bind127.0.0.1(bind绑定的是自己机器网卡的ip,如果有多块网卡可以配多个ip,代表允许客户 端通过机器的哪些网卡ip去访问,内网一般可以不配置bind,注释掉即可)
启动服务:src/redis‐serverredis.conf
验证启动是否成功:ps‐ef|grepredis
进入redis客户端:src/redis‐cli
退出客户端:quit
退出redis服务:src/redis‐cli shutdown
Redis的单线程和高性能
Redis是单线程吗?
Redis 的单线程主要是指 Redis 的网络 IO 和键值对读写是由一个线程来完成的,这也是 Redis 对外 提供键值存储服务的主要流程。但 Redis 的其他功能,比如持久化、异步删除、集群数据同步等,其实是由额外的线程执行的。
Redis 单线程为什么还能这么快?
因为它所有的数据都在内存中,所有的运算都是内存级别的运算,而且单线程避免了多线程的切换性 能损耗问题。正因为Redis是单线程,所以要小心使用Redis指令,对于那些耗时的指令(比如 keys),一定要谨慎使用,一不小心就可能会导致 Redis 卡顿。
Redis 单线程如何处理那么多的并发客户端连接?
Redis的IO多路复用:redis利用epoll来实现IO多路复用,将连接信息和事件放到队列中,依次放到 文件事件分派器,事件分派器将事件分发给事件处理器。