使用register_shutdown_function触发写日志,使用fastcgi_finish_request提高响应速度

公司内部的市场管理系统,一直是我一个人维护,最近老是有开发埋怨,内网的账号被人改了密码,账号被解绑了。。。哈的,错在这还不是一个完整的系统,既没有严格的权限也没有做操作日志呀。。。

权限现在是准备做在下一阶段的的API网关项目里面做统一的管理,想着还是先把操作日志做起来吧。

系统框架使用的Think PHP 5,查了一下文档,http://www.kancloud.cn/manual/thinkphp5/135195,模型是支持事件的,于是计划是这样,通过模型的事件触发记录日志的动作。

看了一下系统的日志源码,发现框架是通过register_shutdown_function注册了一个方法,把执行过程中写入内存的日志信息在脚本程序执行结束后,返回客服端前写入到文件的,由于操作日志要和系统日志

有所区分,所以在入口文件处通过register_shutdown_function也注册了方法,实现过程发现没什么问题,可是想着像这种记录日志的动作,其实并不是客户端用户关心的问题,却要在响应前做,真真的是拖慢了

响应的速度呀,想着能不能有可以把这个写文件的操作放在响应客户端之后做,结果真的发现一个函数可以做到,http://www.laruence.com/2011/04/13/1991.html,这个函数就是fastcgi_finish_request,

fastcgi_finish_request函数之后的程序可以继续执行,而响应则已经发送给客户端了,我看大神的文章后也做了下测试,测试代码 https://github.com/huanglintian/log

时间: 2024-08-27 09:43:46

使用register_shutdown_function触发写日志,使用fastcgi_finish_request提高响应速度的相关文章

C# 超高速高性能写日志 代码开源

1.需求 需求很简单,就是在C#开发中高速写日志.比如在高并发,高流量的地方需要写日志.我们知道程序在操作磁盘时是比较耗时的,所以我们把日志写到磁盘上会有一定的时间耗在上面,这些并不是我们想看到的. 2.解决方案 2.1.简单原理说明 使用列队先缓存到内存,然后我们一直有个线程再从列队中写到磁盘上,这样就可以高速高性能的写日志了.因为速度慢的地方我们分离出来了,也就是说程序在把日志扔给列队后,程序的日志部分就算完成了,后面操作磁盘耗时的部分程序是不需要关心的,由另一个线程操作. 俗话说,鱼和熊掌

写日志函数和持续优化

首先看下面的函数 <span style="font-size:18px;">void writelog(char* file, char* msg) { FILE*fp=NULL; int nDataLen = strlen(msg); fp=fopen(file,"ab+");//只供读取 if(fp!=NULL) { fwrite(msg, nDataLen, 1, fp); } fclose(fp);//关闭文件 }</span> 这

使用fastcgi_finish_request提高页面响应速度

当PHP运行在FastCGI模式时,PHP FPM提供了一个名为fastcgi_finish_request的方法.按照文档上的说法,此方法可以提高请求的处理速度,如果有些处理可以在页面生成完后再进行,就可以使用这个方法. 听起来可能有些茫然,我们通过几个例子来说明一下:     <?php           echo '例子:';     fastcgi_finish_request(); /* 响应完成, 关闭连接 */           /* 记录日志 */     file_put_

程序员的修养 -- 如何写日志(logging)

  在程序中写日志是一件非常重要,但是很容易被开发人员忽视的地方.写好程序的日志可以帮助我们大大减轻后期维护压力. 在实际的工作中,开发人员往往迫于的巨大时间压力,而写日志又是一个非常繁琐的事情,往往没有引起足够的重视. 如果我们的开发人员在一开始就养成一个良好的习惯将非常有帮助.并且在实际的工作中也应当为写日志预留足够的时间.   我们为什要写日志呢? 一般来讲,我们在程序中记录日志出自下面几个方面的需求.   * 记录用户操作的审计日志,甚至有的时候就是监管部门的要求. * 快速定位问题的根

Oracle 插入大量数据时不要写日志

1. 采用高速的存储设备,提高读写能力,如:EMC 和NetApp, 2. 假如tab1表中的没有数据的话 DROP   TABLE   TAB1;CREATE   TABLE   TAB1   AS   SELECT   *   FROM   TAB2;然后在创建索引 3. 用Hint 提示减少操作时间 INSERT   /*+Append*/   INTO     tab1                 SELECT   *   FROM   tab2; 4. 采用不写日志及使用Hint提

C#简单写日志

自己整理了一个简单写日志的类,方便以后再次用到. 说明:CS程序,程序启动目录下,自动创建Log目录,写日志.日志按天记录,每天的日志作为一个txt文件保存. /// <summary> /// 日志管理功能 /// //以天建立日志文件, /// </summary> public class LogManager { private static string LogDirectory = Application.StartupPath + @"\Log\"

python 统计时间,写日志

python 统计时间使用time模块,写日志使用logging模块,这两个都是标准模板. 测试socket使用socket模块 # 统计时间 ---------------------- import time start = time.time() end = time.time() stamp = end - start print "耗时", stamp # 日志 ----------------------- import loggingimport datetime cur

利用TraceSource写日志

利用TraceSource写日志 从微软推出第一个版本的.NET Framework的时候,就在“System.Diagnostics”命名空间中提供了Debug和Trace两个类帮助我们完成针对调试和跟踪信息的日志记录.在.NET Framework 2.0中,微软引入了TraceSource并对跟踪日志系统进行了优化,优化后的跟踪日志系统在.NET Core中又经过了相应的简化..NET Core的日志模型借助TraceSourceLoggerProvider实现对TraceSource的整

NodeJS写日志_Log4js使用详解

今天和大家分享一下NodeJS中写日志的一个常用第三方包:Log4js. 跟随主流Blog特色,先简单介绍下Log4js的基本信息.介绍Log4js之前,需要先说一下Log4***,Log4***是由Apache提供的多平台下多语言下日志书写扩展包,目的很简单就是使日志书写更加方便简洁,同时对不同的业务日志能够进行灵活的分文件记录,同时也包含着详细的等级配置,为之后分级输出,检索,及程序自动解析提供更加便捷的支持(一家之言,非官方描述,领会精神).Log4***有很多语言的实现,比如Log4cp