Redis:Remote DIctionary Server(远程字典服务器)。是完全开源免费的,用C语言编写的,遵守BSD协议,是一个高性能的(key/value)分布式内存数据库,基于内存运行并支持持久化的NoSQL数据库,是当前最热门的NoSql数据库之一,也被人们称为数据结构服务器。
开源界的 5 大许可协议:五大开源许可协议分别是GPL,LGPL,BSD,MIT,Apache。
三个特点:
- Redis支持数据的持久化,可以将内存中的数据保持在磁盘中,重启的时候可以再次加载进行使用。
- Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储。
- Redis支持数据的备份,即master-slave模式的数据备份。
【1】单进程
Redis是以单进程模型为处理客户端的请求。对读写等事件的响应是通过对epoll函数的包装来做到的。
Redis的实际处理速度完全依靠主进程的执行效率。
Epoll是Linux内核为处理大批量文件描述符而作了改进的epoll,是Linux下多路复用IO接口select/poll的增强版本,它能显著提高程序在大量并发连接中只有只有少量活跃的情况下的系统CPU效率。
【2】默认16个DB
查看conf配置文件如下:
上图说明,默认共有16个数据库,连接默认使用第一个数据库(db[0])。
可以使用如下命令切换数据库使用:
select index //如select 1
【3】查看当前数据库key的个数
命令格式如下:
DBSIZE
【4】清空当前/全部库
- 清空当前库
FLUSHDB
- 清空全部库(慎用)
FLUSHALL
【5】设置密码
Redis客户端连接默认是不需要密码的。
① 可以使用如下命令进行密码设置
config set requirepass [your password]
如下图所示,当设置密码之后,再次连接必须使用密码,否则提示无权限。
使用密码进行客户端连接:
也可以使用如下方式进行客户端连接:
② 修改conf配置文件
修改配置文件如下:
重启redis,使用①中设置的密码进行登录提示无权限。使用配置文件中设置的密码进行登录,成功。
注释掉配置文件中的密码设置,重启redis服务,再次进行客户端连接,无需使用密码。
即,使用命令配置只针对当前客户端游戏,服务重启,命令配置失效。
【6】Redis与数据库数据一致性
我们知道使用Redis作为缓存数据库时,一般会有时效性问题。如果数据库修改,则可能会造成缓存与数据库数据一致性问题,如果避免这个问题呢?
第一种情况
当Redis里面key失效了(不考虑永久key),则会穿透到数据库,从数据库获取值然后放入Redis,此时是不会有数据一致性问题的。
第二种情况
当要去修改数据库时就会出现Redis与数据库数据一致性问题。如何解决呢?比如说修改数据库后修改Redis里面的值,但是这里有一个问题,如果修改数据库成功了但是修改Redis失败了呢?
最好的办法是如果需要修改数据库里面值是先把Redis里面对应key 删除掉,然后修改数据库,这两步写在一个方法里。这样当另外请求过来时,因为Redis里面key没有了会直接穿透到数据库。
【7】Redis的启动与停止
① 启动
第一种方式:前端启动不指定配置文件
#bin目录下 ./redis-server
第二种方式:修改redis.conf,把daemonize no修改成daemonize yes,启动时,指定配置文件
./redis-server ../conf/redis.conf
第三种方式:编写服务脚本参考CentOS7 下源码安装Redis并配置服务开机启动
service start redis
② 停止
第一种方式:kill -9 pid 强制结束程序。
使用kill -9 进程的pid,强行终止Redis进程可能会导致redis持久化丢失。
第二种方式:向redis发送shutdown命令
./redis-cli shutdown
第三种方式:服务命令
service redis stop