博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Web应用中的轻量级消息队列
阅读量:7287 次
发布时间:2019-06-30

本文共 1195 字,大约阅读时间需要 3 分钟。

Web应用中为什么会需要消息队列?主要原因是由于在高并发环境下,由于来不及同步处理,请求往往会发生堵塞,比如说,大量的insert,update之类的请求同时到达mysql,直接导致无数的行锁表锁,甚至最后请求会堆积过多,从而触发too many connections错误。通过使用消息队列,我们可以异步处理请求,从而缓解系统的压力。在Web2.0的时代,高并发的情况越来越常见,从而使消息队列有成为居家必备的趋势,相应的也涌现出了很多实现方案,像Twitter以前就使用实现消息队列服务,现在又转而使用来实现消息队列服务,此外还有很多其他的选择,比如说:等。

上述消息队列的软件中,大多为了实现AMQP,STOMP,XMPP之类的协议,变得极其重量级,但在很多Web应用中的实际情况是:我们只是想找到一个缓解高并发请求的解决方案,不需要杂七杂八的功能,一个轻量级的消息队列实现方式才是我们真正需要的。

第一感觉是能不能使用来实现消息队列?稍加考虑后就会发现它不合适,因为memcached仅仅支持键值方式的操作,没有排序之类的功能,所以如果要用它来实现消息队列,则必须自己通过某个键来保存数组形式的队列,不过这样的话,在操作队列的时候很容易丢失数据,比如说我们要添加一个消息,则需先取出现有队列,然后把消息保存到队列尾部,最后保存队列,单纯使用memcached的话,由于我们无法保证整个过程的原子性,所以当处理若干个并发请求时,各个请求间可能会互相覆盖,丢失数据就在所难免()。另外,memcached只是内存键值缓存而已,一旦宕机,数据就消失了。

的出现解决了上面的问题,它在memcached的基础上实现了消息队列,以php客户端为例:

消息从尾部入栈:memcache_set
消息从头部出栈:memcache_get

memcacheq依附于memcached之上,所以你可以通过现有的memcached工具来操作它,这无疑是它的一大优势,但它也有一个很大的缺点,那就是memcacheq本身的开发维护似乎并不活跃,如果遇到问题的话,你很可能需要自己动手解决。

目前看来,我更推荐下面这种解决方案,那就是,如果不了解,可以参考我以前的,表面上看,redis和memcached差不多,也是键值操作,但是redis本身实现了,相关操作也可以保证是原子的,所以可以很自然的通过list来实现消息队列:

消息从尾部进队列:RPUSH
消息从头部出队列:LPOP

redis本身虽然是一个新项目,但很有朝气,开发维护也很活跃,如果你的下一个Web应用里需要使用轻量级的消息队列,不妨使用它,顺便说一句,redis里还有set结构,可以用来实现一个高效能的tag系统。

此外,还有不少其他的选择可供尝试,比如说MySQL第三方的,通过扩展SQL语法来操作消息队列,也是一个不错的选择。

转载地址:http://wucjm.baihongyu.com/

你可能感兴趣的文章
好程序员解析Web前端中的IoC是什么
查看>>
ipsec ***——原理理解
查看>>
SecureCRT 自动测试脚本的使用方法
查看>>
C#编程--convert类型转换
查看>>
编译redis报错/deps/hiredis/libhiredis.a解决
查看>>
corosync(pacemaker)+drbd+mysql
查看>>
借助keepalived实现高可用haproxy集群
查看>>
我的友情链接
查看>>
Oracle同义词创建及其作用
查看>>
RHEL6通过安装光盘或ISO文件制作本地yum源的方法
查看>>
安装DELL-openmanage
查看>>
salt基础命令
查看>>
php字符串截取 中英文混排
查看>>
Mybatis逆向工程增强版-Maven插件
查看>>
my ideal
查看>>
7月16日
查看>>
linux下 查看tomcat日志命令及乱码处理
查看>>
java生成表格图片
查看>>
Thread类
查看>>
Zabbix 3.0 监控MySQL [六]
查看>>