延迟执行的,PHP最优解决方案

讲一下我们公司的业务吧。

我们公司是当前市面上最火热,最热辣的O2O。为了解决这一块问题,我们公司针对附近3.5KM的任务来进行派活。如果5分钟内,有附件的商家在接活这个活就是商家的。

如果附件的商家没有接活呢?这样用户体验不就很不好吗?所以说,我们有专门的派单的业务员。只要5分钟没人接的活,会有专门的跑腿 业务员来完成对应的工作。

所以,转换成技术语言就变成这样了:

用户派出一个活,通过IM(即时通信)系统发给商家。如果这个活被人接了,接单请求给到API。进入至交易状态。

如果这个活没有被人接,用户也没有给出反馈,怎么办?难道用线程去解决。如果中间服务器挂了呢?所以这种方案不可考。

我们想了几套不同的实线方案:

1,自己写时间服务器,缺点周期长,不好维护不同的一致性hash

2,用zookeeper来维护一致性,做好时间服务器,在指定时间后执行指定的脚本。

3,用redis 配合python或者lua来实现

4,有没有分布式的延迟队列系统

最后的讨论结果如下:

1,自己写服务器方案这个项目周期太短,方案1和方案2淘汰【淘汰】

2,用redis配合python或者是lua来实现的话效率太低【淘汰】

3,最后我们选择了aliyun的MQS,具有分布式和延迟通知的特点。当然你不想花钱的话,也可以自己架具有延迟、分布式功能的队列服务【选择】

最终实现的过程:

1,用户派单后,向队列中写入一个任务,将队列中延迟执行设为5分钟

2,商家接单了,反向通知API,将队列中的延迟任务删除

3,如果商家没有接单,到达5分钟客户端就自然结束显示

4,服务器端到达了5分钟,开始执行延时队列里面的任务,向自己公司的派单元派单,并且在客户界面中推送接单成功的消息。

完美解决。

PHP学院网友投稿,转载请注明来源。http://www.phpxy.com

原文发布于微信公众号 - php(phpdaily)

原文发表时间:2016-06-02

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏鹅厂网事

腾讯网络应对闰秒危机之最佳实践

"鹅厂网事"由深圳市腾讯计算机系统有限公司技术工程事业群网络平台部运营,我们希望与业界各位志同道合的伙伴交流切磋最新的网络、服务器行业动态信息,同时分享腾讯在网...

1925
来自专栏程序之美

java微服务首篇

654
来自专栏云计算D1net

云端加密存在的困境、隐患和问题

理论上讲,基于云的解决方案至少应当向客户提供与传统IT模式相同的安全水平。在理想情况下,云服务供应商应当提供更高级的安全水平,迁移到云的根本原因之一就是从客户方...

3409
来自专栏看看搬搬

物联网的消息传递

为一个物联网用例部署消息代理模块,对于broker接口的可延展性而言会带来新的挑战。我们现在谈论的物联网涉及到数千个连接,消费者和目的,这让我们必须思考如何更仔...

2656
来自专栏林喜东的专栏

程序世界里的不信任原则

人与人之间最重要的是信任,但程序的世界里,可能信任越少越好;我越发觉得越是高性能高可用的系统里,不信任原则会体现得更加淋漓尽致。

1.7K5

物联网,数据库系统和数据分发,第二部分

在这个由两部分组成的系列文章的第一部分中,我介绍了物联网中需要收集数据的位置:公共云或私有云中的边缘设备,网关和服务器。我还讨论了这些系统的特点以及选择合适的数...

3034
来自专栏北京马哥教育

存储系统的那些事

存储系统从其与生俱来的使命来说,就难以摆脱复杂系统的魔咒。无论是从单机时代的文件系统,还是后来C/S或B/S结构下数据库这样的存储中间件兴起,还是如今炙...

2495
来自专栏Java架构沉思录

微服务等于Spring Cloud?一文告诉你微服务到底是什么。

首先微服务并没有一个官方的定义,想要直接描述微服务比较困难,我们可以通过对比传统WEB应用,来理解什么是微服务。

562
来自专栏SDNLAB

漫谈虚拟路由方案

前言——关于虚拟路由 SDN,抑或是OpenFlow,能否为路由市场开辟一个新的时代?以OpenvSwitch为代表的开源软件交换机,已经推动SDN界发展了一段...

3325
来自专栏后台开发+音视频+ffmpeg

视频云转拉灾备——腾讯云挂掉引发的思考

就在昨天,腾讯云部分功能挂了,经查实广州机房的光缆被挖断导致。当时也影响到了我们视频云转拉这边的业务。有个例子是,一个小客户有个流没有拉起,但是收到了已经拉起的...

2276

扫描关注云+社区