欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

php 用 redis做队列 运行过程是什么样的?

程序员文章站 2022-03-18 21:39:10
...
比如群发1000封邮件,或者同时有1000个用户一人一个发邮件的请求

先用1个或多个php脚本把 1000封邮件的信息存储到redis

然后用另一个php脚本 循环从redis中每次取20条出来 执行发送邮件的函数

那问题来了,那这个取数据脚本是不是一直要在后台跑呢? 而且就它一个线程,效率高吗?

我是不是理解错了?



回复讨论(解决方案)

在哪里跑都行,按你业务的需要
只要你处理一条就删一条,多少的进(线)程同时跑都没关系

就是排队,先来先服务。后来的等着。

你多少个来都一样,按时间排队,如果并发,它系统都会按入队顺序排好的。

php运行一个脚本是一个线程吧?

比如1000个用户一人一个发邮件的请求,如果每个请求都开启一个取数据线程 执行发邮件函数,那队列就没有意义了,相当于直接运行发邮件函数了

怎么让如每20个用户就开启一个线程取数据呢?



就是排队,先来先服务。后来的等着。

你多少个来都一样,按时间排队,如果并发,它系统都会按入队顺序排好的。



排队我懂。
我不理解的是取出数据后,到底是交给谁执行任务(如发邮件),是交给一个线程,还是可以同时交给多个线程,这里边到底是怎么操作的,一个线程是不是会很慢

如果你出队时多线程的,就可以同时处理多个入队的数据了。

或者入队时定义多几个队列,出队时就可以并发执行了。

邮件发送的快慢由很多因素决定,你实际能操控的是你的网卡的吞吐量(当然还有带宽的制约)
只要没超出他的上限,开多少个线程都无所谓
CPU(核) 在任何时刻都只会为一个进(线)程服务,如果你的程序在运行时没有停顿(没有IO请求),那么多线程和单线程并没有区别

你实际需要的是如何调度队列,使之尽快的空下来
1、你需要有一个后台进程,不时的处理队列里的数据
2、你可以在每当用户发来请求时,除了完成请求的工作外,在启动若干个进(线)程来处理队列中的数据