Linux:安装Redis和PHP操作Redis

16 篇文章 0 订阅
7 篇文章 0 订阅

一.Redis

1. 什么是Redis

RedisRemote 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即可:

 

 

make执行成功:

 

 

进入src目录:

 

 

 

创建redis运行目录,并拷贝需要的两个文件:

 

 

进入redis直接解压目录并拷贝 配置文件到运行目录:

 

 

进入redis运行目录,内部有需要的三个文件(刚才拷贝的)

 

 


默认为前台启动redis服务:

前台启动服务:始终有一个终端脚本被挂起执行(终端脚本被关闭后立即停止服务,不推荐)

后台启动服务:服务以隐藏的方式执行,没有终端脚本,可以通过ps -A | grep 名称 查看是否有该服务。

 

Ctrl+c 关闭前台服务

 

修改配置文件(/usr/local/redis/redis.conf),设置后台启动redis服务:

 

 

带着redis.conf配置文件参数,后台启动服务:

 

4. 简单使用

 

 

二. 具体使用

redis中数据的模型为:key/value

类似在php中定义变量:名称 ;

 

1. key的操作

redis里边,除了\n空格 不能作为名字的组成内容外,其他内容都可以作为key的名字部分。名字长度不做要求。

 

rediskey的组成内容较随意(没有\n空格即可)

 

 

redis中一共有16个数据库(redis.conf)

 

 


通过模糊方式查看当前数据库全部的key名称信息(* 代表任意名字信息)

 

查看当前数据库名称n开始key的名字:

 

 

 

 

2. String类型操作

stringredis最基本的类型

redisstring可以包含任何数据。包括jpg图片或者序列化的对象。

单个value值最大上限是1G字节。

 

 

incr:  increment  增长

      该指令可以对key进行累加1操作,默认是累加1操作,类似i++操作

      该指令可以针对 key已有key 进行操作

key创建key并累加1,其值为1

已有keykey的信息值类型要求必须为整型的

已有key的信息必须为“整型”的才允许incr操作:

 

decr  的操作模式与incr一致,不过其实减1操作

 

 

substr对内容进行截取,包括startend标记位置内容

 

 

 

key追加内容(如果被操作内容是空格分隔的多个信息,避免混淆,要使用引号)

 

3. 
数据类型List链表

list类型其实就是一个双向链表。通过push,pop操作从链表的头部或者尾部添加删除元素。

这使得list既可以用作栈,也可以用作队列。

上进上出 :

上进下出 队列

 

 

 

list链表类型应用场合:

获得最新的10个登录用户信息: select * from user order by logintime desc limit 10;

以上sql语句可以实现用户需求,但是数据多的时候,全部数据都要受到影响查询,对数据库的负载比较高。必要情况还需要给关键字段(idlogintime)设置索引索引也比较耗费系统资源

如果通过list链表实现以上功能,可以在list链表中保留最新的10个数据,每进来一个新数据就删除一个旧数据。每次就可以从链表中直接获得需要的数据。极大节省各方面资源消耗

 

 

 

通过list链表保存登录系统的最新5个用户信息:

jim   xiaoli  jack   xiaoming   linken   mary  tom

 

 


newlogin链表添加5个元素:

 

newlogin链表只保留5个元素,每进来一个新的旧删除一个旧的:

 

链表只保留5个有顺序的元素存在:

 

 

按照指定区间对元素进行截取:

 

4. set集合类型

 

redissetstring类型的无序集合。

set元素最大可以包含(232次方-1)个元素。

关于set集合类型除了基本的添加删除操作,其他有用的操作还包含集合的取并集(union)交集(intersection)差集(difference)。通过这些操作可以很容易的实现sns中的好友推荐功能

 

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

 

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

 

tom朋友圈(与某某是好友)mary  jack  xiaoming  wang5  wang6

linken朋友圈(与某某是好友)yuehan  daxiong  luce  wang5  wang6

 

 


tom的好友通过集合给设置好:

 

 

linken的好友集合:

 

 

集合计算:

求交集:

 

 


求并集:

 

求差集(前者对后者求差集,结果只有前者的信息没有后者)

例如:tomlinken求差集,结果只有tom的信息结果:

 

查看集合内部的全部元素信息:

 

marytom集合里边移动到linken的集合中去:

 

总结:

1. redis的安装和使用

key的使用

key具体操作:

exists    keys  *     rename  

del      dbsize       select 0-15

flushdb  flushall

数据类型:

String:

get  set  mget  mset   incr  decr   append   substr

List:

lpush     rpop      lrange    

rpush     lpop       ltrim

Set集合(集合运算):

sadd        sinter    sunion       sdiff

smembers   scard    sismember

 

5. Sort Set排序集合类型

Sort Set是两种类型(listset)的集中体现,称为排序集合类型。

 

set一样sorted 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个帖子会存在于在集合,回复量低的就被删除。

 

