首页 后端开发 php教程 如何在前台触发后台异步批量发送短信而不影响用户体验?

如何在前台触发后台异步批量发送短信而不影响用户体验?

Mar 31, 2025 pm 11:45 PM
redis red talk

本文介绍如何实现前台触发后台异步批量发送短信,且不影响用户体验。 用户点击按钮后,前台立即返回成功提示,后台则异步执行数据库查询、Redis缓存写入和短信发送。

如何在前台触发后台异步批量发送短信而不影响用户体验?

核心思路:异步处理

该方案利用异步处理机制,将耗时操作移至后台执行,避免阻塞前台。 具体步骤如下:

  1. 前台Ajax请求: 用户点击发送按钮,前端使用Ajax向后台发送请求,请求参数包含短信模板ID、手机号列表和短信内容。

    $.ajax({
        url: '/send-sms',
        type: 'POST',
        data: { template_id: 123, mobiles: ['13800138000', '13800138001'], content: '测试短信' },
        success: function(response) {
            alert('短信发送请求已提交');
        },
        error: function(error) {
            alert('请求失败:'   error.responseText);
        }
    });
    登录后复制
  2. 后台接收请求并返回响应: 后台接收Ajax请求后,立即返回成功响应(JSON格式),告知前台请求已接收。 关键在于,短信发送逻辑被放入异步任务中。

    // 后台控制器方法
    public function sendSmsAction() {
        $templateId = $_POST['template_id'];
        $mobiles = $_POST['mobiles'];
        $content = $_POST['content'];
    
        // 立即返回成功响应
        echo json_encode(['success' => true, 'message' => '请求已接收,短信发送任务已启动']);
    
        // 将任务添加到队列(例如使用Redis或RabbitMQ)
        $this->addTaskToQueue($templateId, $mobiles, $content);
    }
    登录后复制
  3. 异步任务处理: addTaskToQueue 方法将短信发送任务添加到消息队列中。 一个独立的后台进程(例如使用队列工作者)持续监听队列,取出任务并执行。

    // 添加任务到队列 (示例使用Redis)
    private function addTaskToQueue($templateId, $mobiles, $content) {
        $redis = new Redis();
        $redis->connect('127.0.0.1', 6379);
        $redis->lPush('sms_queue', json_encode(['template_id' => $templateId, 'mobiles' => $mobiles, 'content' => $content]));
    }
    登录后复制
  4. 队列工作者: 队列工作者从 sms_queue 队列中获取任务,执行短信发送,并处理错误日志。

    // 队列工作者 (示例)
    while (true) {
        $task = $redis->rPop('sms_queue');
        if ($task) {
            $data = json_decode($task, true);
            $result = $this->sendSms($data['template_id'], $data['mobiles'], $data['content']);
            if ($result !== true) {
                // 记录错误日志
                error_log("短信发送失败: " . $result);
            }
        }
        sleep(1); // 避免CPU占用过高
    }
    登录后复制
  5. 短信发送函数 (sendSms): 该函数调用短信服务商API发送短信。

通过以上步骤,前台用户体验不受影响,后台则高效地处理批量短信发送。 选择合适的队列系统(Redis、RabbitMQ、Beanstalkd等)至关重要,它能保证任务可靠地被处理,并支持分布式环境。 此外,完善的错误处理和日志记录机制也必不可少。

以上是如何在前台触发后台异步批量发送短信而不影响用户体验?的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

centos redis如何配置Lua脚本执行时间 centos redis如何配置Lua脚本执行时间 Apr 14, 2025 pm 02:12 PM

在CentOS系统上,您可以通过修改Redis配置文件或使用Redis命令来限制Lua脚本的执行时间,从而防止恶意脚本占用过多资源。方法一:修改Redis配置文件定位Redis配置文件:Redis配置文件通常位于/etc/redis/redis.conf。编辑配置文件:使用文本编辑器(例如vi或nano)打开配置文件:sudovi/etc/redis/redis.conf设置Lua脚本执行时间限制:在配置文件中添加或修改以下行,设置Lua脚本的最大执行时间(单位:毫秒)

