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

使用Redis实现消息队列
本文介绍如何利用Redis实现简单的消息队列系统,包括生产者和消费者的PHP代码示例,并探讨了在高并发场景下使用Redis队列进行延迟发布的应用场景。

原文链接: http://blog.youkuaiyun.com/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();  

内容概要:本文系统介绍了算术优化算法(AOA)的基本原理、核心思想及Python实现方法,并通过图像分割的实际案例展示了其应用价值。AOA是一种基于种群的元启发式算法,其核心思想来源于四则运算,利用乘除运算进行全局勘探,加减运算进行局部开发,通过数学优化器加速函数(MOA)和数学优化概率(MOP)动态控制搜索过程,在全局探索与局部开发之间实现平衡。文章详细解析了算法的初始化、勘探与开发阶段的更新策略,并提供了完整的Python代码实现,结合Rastrigin函数进行测试验证。进一步地,以Flask框架搭建前后端分离系统,将AOA应用于图像分割任务,展示了其在实际工程中的可行性与高效性。最后,通过收敛速度、寻优精度等指标评估算法性能,并提出自适应参数调整、模型优化和并行计算等改进策略。; 适合人群:具备一定Python编程基础和优化算法基础知识的高校学生、科研人员及工程技术人员,尤其适合从事人工智能、图像处理、智能优化等领域的从业者;; 使用场景及目标:①理解元启发式算法的设计思想与实现机制;②掌握AOA在函数优化、图像分割等实际问题中的建模与求解方法;③学习如何将优化算法集成到Web系统中实现工程化应用;④为算法性能评估与改进提供实践参考; 阅读建议:建议读者结合代码逐行调试,深入理解算法流程中MOA与MOP的作用机制,尝试在不同测试函数上运行算法以观察性能差异,并可进一步扩展图像分割模块,引入更复杂的预处理或后处理技术以提升分割效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值