redis是一个开源的key-value存储系统。与Memcached类似,Redis将大部分数据存储在内存中,支持的数据类型包括:字符串、哈希表、链表、集合、有序集合以及基于这些数据类型的相关操作。Redis使用C语言开发,在大多数像Linux、BSD和Solaris等POSIX系统上无需任何外部依赖就可以使用。Redis支持的客户端语言也非常丰富,常用的计算机语言如C、C#、C++、Object-C、PHP、Python、 Java、Perl、Lua、Erlang等均有可用的客户端来访问Redis服务器。当前Redis的应用已经非常广泛,国内像新浪、淘宝,国外像 Flickr、Github等均在使用Redis的缓存服务。 Redis的安装非常方便,只需从http://redis.io/download获取源码,然后make && make install即可。默认情况下,Redis的服务器启动程序和客户端程序会安装到/usr/local/bin目录下。在启动Redis服务器时,我们需要为其指定一个配置文件,缺省情况下配置文件在Redis的源码目录下,文件名为redis.conf
在项目中使用消息队列一般是有如下几个原因:
-
把瞬间服务器的请求处理换成异步处理,缓解服务器的压力
-
实现数据顺序排列获取
redis实现消息队列步骤如下:
1).redis函数rpush,lpop
2).建议定时任务入队列
3)创建定时任务出队列
文件:demo.php插入数据到redis队列
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
<?php
$redis
=
new
Redis();
$redis
->connect(
'127.0.0.1'
,6379);
$password
=
'123456'
;
$redis
->auth(
$password
);
$arr
=
array
(
'h'
,
'e'
,
'l'
,
'l'
,
'o'
,
'w'
,
'o'
,
'r'
,
'l'
,
'd'
);
foreach
(
$arr
as
$k
=>
$v
){
$redis
->rpush(
"mylist"
,
$v
);
}
|
执行后结果如下
?>
文件:index.php定时扫描出队列
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
<?php
$redis
=
new
Redis();
$redis
->connect(
'127.0.0.1'
,6379);
$password
=
'123456'
;
$redis
->auth(
$password
);
//list类型出队操作
$value
=
$redis
->lpop(
'mylist'
);
if
(
$value
){
echo
"出队的值"
.
$value
;
}
else
{
echo
"出队完成"
;
}
?>
|
建立定时任务
*/1 * * * * root php /wwwroot/workplace/redis/index.php
*/3 * * * * root php /wwwroot/workplace/redis/demo.php
tail -f /var/log/cron 查看定时任务执行情况
Nov 7 00:30:01 dongzi CROND[6888]: (root) CMD (php /wwwroot/workplace/redis/demo.php)
Nov 7 00:30:01 dongzi CROND[6890]: (root) CMD (php /wwwroot/workplace/redis/index.php )
定时任务执行队列写入结果如下
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
127.0.0.1:6379> lrange mylist 0 -1
1)
"h"
2)
"e"
3)
"l"
4)
"l"
5)
"o"
6)
"w"
7)
"o"
8)
"r"
9)
"l"
10)
"d"
|
定时任务执行出队列后:
127.0.0.1:6379> lrange mylist 0 -1 1) "e" 2) "l" 3) "l" 4) "o" 5) "w" 6) "o" 7) "r" 8) "l" 9) "d"