Redis

1.什么是Redis
Redis是Remote Dictionary Server(远程数据服务)的缩写
由意大利人 antirez(Salvatore Sanfilippo) 开发的一款 内存高速缓存数据库
该软件使用C语言编写,它的数据模型为 key-value
它支持丰富的数据结构(类型),比如 String list hash set sorted set。
可持久化(随时把备份到硬盘中一份),保证了数据安全。
同一个select 查询语句,每天需要被执行查询100万次,为了减轻数据库的负载,就把查询好的数据给缓存起来(存储在内存中),每天的第一个用户执行从mysql中获得数据并存储到内存中,第二个 到 第100万个用户就直接从内存中获得数据。

使用缓存减轻数据库的负载。
在开发网站的时候如果有一些数据在短时间之内不会发生变化,而它们还要被频繁访问,为了提高用户的请求速度和降低网站的负载,就把这些数据放到一个读取速度更快的介质上(或者是通过较少的计算量就可以获得该数据) ,该行为就称作对该数据的缓存。

该介质可以是文件、数据库、内存,内存介质经常用于数据缓存。

缓存的两种形式:
页面缓存经常用在CMS(content manage system)内存管理系统里边(Smarty缓存)
数据缓存经常会用在页面的具体数据里边

新闻信息(数据不变化、有实时性)页面适合做页面缓存:
在这里插入图片描述
商品展示页面(数据有各种分类),为了降低数据库负载,他们比较适合做各个小部分的
数据缓存,数据更新也只是更新每个小块的数据缓存:
在这里插入图片描述
在这里插入图片描述
3.安装redis
把redis需要的软件上传到此目录:
在这里插入图片描述
把其他组用户的w写权限赋予给rdtar目录:
在这里插入图片描述
把需要安装的软件上传到服务器:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
进入解压目录直接make即可:(省去了configure和make install)
在这里插入图片描述
make执行成功:
在这里插入图片描述
进入src目录:
在这里插入图片描述
在这里插入图片描述
创建redis运行目录,并拷贝需要的两个文件:
在这里插入图片描述
进入redis直接解压目录并拷贝 配置文件到运行目录:
在这里插入图片描述
进入redis运行目录,内部有需要的三个文件(刚才拷贝的):
在这里插入图片描述
默认为前台启动redis服务:
前台启动服务:始终有一个终端脚本被挂起执行(终端脚本被关闭后立即停止服务,不推荐)
后台启动服务:服务以隐藏的方式执行,没有终端脚本,可以通过ps -A | grep 名称 查看是否有该服务。
在这里插入图片描述
上图 Port 端口号码 ,PID进程号码

Ctrl+c 关闭前台服务
修改配置文件(/usr/local/redis/redis.conf),设置后台启动redis服务:
在这里插入图片描述
带着redis.conf配置文件参数,后台启动服务:
在这里插入图片描述
4.简单使用
在这里插入图片描述
二.具体使用
redis中数据的模型为:key/value
类似在php中定义变量:名称 = 值;
1.key的操作
在redis里边,除了”\n”和空格 不能作为名字的组成内容外,其他内容都可以作为key的名字部分。名字长度不做要求。

redis中key的组成内容较随意(没有\n和空格即可):
在这里插入图片描述
redis中一共有16个数据库(vi redis.conf里面看):
在这里插入图片描述
通过模糊方式查看当前数据库全部的key名称信息(*星 代表任意名字信息):
在这里插入图片描述
查看当前数据库名称以n开始的key的名字:
在这里插入图片描述
在这里插入图片描述
2. String类型操作
string是redis最基本的类型
redis的string可以包含任何数据。包括jpg图片或者序列化的对象。
单个value值最大上限是1G字节。
在这里插入图片描述
incr: increment 增长
该指令可以对key进行累加1操作,默认是累加1操作,类似i++操作
该指令可以针对 新key或已有key 进行操作
新key:创建该key并累加1,其值为1
已有key:key的信息值类型要求必须为整型的
已有key的信息必须为“整型”的才允许incr操作:
在这里插入图片描述
decr 的操作模式与incr一致,不过其实减1操作

