redis

Redis

什么是redis

redis是Remote Dictionary Server(远程数据服务)的缩写

该软件使用C语言编写,它的数据模型为 key-value

它支持丰富的数据结构(类型),比如 String  list  hash   set  sorted set。

可持久化,保证了数据安全。

 

ongz

新闻信息(数据不变化、有实时性)页面适合做页面缓存。

商品展示页面(数据有各种分类),为了降低数据库负载,他们比较适合做各个小部分的

数据缓存,数据更新也只是更新每个小块的数据缓存。

redismemcache比较

  1. Redis不仅仅支持简单的k/v类型的数据,同时还提供list,set,zset,hash等数据结构的存储
  2. Redis支持master-slave(主-从)模式应用
  3. Redis支持数据的持久化,可以将内存中的数据保持在磁盘中,重启的时候可以再次加载进行使用
  4. 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

从服务器默认禁止写入操作:

 

phpredis结合

安装phpredis的扩展

把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指令的名字一致,参数也一致)

 

phpredis的可操作方法有哪些

利用反射感知Redis类的全部操作方法。

 

 

 

 

 

 

 

 

 

 

 

 

 

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值