$res['code'] = 200;
//这里进行计算生成数据,但生成的数据不是用户急需的,
//没有想到其它方式可以触发这个计算程序,所以只能设计最后一个用户提交后计算,
//由于数据量大,用户等待返回的时间由计算时间决定,可不可以先返回给用户再计算,怎么操作?
$this->ajaxReturn($res);//只需返回 code=200 给用户
$res['code'] = 200;
//这里进行计算生成数据,但生成的数据不是用户急需的,
//没有想到其它方式可以触发这个计算程序,所以只能设计最后一个用户提交后计算,
//由于数据量大,用户等待返回的时间由计算时间决定,可不可以先返回给用户再计算,怎么操作?
$this->ajaxReturn($res);//只需返回 code=200 给用户
把计算当做一个任务,放到队列中,有一个脚本在跑,从队列里获取任务,然后在后台处理.
这也就是需要所谓的消息队列,可以看下 rabbitmq,gearman 等消息队列.
我这里写了一篇 php rabbitmq 的使用方法,可以看下.
https://segmentfault.com/a/1190000004924668
如果计算的数据不需要返回给用户,可以先行返回继续执行代码的。php-fpm可以使用这个fastcgi_finish_request,echo 返回值,fastcgi_finish_request(),后面继续执行。。。。或者就是使用队列了
2 回答3.1k 阅读✓ 已解决
1 回答1.4k 阅读✓ 已解决
1 回答1k 阅读✓ 已解决
1 回答1.3k 阅读✓ 已解决
3 回答1.2k 阅读
2 回答1.2k 阅读
1 回答1.2k 阅读
把要做的计算业务先推入mq,就是任务队列,这个可以用redis去做。
Linux跑脚本,一直消费队列。