redis 队列操作的例子(php)


Posted in PHP onApril 12, 2012

入队操作

<?php 
$redis = new Redis(); 
$redis->connect('127.0.0.1',6379); 
while(True){ 
try{ 
$value = 'value_'.date('Y-m-d H:i:s'); 
$redis->LPUSH('key1',$value); 
sleep(rand()%3); 
echo $value."\n"; 
}catch(Exception $e){ 
echo $e->getMessage()."\n"; 
} 
} 
?>

出队操作
<?php 
$redis = new Redis(); 
$redis->pconnect('127.0.0.1',6379); 
while(True){ 
try{ 
echo $redis->LPOP('key1')."\n"; 
}catch(Exception $e){ 
echo $e->getMessage()."\n"; 
} 
sleep(rand()%3); 
}?>

如何使用Redis 做队列操作
Reids是一个比较高级的开源key-value存储系统,采用ANSI C实现。其与memcached类似,但是支持持久化数据存储,同时value支持多种类型:字符串 (同memcached中的value),列表 ,集合 (Set),有序集合 (OrderSet)和Hash 。所有的值类型均支持原子操作,如列表中追加弹出元素,集合中插入移除元素等。Rdids的数据大部分位于内存中,其读写效率非常高,其提供AOF(追加 式操作记录文件)和DUMP(定期数据备份)两种持久化方式。Redis支持自定义的VM(虚拟内存)机制,当数据容量超过内存时,可以将部分Value 存储到文件中。同时Redis支持Master-Slave机制,可以进行数据复制。
可以把Redis的list结构当队列来用.
从上面Redis的场景和作用来说,对于我们现在的开发活动,究竟能把Redis引入在那些场景,而不是把这么好的东东演变成“为了使用Redis,而Redis”的惨烈局面呢?当然,具体问题具体分析,这个真的很重要哈。
缓存?分布式缓存?
队列?分布式队列?
某些系统应用(例如,电信、银行和大型互联网应用等)都会使用到,当然,现在大行其道的memcache就是很好的证明;但从某一方面来说,memcache是否能把两张囊括其中,而且能做到更好(没有实际的应用过,所以只是抛出)。但从Redis身上,我就能感觉到,Redis,就能把队列和缓存两张都囊括其中,而且都不会产生并发环境下的困扰,因为Redis中的操作都是原子操作来着。
至于评论两者的孰好孰坏就免了,存在就是理由,选择适合的就是最好的。
下面开始玩玩Redis中的队列(分布式)设计YY吧,请大虾们多多指点。
状况场景:
现在的项目,都是部署在多个服务器,或者多个IP上,而且前台经由F5分发,所以用户的请求究竟落在那一台的服务器上,是无法确定的。对于项目中,有一秒杀设计,刚开始没有考虑到这种部署,同时也是使用最容易处理的方式,直接给数据库表锁行记录(Oracle上的)。可以说,对于不同的应用部署,而只有一台数据库服务器来说,很“轻松”的就解决了这个并发的问题。所以现在考虑一下,是不是挪到应用上,避免数据库服务器也掺杂到业务上。
比如,现在有2台应用服务器,1台数据库服务器。想法是,把Redis部署在数据库服务器上,两台服务器在操作并发缓存或者队列时,先从Redis服务器上,取得在两台应用服务器的代理对象,再做入列出列的操作。
看代码实现(PHP)
入队列操作文件 list_push.php
<?php 
$redis = getRedisInstance();//从Redis服务器拿到redis实例 
$redis->connect('Redis服务器IP', 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 = getRedisInstance();//从Redis服务器拿到redis实例 
$redis->pconnect('Redis服务器IP', 6379); 
while(true) { 
try { 
var_export( $redis->blPop('list1', 10) ); 
} catch(Exception $e) { 
//echo $e; 
} 
}

实现方法(Python)
1.入队列(write.py)
#!/usr/bin/env python 
import time 
from redis import Redis 
redis = Redis(host='127.0.0.1', port=6379) 
while True: 
now = time.strftime("%Y/%m/%d %H:%M:%S") 
redis.lpush('test_queue', now) 
time.sleep(1)

2.出队列(read.py)
#!/usr/bin/env python 
import sys 
from redis import Redis 
redis = Redis(host='127.0.0.1', port=6379) 
while True: 
res = redis.rpop('test_queue') 
if res == None: 
pass 
else: 
print str(res)

在操作时,注意,要操作的是同一个list对象。
呵呵,现在的主要思路就差不多就是如此,不过真实场景中,会有出入。
PHP 相关文章推荐
用定制的PHP应用程序来获取Web服务器的状态信息
Oct 09 PHP
PHP中extract()函数的妙用分析
Jul 11 PHP
php数组一对一替换实现代码
Aug 31 PHP
mysql 查询指定日期时间内sql语句实现原理与代码
Dec 16 PHP
深入PHP autoload机制的详解
Jun 09 PHP
php解析xml提示Invalid byte 1 of 1-byte UTF-8 sequence错误的处理方法
Nov 14 PHP
PHP调用C#开发的dll类库方法
Jul 28 PHP
php_imagick实现图片剪切、旋转、锐化、减色或增加特效的方法
Dec 15 PHP
php实现遍历目录并删除指定文件中指定内容
Jan 21 PHP
DEDECMS首页调用图片集里的多张图片
Jun 05 PHP
CI框架中$this-&gt;load-&gt;library()用法分析
May 18 PHP
jQuery+php简单实现全选删除的方法
Nov 28 PHP
PHP得到某段时间区间的时间戳 php定时任务
Apr 12 #PHP
比较好用的PHP防注入漏洞过滤函数代码
Apr 11 #PHP
PHP 杂谈《重构-改善既有代码的设计》之四 简化条件表达式
Apr 09 #PHP
PHP 杂谈《重构-改善既有代码的设计》之三 重新组织数据
Apr 09 #PHP
PHP 杂谈《重构-改善既有代码的设计》之一 重新组织你的函数
Apr 09 #PHP
PHP乱码问题,UTF-8乱码常见问题小结
Apr 09 #PHP
PHP中return 和 exit 、break和contiue 区别与用法
Apr 09 #PHP
You might like
php无限遍历文件夹示例分享
2014/03/04 PHP
jquery中dom操作和事件的实例学习 下拉框应用
2011/12/01 Javascript
用js实现table单元格高宽调整,兼容合并单元格(兼容IE6、7、8、FF)实例
2013/06/25 Javascript
jquery如何获取复选框的值
2013/12/12 Javascript
详谈jQuery中的this和$(this)
2014/11/13 Javascript
JavaScript中的toLocaleDateString()方法使用简介
2015/06/12 Javascript
基于Bootstrap的UI扩展 StyleBootstrap
2016/06/17 Javascript
使用 jQuery.ajax 上传带文件的表单遇到的问题
2016/10/31 Javascript
jQuery自定义图片上传插件实例代码
2017/04/04 jQuery
原生JS 购物车及购物页面的cookie使用方法
2017/08/21 Javascript
React Native预设占位placeholder的使用
2017/09/28 Javascript
详解Vue中数组和对象更改后视图不刷新的问题
2018/09/21 Javascript
Vue组件间通信 Vuex的用法解析
2019/08/05 Javascript
Element 默认勾选表格 toggleRowSelection的实现
2019/09/04 Javascript
layui table数据修改的回显方法
2019/09/04 Javascript
微信小程序 多行文本显示...+显示更多按钮和收起更多按钮功能
2019/09/26 Javascript
JS造成内存泄漏的几种情况实例分析
2020/03/02 Javascript
JavaScript JSON使用原理及注意事项
2020/07/30 Javascript
[52:31]VP vs Serenity 2018国际邀请赛小组赛BO2 第二场 8.16
2018/08/17 DOTA
[01:30]我们共输赢 完美世界城市挑战赛开启全新赛季
2019/04/19 DOTA
python判断windows系统是32位还是64位的方法
2015/05/11 Python
利用Python实现颜色色值转换的小工具
2016/10/27 Python
在PyCharm中三步完成PyPy解释器的配置的方法
2018/10/29 Python
详解Python Qt的窗体开发的基本操作
2019/07/14 Python
docker-py 用Python调用Docker接口的方法
2019/08/30 Python
python 三种方法实现对Excel表格的读写
2020/11/19 Python
Html5内唤醒百度、高德APP的实现示例
2019/05/20 HTML / CSS
戴森西班牙官网:Dyson西班牙
2020/02/04 全球购物
在职人员函授期间自我评价分享
2013/11/08 职场文书
应届大学生求职信
2013/12/01 职场文书
服务员自我评价
2014/01/25 职场文书
社区反邪教工作方案
2014/06/16 职场文书
领导干部群众路线教育实践活动剖析材料
2014/10/10 职场文书
《老人与海鸥》教学反思
2016/02/16 职场文书
Anaconda安装pytorch及配置PyCharm 2021环境
2021/06/04 Python
windows系统搭建WEB服务器详细教程
2022/08/05 Servers