Redis
什么是redis
redis是Remote Dictionary Server(远程数据服务)的缩写
该软件使用C语言编写,它的数据模型为 key-value
它支持丰富的数据结构(类型),比如 String list hash set sorted set。
可持久化,保证了数据安全。
ongz
新闻信息(数据不变化、有实时性)页面适合做页面缓存。
商品展示页面(数据有各种分类),为了降低数据库负载,他们比较适合做各个小部分的
数据缓存,数据更新也只是更新每个小块的数据缓存。
redis和memcache比较
- Redis不仅仅支持简单的k/v类型的数据,同时还提供list,set,zset,hash等数据结构的存储
- Redis支持master-slave(主-从)模式应用
- Redis支持数据的持久化,可以将内存中的数据保持在磁盘中,重启的时候可以再次加载进行使用
- Redis单个value的最大限制是1GB,memcached只能保存1MB的数据
安装redis
使用ftp将压缩包传到linux,然后解压,进入解压后目录直接make。执行后效果。
Cd src
创建redis运行目录;mkdir /usr/local/redis,并拷贝两个文件
给redis运行目录拷贝一个配置文件(配置文件在redis解压目录中)
前端启动服务./redis-server
修改redis.conf配置文件,设置后台启动redis:
带着redis.conf配置文件,在后台启动redis服务:
简单使用:
简单操作:设置和读取变量
具体使用
key的操作
在Redis里边,除了“\n”和空格不能作为名字的组成内容外,其他内容都可以作为key的名字部分。名字长度不做要求
具体命令:
keys
Redis总共有16个数据库。Redis.conf中。
不同数据库之间的切换
String类型操作
string是redis最基本的类型
Redis的string可以包含任何数据。包括jpg图片或者序列化的对象。
单个value值最大上限是1G字节。
如果只用string类型,redis就可以被看作加上持久化的memcache
incr: increment 增长
该指令可以对key进行累加1操作,默认是累加1操作,类似i++操作
该指令可以针对 新key或已有key 进行操作
新key:创建该key并累加1,其值为1.( incr 一个不存在的key相当于创建key,并设置值为1.)
已有key:key的信息值类型要求必须为整型的
已有key的信息必须为“整型”的才允许incr操作:
derc是减一操作。
Substrs是字符串截取,包括start和end标记位置内容
数据类型List
list类型其实就是一个双向链表。通过push,pop操作从链表的头部或者尾部添加删除元素。这使得list既可以用作栈,也可以用作队列。
该list链表类型应用场合:
获得最新的10个登录用户信息: select * from user order by logintime desc limit 10;
以上sql语句可以实现用户需求,但是数据多的时候,全部数据都要受到影响查询,对数据库的负载比较高。必要情况还需要给关键字段(id或logintime)设置索引,索引也比较耗费系统资源
如果通过list链表实现以上功能,可以在list链表中只保留最新的10个数据,每进来一个新数据就删除一个旧数据。每次就可以从链表中直接获得需要的数据。极大节省各方面资源消耗
设置一个list链表key,内部有五个元素:
添加一个(链表的头插入方法),删除一个
通过范围查找链表的内部信息:lrange 链表名称 开始位置 结束位置
返回元素长度:llen 链表名称
保留指定区域:ltrim 链表名称 起始位置 结束位置
Set集合类型
redis的set是string类型的无序集合
set元素最大可以包含(2的32次方-1)个元素。
关于set集合类型除了基本的添加、删除操作,其他有用的操作还包含集合的取并集(union),交集(intersection),差集(difference)。通过这些操作可以很容易的实现sns中的好友推荐功能。
创建tomFri的set集合类型数据,内部有五个元素:
创建linken的set集合类型数据,内部五个元素
交集、并集、差集:
获得key对应的set集合中的所有元素:
判断是否为key对应的set集合的元素
Sort Set排序集合类型
该Sort Set是两种类型(list和set)的集中体现,称为排序集合类型。
和set一样sort set也是string类型元素的集合,
不同的是每个元素都会关联一个权。
通过权/值可以有序的获取集合中的元素
该Sort set类型适合场合:
获得最热门(回复量)前5个帖子信息:
select * from message order by backnum desc limit 5;
(以上需求可以通过简单sql语句实现,但是sql语句比较耗费mysql数据库资源)
案例:利用sort set实现获取最热门的前5帖子信息
排序集合中的每个元素都是值、权的组合
(之前的set集合类型每个元素就只是一个值)
我们制作一个sort set排序集合,里边只保留5个元素信息,该5个元素是回复量最高的,每个帖子被回复的时候,都有机会进入该集合里边,但是只有回复量最高的前5个帖子会存在该集合,回复量低的就被删除。
创建sort set排序集合的hotmessage的key,内部有5个元素:
按照全职由高到低的顺序获得具体元素值的信息:
删除全职最小的元素:zremrangebyrank 筛选集合的时候,权由小到大排序
Hash
关于重复元素:
set类型:没有
list类型:有
Sort set :没有
持久化功能
redis(nosql产品)为了内部数据的安全考虑,会把本身的数据以文件形式保存到硬盘中一份,在服务器重启之后会自动把硬盘的数据恢复到内存(redis)的里边。
数据保存到硬盘的过程就称为“持久化”效果。
Snap shotting快照持久化
该持久化默认开启,一次性把redis中全部的数据保存一份存储在硬盘中,如果数据非常多(10-20G)就不适合频繁该持久化操作。
快照持久化在本地硬盘保留的数据备份文件:
快照持久化频率:
900秒内如果超过一个key被修改,则发起快照保存
300秒内如果超过十个key被修改,则发起快照保存
60秒内如果超过一万个key被修改,则发起快照保存
以上三个save的意思:
数据修改的频率非常高,备份的频率也高。数据修改的频率低,备份的频率也低。
快照持久化的名字和保存位置:
快照持久化和精细持久化 可以尽量最大程度保证数据的安全:
手动发起快照持久化
手动发起快照持久化:./redis-cli [-hlocalhost -p6379] bgsave (可以通过写一个脚本实现固定事件的持久化)
Append only file(AOF持久化)
本质:把用户执行的每个“写”指令(添加、修改、删除)都备份到文件中,还原数据的时候就是执行具体写指令而已。
开启AOF持久化(会清空redis内部的数据):(同时可以修改备份文件的名字,默认是appendonly.aof)
配置文件被修改,需要删除旧的进程,再根据新的配置文件启动新进程:
新进程启动好后会看到对应的aof持久化备份文件appendonly.aof:
aof追加持久化的备份频率:
为aof备份文件做优化处理
对appendonly.aof文件内容做优化压缩处理./redis.cli bgrewriteaof
(例如多个incr指令编程一个set指令)
redis的持久化相关指令
- bgsave 异步保存数据到磁盘(快照保存)
- lastsave 返回上次成功保存到磁盘的unix时间戳
- shutdown 同步保存到服务器并关闭redis服务器
- bgrewriteaof 当日志文件过长时优化AOF日志文件存储
- ./redis-cli bgrewriteaof
- ./redis-cli bgsave
- ./redis-cli -h 127.0.0.1 -p 6379 bgsave #手动发起快照
redis的主从模式
为了降低每个redis服务器的负载,可以多设置几个,并做主从模式
一个服务器负载“写”(添加、修改、删除)数据,其他服务器负载“读”数据
主服务器数据会“自动”同步给从服务器
配置redis.conf,修改服务器为从服务器:
重启服务,杀死旧的进程,重新启动服务 ./redis-server redis.conf
从服务器默认禁止写入操作:
php与redis结合
安装php的redis的扩展
把php扩展和依赖软件上传到linux系统上:
在redis扩展解压软件目录执行指令(该指令是/usr/local/php/bin目录下的一个可执行文件):
作用:可以把redis扩展反过来安装进php里边,可以给redis扩展做一些php相关的配置
提示有软件依赖问题:
解压依赖软件,安装:
autoconf依赖软件安装成功:
phpize指令执行成功:
为redis扩展软件做configure配置:
configure执行成功:
Make && make install执行成功:
redis相对php的扩展文件生成:
给php配置文件(/usr/local/php/lib/php.ini)增加redis的扩展;
Php.ini修改后重启apache:
redis已经成为php的扩展:
通过php操作redis
在php里边,redis就是一个功能类Redis,Redis类里边有许多成员方法(名字基本与redis指令的名字一致,参数也一致)
php中redis的可操作方法有哪些
利用反射感知Redis类的全部操作方法。