给key追加内容(如果被操作内容是空格分隔的多个信息,避免混淆,要使用引号):
在这里插入图片描述
substr: 对内容进行截取,包括start和end标记位置内容
在这里插入图片描述
3.数据类型List链表
list类型其实就是一个双向链表。通过push,pop操作从链表的头部或者尾部添加删除元素。
这使得list既可以用作栈,也可以用作队列。
上进上出 :栈
上进下出 :队列
在这里插入图片描述
该list链表类型应用场合:
获得最新的10个登录用户信息: select * from user order by logintime desc limit 10;
以上sql语句可以实现用户需求,但是数据多的时候,全部数据都要受到影响查询,对数据库的负载比较高。必要情况还需要给关键字段(id或logintime)设置索引,索引也比较耗费系统资源
如果通过list链表实现以上功能,可以在list链表中只保留最新的10个数据,每进来一个新数据就删除一个旧数据。每次就可以从链表中直接获得需要的数据。极大节省各方面资源消耗
在这里插入图片描述
该list链表类型应用场合:
获得最新的10个登录用户信息: select * from user order by logintime desc limit 10;
以上sql语句可以实现用户需求,但是数据多的时候,全部数据都要受到影响查询,对数据库的负载比较高。必要情况还需要给关键字段(id或logintime)设置索引,索引也比较耗费系统资源
如果通过list链表实现以上功能,可以在list链表中只保留最新的10个数据,每进来一个新数据就删除一个旧数据。每次就可以从链表中直接获得需要的数据。极大节省各方面资源消耗
在这里插入图片描述
在这里插入图片描述
通过list链表保存登录系统的最新5个用户信息:
jim xiaoli jack xiaoming linken mary tom
给newlogin链表添加5个元素:
在这里插入图片描述
newlogin链表只保留5个元素,每进来一个新的旧删除一个旧的:
在这里插入图片描述
链表只保留5个有顺序的元素存在:
在这里插入图片描述
按照指定区间对元素进行截取:
在这里插入图片描述
4.set集合类型
在这里插入图片描述
redis的set是string类型的无序集合。
set元素最大可以包含(2的32次方-1)个元素。
关于set集合类型除了基本的添加、删除操作,其他有用的操作还包含集合的取并集(union),交集(intersection),差集(difference)。通过这些操作可以很容易的实现sns中的好友推荐功能。

注意:每个集合中的各个元素不能重复。

该类型应用场合:qq好友推荐。

tom朋友圈(与某某是好友):mary jack xiaoming wang5 wang6
linken朋友圈(与某某是好友):yuehan daxiong luce wang5 wang6
在这里插入图片描述
把tom的好友通过集合给设置好:
在这里插入图片描述
linken的好友集合:
在这里插入图片描述
集合计算:
求交集:
在这里插入图片描述
求并集:
在这里插入图片描述
求差集(前者对后者求差集,结果只有前者的信息没有后者):
例如:tom对linken求差集,结果只有tom的信息结果:
在这里插入图片描述
查看集合内部的全部元素信息:
在这里插入图片描述
把mary从tom集合里边移动到linken的集合中去:
在这里插入图片描述
5. Sort Set排序集合类型
该Sort Set是两种类型(list和set)的集中体现,称为排序集合类型。

和set一样sorted set也是string类型元素的集合,
不同的是每个元素都会关联一个权。
通过权/值可以有序的获取集合中的元素
在这里插入图片描述
上图中 score是权,member是值
该Sort set类型适合场合:
获得最热门(回复量)前5个帖子信息:
select * from message order by backnum desc limit 5;
(以上需求可以通过简单sql语句实现,但是sql语句比较耗费mysql数据库资源)
案例:利用sort set实现获取最热门的前5帖子信息
在这里插入图片描述
排序集合中的每个元素都是值、权的组合
(之前的set集合类型每个元素就只是一个 值)
在这里插入图片描述
我们只做一个sort set排序集合,里边只保留5个元素信息,该5个元素是回复量最高的,
每个帖子被回复的时候,都有机会进入该集合里边,但是只有回复量最高的前5个帖子会存在于在集合,回复量低的就被删除。

制作一个排序集合类型的key,内部5个元素:
在这里插入图片描述
按照权值由高到低的顺序获得对应元素:
在这里插入图片描述
每进一个新元素,就删除一个权值最低的元素(保证集合中只有5个元素):
在这里插入图片描述
给指定值为17的元素的权累加200信息:
在这里插入图片描述
三.持久化功能
redis(nosql产品)为了内部数据的安全考虑,会把本身的数据以文件形式保存到硬盘中一份,在服务器重启之后会自动把硬盘的数据恢复到内存(redis)的里边。
数据保存到硬盘的过程就称为“持久化”效果。

