位置: 编程技术 - 正文

深入剖析浏览器退出之后php还会继续执行么(浏览器分析)

编辑:rootadmin

推荐整理分享深入剖析浏览器退出之后php还会继续执行么(浏览器分析),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:浏览器的问题,浏览器的问题,浏览器整治,浏览器解析网页过程,浏览器的解析原则,浏览器分析,浏览器的问题,浏览器分析,内容如对您有帮助,希望把文章链接给更多的朋友!

前提:这里说的是典型的lnmp结构,nginx+php-fpm的模式

如果我有个php程序执行地非常慢,甚至于在代码中sleep(),然后浏览器连接上服务的时候,会启动一个php-fpm进程,但是这个时候,如果浏览器关闭了,那么请问,这个时候服务端的这个php-fpm进程是否还会继续运行呢?

今天就是要解决这个问题。

最简单的实验

最简单的方法就是做实验,我们写一个程序:在sleep之前和之后都用file_put_contents来写入日志:

实际操作的结果是,我们在服务器sleep的过程中,关闭客户端浏览器,是会被写入日志中。

那么就意味着浏览器关闭以后,服务端的php还是会继续运行的&#;

ignore_user_abort

老王和diogin提醒,这个可能是和php的ignore_user_abort函数相关。

于是我就把代码稍微改成这样的:

发现并没有任何软用,不管设置ignore_user_abort为何值,都是会继续执行的。

但是这里有一个疑问: user_abort是什么?

文档对cli模式的abort说的很清楚,当php脚本执行的时候,用户终止了这个脚本的时候,就会触发abort了。然后脚本根据ignore_user_abort来判断是否要继续执行。

但是官方文档对cgi模式的abort并没有描述清楚。感觉即使客户端断开连接了,在cgi模式的php是不会收到abort的。

难道ignore_user_abort在cgi模式下是没有任何作用的?

是不是心跳问题呢?

首先想到的是不是心跳问题呢?我们断开浏览器客户端,等于在客户端没有close而断开了连接,服务端是需要等待tcp的keepalive到达时长之后才会检测出来的。

好,需要先排除浏览器设置的keepalive问题。

抛弃浏览器,简单写一个client程序:程序连接上http服务之后,发送一个header头,sleep1秒就主动close连接,而这个程序并没有带http的keepalive头。

程序如下:

服务端程序:

深入剖析浏览器退出之后php还会继续执行么(浏览器分析)

发现仍然还是一样,php还是不管是否设置ignore_user_abort,会继续执行完成整个脚本。看来ignore_user_abort还是没有生效。

如何触发ignore_user_abort

那该怎么触发ignore_user_abort呢?服务端这边怎么知晓这个socket不能使用了呢?老王和diogin说是不是需要服务端主动和socket进行交互,才会判断出这个socket是否可以使用?

另外,我们还发现,php提供了connection_status和connection_aborted两个方法,这两个方法都能检测出当前的连接状态。于是我们的打日志的那行代码就可以改成:

根据手册连接处理显示我们可以打印出当前连接的状态了。

下面还缺少一个和socket交互的程序,我们使用echo,后面也顺带记得带上flush,排除了flush的影响。

程序就改成

很好,执行我们前面写的client。观察日志:

终于制造出了abort。日志也显示后面几次的abort状态都是1。

但是这里有个奇怪的地方,为什么第一个2 connection status的状态还是0呢(NORMAL)。

RST

我们使用wireshark抓包看整个客户端和服务端交互的过程

这整个过程只有发送个包,我们看下服务端第一次发送的时候,客户端返回的是RST。后面就没有进行后续的包请求了。

于是理解了,客户端和服务端大概的交互流程是:

当服务端在循环中第一次发送的时候,客户端由于已经断开连接了,返回的是一个RST,但是这个发送过程算是请求成功了。直到第二次服务端再 次想往这个socket中进行write操作的时候,这个socket就不进行网络传输了,直接返回说connection的状态已经为abort。所以 就出现了上面的情况,第一次是status为0,第二次的时候才出现abort。

strace进行验证

我们也可以使用strace php -S XXX来进行验证

整个过程strace的日志如下:

第二次往socket中发送的时候显示了Broken pipe。这就是程序告诉我们,这个socket已经不能使用了,顺便php中的connection_status就会被设置为1了。后续的写操作也都不会再执行了。

总结

正常情况下,如果客户端client异常推出了,服务端的程序还是会继续执行,直到与IO进行了两次交互操作。服务端发现客户端已经断开连接,这个 时候会触发一个user_abort,如果这个没有设置ignore_user_abort,那么这个php-fpm的程序才会被中断。