制作一个排序集合类型的key,内部5个元素:

 

按照权值由高到低的顺序获得对应元素:

 

 

每进一个新元素,就删除一个权值最低的元素(保证集合中只有5个元素)

 

 

 

给指定值为17的元素的权累加200信息:

 

 

三. 
持久化功能

redis(nosql产品)为了内部数据的安全考虑,会把本身的数据文件形式保存到硬盘中一份,在服务器重启之后会自动把硬盘的数据恢复到内存(redis)的里边。

数据保存到硬盘的过程就称为“持久化”效果。

1. snap shotting快照持久化

该持久化默认开启,一次性redis全部的数据保存一份存储在硬盘中,如果数据非常多(10-20G)不适合频繁进行该持久化操作。

 

快照持久化备份文件:

 

 

备份文件dump.rdb内部的数据:

 

 

该方式备份机制(频率)

 

save 900 1  #900 秒内如果超过 个 key 被修改,则发起快照保存

save 300 10     #300秒超过10key被修改,发起快照

save 60 10000   #60秒超过10000key被修改,发起快照

以上三个备份频率需要同时存在:

数据变化非常快的时候,就快点做备份(保证数据安全)

数据变化慢的时候,就慢点做备份(节省服务器资源)

 


快照持久化备份文件的名称和目录设置:

 

 

1.1 手动发起快照持久化

 


2. append only file AOF持久化)

本质:把用户执行的每个“写”指令(添加、修改、删除)都备份到文件中,还原数据的时候就是执行具体指令而已。

 

 

AOF持久化默认没有开启,现在就开启使用:

(可以自定义该持久化备份文件的名称)

 

 

配置文件redis.conf被修改后,为了有效果,需要重启redis服务:

(杀掉旧进程,根据新配置文件启动新进程)

 


AOF持久化开启后会自动生成一个备份文件:

 

 

注意:AOF持久化开启后会自动清除目前redis中的全部数据

 

AOF备份的频率:

 

数据最安全      服务器性能低  

数据较安全      服务器性能中等

数据不安全      服务器性能高(优良)

# appendfsync always   //每次收到写命令就立即强制写入磁盘,最慢的,但是保证完全的持久化,不推荐使用

appendfsync everysec   //每秒钟强制写入磁盘一次,在性能和持久化方面做了很好的折中,推荐

# appendfsync no   //完全依赖 os,性能最好,持久化没保证

 

2.1 aof备份文件做优化压缩处理

例如:可以把多个incr指令换为一个set指令

 

 


持久化相关指令:

 

 

四. redis的主从模式

mysql为了降低每个服务器负载,可以设置读写分类(有写服务器、有读取服务器)

 

为了降低每个redis服务器的负载,可以多设置几个,并做主从模式

一个服务器负载“写”(添加、修改、删除)数据,其他服务器负载“读”数据

主服务器数据会“自动”同步给从服务器

 

 


redis.conf里边设置并成为192.168.40.148服务器的从服务器:

 

redis.conf配置文件修改后杀掉旧进程,启动新进程:

 

此时就可以看到主服务器自动同步给从服务器的数据

 

从服务器默认只读:

 


. phpredis结合

1. 安装phpredis扩展

上传redis扩展软件和依赖软件:

 

解压缩phpredis软件:

 

 

顺序:redis与其他软件(xmlgdjpeg等等)都是php的扩展(php依赖扩展软件)

正确的安装顺序是安装依赖软件、之后在安装php软件

此时redisphp的安装顺序有前后颠倒的意味,但是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就是一个功能类RedisRedis类里边有许多成员方法(名字基本与redis指令的名字一致,参数也一致)

 

 

3.phpredis的可操作方法有哪些

获得Redis类内部一共的方法(利用反射Reflection实现)

php大部分操作都是正向的:类、实例化对象、对象调用成员

其实类可以反向操作:类、反过来感知类的成员、反方向感知方法是否是公开的/私有的/受保护的/最终的

 

 

总结:

1. 数据类型 Sort Set

获得最热门前5个帖子信息

(优秀学员奥赛班分班使用)

2. 持久化

1) 快照持久化(默认开启)

2) AOF追加持久化(精细),本质备份用户的“写指令”

3. 主从模式

4. php实现redis操作

1) php安装redis扩展

2) phpredis操作

 

作业:

1. 利用list链表数据类型实现网站首页面显示前10个登录用户信息。

 

问题:

php代码都在是wamp环境下开发的,该环境php不支持redis使用

解决:

linux系统里边创建两个php文件(user_add.php 和 user_look.php)

user_add.php负责给redis写数据

user_look.php负责redis读数据

 

windows下触发linux中的php执行

file_get_contents(http://192.168.40.148/user_add.php?user_id=105);

file_get_contents(http://192.168.40.148/user_look.php);

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值