1.snap shotting快照持久化
该持久化默认开启,一次性把redis中全部的数据保存一份存储在硬盘中,如果数据非常多(10-20G)就不适合频繁进行该持久化操作。
快照持久化备份文件:
在这里插入图片描述
备份文件dump.rdb内部的数据:(vi dump.rdb)
在这里插入图片描述
该方式备份机制(频率):(vi redis.conf)
在这里插入图片描述
save 900 1                 #900 秒内如果超过 1 个 key 被修改,则发起快照保存
save 300 10                 #300秒超过10个key被修改,发起快照
save 60 10000                 #60秒超过10000个key被修改,发起快照
以上三个备份频率需要同时存在:
数据变化非常快的时候,就快点做备份(保证数据安全)
数据变化慢的时候,就慢点做备份(节省服务器资源)
快照持久化备份文件的名称和目录设置:
在这里插入图片描述
1.1 手动发起快照持久化
在这里插入图片描述
上图是齐全的快照持久化,可以为别人设置快照持久化,下图是为自身设置快照持久化
在这里插入图片描述
2. append only file (AOF持久化)
本质:把用户执行的每个“写”指令(添加、修改、删除)都备份到文件中,还原数据的时候就是执行具体写指令而已。
在这里插入图片描述
该AOF持久化默认没有开启,现在就开启使用:(vi redis.conf)
(可以自定义该持久化备份文件的名称)
在这里插入图片描述
配置文件redis.conf被修改后,为了有效果,需要重启redis服务:
(杀掉旧进程,根据新配置文件启动新进程)
在这里插入图片描述
AOF持久化开启后会自动生成一个备份文件:
在这里插入图片描述
注意:AOF持久化开启后会自动清除目前redis中的全部数据
AOF备份的频率:(vi redis.conf)
在这里插入图片描述
数据最安全              服务器性能低
数据较安全              服务器性能中等
数据不安全              服务器性能高(优良)
# appendfsync always //每次收到写命令就立即强制写入磁盘,最慢的,但是保证完全的持久化,不推荐使用
appendfsync everysec //每秒钟强制写入磁盘一次,在性能和持久化方面做了很好的折中,推荐
# appendfsync no //完全依赖 os,性能最好,持久化没保证 (看服务器是否繁忙,不忙就备份)

2.1 为aof备份文件做优化压缩处理
例如:可以把多个incr指令换为一个set指令(原先文件中执行了10次 incr num appendonly.aof文件大小变为349,执行完bgrewriteaof指令后文件大小变为149),也可以在这个指令中像手动发起快照持久化一样,添加-h -p等参数对别人的文件进行优化压缩
在这里插入图片描述
持久化相关指令:
在这里插入图片描述
四.redis的主从模式
mysql为了降低每个服务器负载,可以设置读写分类(有写服务器、有读取服务器)

为了降低每个redis服务器的负载,可以多设置几个,并做主从模式
一个服务器负载“写”(添加、修改、删除)数据,其他服务器负载“读”数据
主服务器数据会“自动”同步给从服务器
在这里插入图片描述
在redis.conf里边设置并成为192.168.40.148服务器的从服务器:
在这里插入图片描述
在这里插入图片描述
redis.conf配置文件修改后杀掉旧进程,启动新进程:
在这里插入图片描述
此时就可以看到主服务器自动同步给从服务器的数据
从服务器默认只读:
在这里插入图片描述
五. php与redis结合
1.安装php的redis扩展
上传redis扩展软件和依赖软件:
在这里插入图片描述
解压缩phpredis软件:
在这里插入图片描述
顺序:redis与其他软件(xml、gd、jpeg等等)都是php的扩展(php依赖扩展软件)
正确的安装顺序是先安装依赖软件、之后在安装php软件
此时redis与php的安装顺序有前后颠倒的意味,但是php允许redis反方向安装进来。
在phpredis的解压目录下运行/usr/local/php/bin/phpize,以便redis反方向安装进php里边:
在这里插入图片描述
执行phpize时提示有软件(autoconf)依赖没哟解决:
在这里插入图片描述
解压缩autoconf软件并安装:
在这里插入图片描述
autoconf依赖软件安装成功:
在这里插入图片描述
之后继续安装phpize:
在这里插入图片描述
可以看见,phpize安装成功(前提是autoconf依赖软件先安装好)

下边开始安装phpredis:
带着php-config参数值给phpredis做配置:
在这里插入图片描述
configure指令执行成功:
在这里插入图片描述
之后执行make && make install:
在这里插入图片描述
make && make install执行成功:
在这里插入图片描述
给php生成好的redis扩展文件:
在这里插入图片描述
在/usr/local/php/lib/php.ini配置文件中开启redis
在这里插入图片描述
之后重启apache:
在这里插入图片描述
通过浏览器访问php代码(phpinfo()):
在这里插入图片描述
2. 通过php操作redis
在php里边,redis就是一个功能类Redis,Redis类里边有许多成员方法(名字基本与redis指令的名字一致,参数也一致)
在这里插入图片描述
3.php中redis的可操作方法有哪些
获得Redis类内部一共的方法(利用反射Reflection实现):
php大部分操作都是正向的:类、实例化对象、对象调用成员
其实类可以反向操作:类、反过来感知类的成员、反方向感知方法是否是公开的/私有的/受保护的/最终的
在这里插入图片描述
在这里插入图片描述
redis本身没有windows版本,微软自己做的windows 下运行的redis
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值