至此,问题结了。

以上这篇深入剖析浏览器退出之后php还会继续执行么就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持积木网。

CI框架整合widget(页面格局)的方法 本文实例讲述了CI框架整合widget(页面格局)的方法。分享给大家供大家参考,具体如下:在WEB开发过程中,我们免不了要输出视图文件,而通常视图文件

CodeIgniter记录错误日志的方法全面总结 本文实例讲述了CodeIgniter记录错误日志的方法。分享给大家供大家参考,具体如下:CI工作流程:所有的入口都从根目录下的index.php进入,确定应用所在

CI框架常用方法小结 本文实例讲述了CI框架常用方法。分享给大家供大家参考,具体如下:一、在模板文件中加载css、js文件:linkrel="stylesheet"type="text/css"href="=base_url('css/style.c

标签: 浏览器分析

本文链接地址:https://www.jiuchutong.com/biancheng/294702.html 转载请保留说明!

上一篇:CI框架出现mysql数据库连接资源无法释放的解决方法(mysql框架有哪些)

下一篇:CI框架整合widget(页面格局)的方法(ci框架api版本)

  • 所得税税前扣除项目及扣除标准
  • 息税前利润计算每股收益
  • 新车检测费能入什么科目
  • 保单的增值税发票
  • 购入土地使用权以什么为计税依据
  • 会计净额法和总额法
  • 2019最新运输发票样本
  • 工厂筹建期间购房合法吗
  • 高新技术企业季报填报
  • 资源税折算后计提怎么算
  • 对公账户的理财收入计入什么科目
  • 资本公积的核算内容不包括
  • 估价入账固定资产实际入账时补提折旧吗?
  • 个人投资理财需要注意什么
  • 工伤期间奖金发放标准
  • 未分配利润转增股本 个人所得税
  • 高铁票可以要发票吗
  • 特殊性税务处理和一般性税务处理的区别
  • 简易计税视同销售如何处理?
  • 全部出售子公司怎么做账
  • 总账会计就是内外账合并吗
  • 待摊费用报价变更的会计处理怎么做?
  • 会议费税前扣除最新税务规定
  • 税金及附加期末结转分录
  • 如何删除系统自带的软件
  • 小规模纳税人取得防伪税控系统普通发票
  • 抵押和质押的区别主要表现在哪些方面
  • 工人的意外险如何赔付
  • win服务器安装
  • linux获取网络设备的交换机网络
  • mac电脑修改dns
  • 逾期未收回包装物押金税率
  • php 设计模式 鸟哥
  • 生产性生物资产和消耗性生物资产有什么区别
  • 债券到期收回本息计算单
  • os x 10.10 yosemite自动纠正怎么关?os x yosemite自动纠正功能关闭教程
  • 购进旧设备折旧年限如何计算
  • 提取公益金会计科目
  • 往来账怎么处理
  • 增值税专用发票上注明的价款含税吗
  • PHP:imagecreatefromgd2part()的用法_GD库图像处理函数
  • 公司分立土地涉税问题
  • php使用oci8扩展连接oracle
  • 建筑劳务费发票有进项抵扣吗
  • 员工工资扣工作服合法吗?
  • php 方括号
  • 7z命令行详解
  • python可以制作软件吗
  • 帝国cms配置数据库
  • 人力资源管理公务员岗位
  • 为员工购买意外险会计处理
  • 租赁公司成本如何计算
  • 固定资产处置时发生的清理费用
  • 个税汇算清缴时劳务报酬怎么计税
  • 借款怎么入会计分录
  • 工程款发票怎么做分录
  • 房屋出租要交的税有哪些
  • 营业外收入算未开票收入吗
  • 递延收益为什么属于负债
  • mysql进阶之路
  • linux系统批量查找替换多个字符
  • svchos1.exe - svchos1是什么教程 有什么作用
  • 怎么更改桌面图标字体
  • vs2013运行
  • linux命令行在哪
  • windows7开机后显示配置失败
  • linux系统怎么复制文件到u盘
  • 5个小技巧让你成长
  • linux查看进程并杀死
  • cocos2d游戏引擎
  • JS写XSS cookie stealer来窃取密码的步骤详解
  • arcgis栅格图像
  • jquery 刷新div
  • 批处理命令在哪个菜单中
  • iframe用法和代码
  • android重写方法
  • nodejs eventloop
  • 如何配置centos7
  • 代理记账费用可以全额抵扣吗
  • 黑龙江工商局网站官网
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设