[示例] -- redis作为消息队列实现代码

原文链接: http://blog.csdn.net/nuli888/article/details/52138292


示例一 

这里只是简单实现下Redis消息队列,主要了解下这个思路
要把消息队列最好,还需考虑可靠消费、可靠发布、持久化、路由匹配、队列监控、负载均衡。。。
大都用专业的消息队列系统如rabbitmq,我们公司用的就是这个


producer.PHP生产者者代码

  1. <?php  
  2. $redis = new Redis();  
  3. $redis->connect('192.168.1.198',7000);  
  4. while(true){   
  5.     try{   
  6.         $value = 'value_'.date('Y-m-d H:i:s');   
  7.         $redis->lpush('key1',$value);//生成消息  
  8.         sleep(rand()%3);   
  9.         echo $value."\n";   
  10.     }catch(Exception $e){   
  11.         echo $e->getMessage()."\n";   
  12.     }   
  13. }   
  14. ?>  

consumer.php消费者代码

  1. <?php  
  2. $redis = new Redis();  
  3. $redis->connect('192.168.1.198',7000);  
  4. while(true){   
  5.     try{   
  6.         $value=$redis->lpop('key1')."\n";   
  7.         file_put_contents('val.txt',$value,FILE_APPEND);//将获取到的消息存入val.txt  
  8.     }catch(Exception $e){   
  9.         echo $e->getMessage()."\n";   
  10.     }   
  11.     sleep(rand()%3);   
  12. }  
  13. ?>  


分别命令行执行生产者和消费者
[root@localhost redis]# php producer.php
value_2016-08-06 20:22:57
value_2016-08-06 20:22:58
value_2016-08-06 20:22:59
value_2016-08-06 20:23:01
value_2016-08-06 20:23:03
...


[root@localhost redis]# php consumer.php




示例二

发帖、发微博、点赞、评论等这些操作很频繁的动作如果并发量小,直接入库是最简单的
但是并发量一大,数据库肯定扛不住,这时可采取延迟发布:先将发布动作保存在队列里,后台进程循环获取再入库

模拟发布微博先进入Redis队列

weibo_redis.PHP

[php]  view plain  copy
  1. <?php  
  2. //此处需要安装phpredis扩展  
  3. $redis = new Redis();  
  4. $redis->connect('127.0.0.1', 6379);  
  5. $redis->auth("php001");  
  6. //连接redis  
  7. $web_infoarray(  
  8.     'uid' => $_REQUEST[uid], //发布者id  
  9.     'username' => $_REQUEST[username],//发布者用户名  
  10.     'content' =>$_REQUEST[content],//微博内容  
  11. );  
  12.   
  13.   
  14. //将数组转成json来存储  
  15. $list = json_encode($web_info);  
  16. //lpush向KEY对应的头部添加一个字符串元素  
  17. $redis->lpush('weibo_lists',$list);  
  18. $redis->close();  
  19. var_dump($list);  
  20. ?>  

模拟后台进程从redis队列获取微博

Pdodb.class.php
[php]  view plain  copy
  1. <?php  
  2. class Pdodb{  
  3.     public function post($uid='',$username='',$content=''){  
  4.         try{  
  5.             $dsn = "mysql:localhost;dbname=localhost;dbname=big";  
  6.             $db = new PDO($dsn,'big','123456');   
  7.             $db->exec("SET NAMES UTF8");  
  8.             $sql ="insert into ih_weibo(uid,username,content)values('$uid','$username','$content')";  
  9.             //echo $sql;  
  10.             $db->exec($sql);  
  11.         }catch(PDOException $e){  
  12.             echo $e->getMessage();  
  13.         }  
  14.     }  
  15. }  


weibo_mysql.php

[php]  view plain  copy
  1. <?php  
  2. require_once 'Pdodb.class.php';  
  3. set_time_limit(0); // 取消脚本运行时间的超时上限  
  4.   
  5.   
  6. $pdo = new Pdodb();  
  7. $redis = new Redis();  
  8. $redis->connect('127.0.0.1', 6379);  
  9.   
  10.   
  11. while (true) {  
  12.     //返回的列表的大小。如果列表不存在或为空,该命令返回0。如果该键不是列表,该命令返回false  
  13.     if($redis -> lsize('weibo_lists')){  
  14.         //从LIST头部删除并返回删除数据  
  15.         $info = $redis->rpop('weibo_lists');  
  16.         $info = json_decode($info);  
  17.         $pdo->post($info->uid,$info->username,$info->content);  
  18.     }  
  19.       
  20.     sleep(10);//延时10秒  
  21. }  
  22. $redis->close();  

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值