使用Redis 做队列服务器
Redis介绍
Reids是一个比较高级的开源key-value存储系统,采用ANSI C实现。其与memcached类似,但是支持持久化数据存储,同时value支持多种类型:字符串 (同memcached中的value),列表 ,集合 (Set),有序集合 (OrderSet)和Hash 。所有的值类型均支持原子操作,如列表中追加弹出元素,集合中插入移除元素等。Rdids的数据大部分位于内存中,其读写效率非常高,其提供AOF(追加 式操作记录文件)和DUMP(定期数据备份)两种持久化方式。Redis支持自定义的VM(虚拟内存)机制,当数据容量超过内存时,可以将部分Value 存储到文件中。同时Redis支持Master-Slave机制,可以进行数据复制。
可以把Redis的list结构当队列来用.
安装过程
1.安装定制源
安装#rpm -Uvh http://os.69hn.com/custom.rpm
2.安装redis
# yum -y install redis
3. 启动:
#service redis start
接着安装php的下redis的扩展包,
#yum -y install php-redis
入队列操作文件 list_push.php
<?php
$redis = new Redis();
$redis->connect('127.0.0.1', 6379);
while (true) {
$redis->lPush('list1', 'A_'.date('Y-m-d H:i:s'));
sleep(rand()%3);
}
?>
执行# php list_push.php &
出队列操作 list_pop.php文件
<?php
$redis = new Redis();
$redis->pconnect('127.0.0.1', 6379);
while(true) {
try {
var_export( $redis->blPop('list1', 10) );
} catch(Exception $e) {
//echo $e;
}
}
就是这么简单的一段代码,就搞定了
2.安装redis
# yum -y install redis
3. 启动:
#service redis start
接着安装php的下redis的扩展包,
#yum -y install php-redis
入队列操作文件 list_push.php
<?php
$redis = new Redis();
$redis->connect('127.0.0.1', 6379);
while (true) {
$redis->lPush('list1', 'A_'.date('Y-m-d H:i:s'));
sleep(rand()%3);
}
?>
执行# php list_push.php &
出队列操作 list_pop.php文件
<?php
$redis = new Redis();
$redis->pconnect('127.0.0.1', 6379);
while(true) {
try {
var_export( $redis->blPop('list1', 10) );
} catch(Exception $e) {
//echo $e;
}
}
就是这么简单的一段代码,就搞定了
posted on 2012-03-08 14:08 cn三少<script></script> 阅读(415) 评论(0) 编辑 收藏 举报