Debian如何提升Hadoop数据处理速度 Debian如何提升Hadoop数据处理速度 Apr 13, 2025 am 11:54 AM

本文探讨如何在Debian系统上提升Hadoop数据处理效率。优化策略涵盖硬件升级、操作系统参数调整、Hadoop配置修改以及高效算法和工具的运用。一、硬件资源强化确保所有节点硬件配置一致,尤其关注CPU、内存和网络设备性能。选择高性能硬件组件对于提升整体处理速度至关重要。二、操作系统调优文件描述符和网络连接数:修改/etc/security/limits.conf文件,增加系统允许同时打开的文件描述符和网络连接数上限。JVM参数调整:在hadoop-env.sh文件中调整

HDFS配置CentOS需要哪些步骤 HDFS配置CentOS需要哪些步骤 Apr 14, 2025 pm 06:42 PM

在CentOS系统上搭建Hadoop分布式文件系统(HDFS)需要多个步骤,本文提供一个简要的配置指南。一、前期准备安装JDK:在所有节点上安装JavaDevelopmentKit(JDK),版本需与Hadoop兼容。可从Oracle官网下载安装包。环境变量配置:编辑/etc/profile文件,设置Java和Hadoop的环境变量,使系统能够找到JDK和Hadoop的安装路径。二、安全配置:SSH免密登录生成SSH密钥:在每个节点上使用ssh-keygen命令

centos redis如何配置慢查询日志 centos redis如何配置慢查询日志 Apr 14, 2025 pm 04:54 PM

在CentOS系统上启用Redis慢查询日志,提升性能诊断效率。以下步骤将指导您完成配置:第一步:定位并编辑Redis配置文件首先,找到Redis配置文件,通常位于/etc/redis/redis.conf。使用以下命令打开配置文件:sudovi/etc/redis/redis.conf第二步:调整慢查询日志参数在配置文件中,找到并修改以下参数:#慢查询阈值(毫秒)slowlog-log-slower-than10000#慢查询日志最大条目数slowlog-max-len

centos7 如何安装redis centos7 如何安装redis Apr 14, 2025 pm 08:21 PM

从 Redis 官方源下载源码包编译安装,保证最新稳定版本,可个性化定制。具体步骤如下:更新软件包列表创建 Redis 目录下载 Redis 源码包解压源码包编译安装配置并修改 Redis 配置启动 Redis检查启动状态

HDFS配置CentOS需要修改哪些文件 HDFS配置CentOS需要修改哪些文件 Apr 14, 2025 pm 07:27 PM

在CentOS上配置Hadoop分布式文件系统(HDFS)时,需要修改以下关键配置文件:core-site.xml:fs.defaultFS:指定HDFS的默认文件系统地址,例如hdfs://localhost:9000。hadoop.tmp.dir:指定Hadoop临时文件的存储目录。hadoop.proxyuser.root.hosts和hadoop.proxyuser.ro

Debian Hadoop任务执行流程是什么 Debian Hadoop任务执行流程是什么 Apr 13, 2025 am 11:24 AM

Hadoop任务执行流程主要包括以下几个步骤:提交作业:用户在客户端机器上使用Hadoop提供的命令行工具或API,构建任务的执行环境并将任务提交到YARN(Hadoop的资源管理器)。资源申请:YARN收到任务提交请求后,会根据任务所需资源(如内存、CPU等)向集群中的节点申请资源。任务启动:一旦资源分配完成,YARN会将任务的启动命令发送给相应的节点。在节点上,NodeMana

Debian上TigerVNC共享文件方法 Debian上TigerVNC共享文件方法 Apr 13, 2025 am 11:45 AM

本文介绍如何在Debian系统上使用TigerVNC共享文件。你需要先安装TigerVNC服务器,然后进行配置。一、安装TigerVNC服务器打开终端。更新软件包列表:sudoaptupdate安装TigerVNC服务器:sudoaptinstalltigervnc-standalone-servertigervnc-common二、配置TigerVNC服务器设置VNC服务器密码:vncpasswd启动VNC服务器:vncserver:1-localhostno

See all articles