php 用 redis做队列 运行过程是什么样的?
程序员文章站
2022-03-18 21:39:10
...
比如群发1000封邮件,或者同时有1000个用户一人一个发邮件的请求
先用1个或多个php脚本把 1000封邮件的信息存储到redis
然后用另一个php脚本 循环从redis中每次取20条出来 执行发送邮件的函数
那问题来了,那这个取数据脚本是不是一直要在后台跑呢? 而且就它一个线程,效率高吗?
我是不是理解错了?
排队我懂。
我不理解的是取出数据后,到底是交给谁执行任务(如发邮件),是交给一个线程,还是可以同时交给多个线程,这里边到底是怎么操作的,一个线程是不是会很慢
先用1个或多个php脚本把 1000封邮件的信息存储到redis
然后用另一个php脚本 循环从redis中每次取20条出来 执行发送邮件的函数
那问题来了,那这个取数据脚本是不是一直要在后台跑呢? 而且就它一个线程,效率高吗?
我是不是理解错了?
回复讨论(解决方案)
在哪里跑都行,按你业务的需要
只要你处理一条就删一条,多少的进(线)程同时跑都没关系
就是排队,先来先服务。后来的等着。
你多少个来都一样,按时间排队,如果并发,它系统都会按入队顺序排好的。
php运行一个脚本是一个线程吧?
比如1000个用户一人一个发邮件的请求,如果每个请求都开启一个取数据线程 执行发邮件函数,那队列就没有意义了,相当于直接运行发邮件函数了
怎么让如每20个用户就开启一个线程取数据呢?
就是排队,先来先服务。后来的等着。
你多少个来都一样,按时间排队,如果并发,它系统都会按入队顺序排好的。
排队我懂。
我不理解的是取出数据后,到底是交给谁执行任务(如发邮件),是交给一个线程,还是可以同时交给多个线程,这里边到底是怎么操作的,一个线程是不是会很慢
如果你出队时多线程的,就可以同时处理多个入队的数据了。
或者入队时定义多几个队列,出队时就可以并发执行了。
邮件发送的快慢由很多因素决定,你实际能操控的是你的网卡的吞吐量(当然还有带宽的制约)
只要没超出他的上限,开多少个线程都无所谓
CPU(核) 在任何时刻都只会为一个进(线)程服务,如果你的程序在运行时没有停顿(没有IO请求),那么多线程和单线程并没有区别
你实际需要的是如何调度队列,使之尽快的空下来
1、你需要有一个后台进程,不时的处理队列里的数据
2、你可以在每当用户发来请求时,除了完成请求的工作外,在启动若干个进(线)程来处理队列中的数据
上一篇: 详解CSS处理长短文本内容的几种小技巧(值得收藏)
下一篇: php变量作用域