fastcgi_finish_request()函数和ignore_user_abort()函数

场景描述:

我们现在有这样一个案例,在oracle数据库导出几十万条数据,保存到json文件中,再把json文件的数据导入excel中。实际情况是执行了一半的时候,程序超时了,不能成功导出excel。

解决方案:

一:在web程序中调用后台脚本实现

二:使用今天的这两个函数(注意:先确认函数是否能正常使用

函数介绍:
复制代码
fastcgi_finish_request()冲刷(flush)所有响应的数据给客户端.
此函数冲刷(flush)所有响应的数据给客户端并结束请求。这允许在不打开与客户端之间的连接的情况下执行耗时任务。 可以提高页面响应速度。

注意问题PHP 与 Web 服务器使用了PHP-FPM(FastCGI进程管理器),那通过fastcgi_finish_request() 函数能马上结束会话,而 PHP 线程可以继续在后台运行。也就是说只针对php-fpm的进程管理方式才能使用该函数

由于该函数不是 PHP 核心函数,所以在某些情况下可能会受限或不可用。因此,在使用该函数之前,最好先检查是否可以使用该函数,并提供备选方案以处理不支持的情况。

ignore_user_abort() 函数设置与客户机断开是否会终止脚本的执行。

本函数返回 user-abort 设置的之前的值(一个布尔值)。

可选。如果设置为 true,则忽略与用户的断开,如果设置为 false,会导致脚本停止运行。

如果未设置该参数,会返回当前的设置

 # 执行耗时程序
    $filename = self::FILE_NAME_KEY . '_' .date('mdHis') . '.xlsx';

    ignore_user_abort(true); // 后台运行
    set_time_limit(0); // 取消脚本运行时间的超时上限

    # 耗时程序
    $model->doSomething();
相关推荐
aq55356003 小时前
ThinkPHP5.x核心特性全解析
android·数据库·oracle·php·laravel
KevinCyao4 小时前
php彩信接口代码示例:PHP使用cURL调用彩信网关发送图文消息
android·开发语言·php
其实防守也摸鱼5 小时前
集成开发环境phpStudy安装与配置指南(包含DVWA)
网络·安全·php·web·ctf·工具配置
Cyber4K6 小时前
【Nginx专项】高级进阶架构篇-Proxy正反向代理、FastCGI及PHP-FPM介绍
运维·服务器·nginx·架构·php
传说中胖子6 小时前
Magento服务器VSCode开启XDebug方法
服务器·vscode·php
niucloud-admin7 小时前
PHP SAAS 框架常见问题——配置问题——小程序消息推送配置 Token 校验失败
php
FreeBuf_8 小时前
微软 SharePoint Server 0Day漏洞遭在野利用
microsoft·php·sharepoint
齐潇宇9 小时前
LVS 基线检查与安全加固指南(附案例)
服务器·网络·php
爱学习的小囧9 小时前
SXi LAG 链路聚合负载均衡配置全教程 | LACP 协议 + 交换机联动,新手也能落地
运维·服务器·php·负载均衡·esxi
郝学胜-神的一滴9 小时前
[系统设计] 新鲜事系统:写扩散与读扩散的实现与对比
java·设计模式·php·软件构建·需求分析·软件设计·系统设计