XHPROF相关内容

定义入口文件

define(‘XHPROF_OPEN‘, 0);
define(‘XHPROF_ROOT‘, ‘/home/www/xhprof/‘);

// 开启调试模式 建议开发阶段开启 部署阶段注释或者设为false
define(‘APP_DEBUG‘,true);

// 定义应用目录
define(‘APP_PATH‘,‘../app/‘);
define(‘LOG_PATH‘,APP_PATH.‘Runtime/Logs/‘);

if(defined(‘XHPROF_OPEN‘) && XHPROF_OPEN) {
    require (‘./xhprof.php‘);
}

加载xhprof.php

<?php
if (!defined(‘XHPROF_OPEN‘)) define(‘XHPROF_OPEN‘, 0);
class Xhprof
{
    private static $st = 0;

    /**
     * [start description]
     * @return [type] [description]
     */
    public static function start()
    {
        if (!function_exists(‘xhprof_enable‘)) {
            exit("xhprof_enable not exists!");
        }
        if (!is_dir(XHPROF_ROOT)) {
            exit(XHPROF_ROOT . " not exists!");
        }
        //xhprof_enable(XHPROF_FLAGS_CPU + XHPROF_FLAGS_MEMORY);
        xhprof_enable(XHPROF_FLAGS_NO_BUILTINS |XHPROF_FLAGS_CPU | XHPROF_FLAGS_MEMORY);
        self::$st = microtime(true);
        register_shutdown_function(array(__CLASS__, ‘end‘)); //php进程关闭时自动执行的方法
    }

    /**
     * [end description]
     * @return [type] [description]
     */
    public static function end()
    {
        $et = microtime(true);
        $data = xhprof_disable();

        include_once XHPROF_ROOT."xhprof_lib/utils/xhprof_lib.php";
        include_once XHPROF_ROOT."xhprof_lib/utils/xhprof_runs.php";
        $runs = new XHProfRuns_Default();
        $runId = $runs->save_run($data, "hx");

        $log = XHPROF_ROOT . ‘xhprof_html/logs/‘.date(‘YmdHis‘).‘.html‘;
        $cost = $et - self::$st;
        $host = $_SERVER[‘HTTP_HOST‘];
        $title = $_SERVER[‘REQUEST_URI‘];
        $content = ‘Time: ‘.date(‘H:i:s‘)."\tCost: {$cost}\t\tUri({$host}): <a href=‘/index.php?run={$runId}&source=hx‘ target=‘_blank‘>{$title}</a><br/>";
        file_put_contents($log, $content, FILE_APPEND);
    }
}
if(XHPROF_OPEN) Xhprof::start();
XHPROF_OPEN 调试为1就可用
时间: 2024-10-29 20:49:18

XHPROF相关内容的相关文章

移动端 h5开发相关内容总结——CSS篇

移动端 h5开发相关内容总结——CSS篇 标签: css移动 2016-01-06 15:59 5536人阅读 评论(3) 收藏 举报  分类: HTML+CSS(17)  版权声明:本文为博主原创文章,未经博主允许不得转载. 目录(?)[+] 1.移动端开发视窗口的添加 h5端开发下面这段话是必须配置的 <meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=n

EF Code First 配置的相关内容

I.实体间一对一的关系 添加一个PersonPhoto类,表示用户照片类 1 /// <summary> 2 /// 用户照片类 3 /// </summary> 4 public class PersonPhoto 5 { 6 [Key] 7 public int PersonId { get ; set ; } 8 public byte [] Photo { get ; set ; } 9 public string Caption { get ; set ; } // 标题

【转帖】MATLAB 与 音频处理 相关内容摘记

MATLAB 与 音频处理 相关内容摘记 MATLAB 与 音频处理 相关内容摘记 MATLAB 与 音频处理 相关内容摘记 1 MATLAB 音频相关函数 1 MATLAB 处理音频信号的流程 2 音量标准化 2 声道分离合并与组合 3 数字滤波 3 数据转换 5 基于MATLAB 的数字滤波实验6 MATLAB 音频相关函数 声音数据输入输出函数: 可以方便地读写au和way文件,并可控制其中的位及频率. wavread()和wavwriteO. 声音播放: wavplay():播放wav声

python爬虫主要就是五个模块:爬虫启动入口模块,URL管理器存放已经爬虫的URL和待爬虫URL列表,html下载器,html解析器,html输出器 同时可以掌握到urllib2的使用、bs4(BeautifulSoup)页面解析器、re正则表达式、urlparse、python基础知识回顾(set集合操作)等相关内容。

本次python爬虫百步百科,里面详细分析了爬虫的步骤,对每一步代码都有详细的注释说明,可通过本案例掌握python爬虫的特点: 1.爬虫调度入口(crawler_main.py) # coding:utf-8from com.wenhy.crawler_baidu_baike import url_manager, html_downloader, html_parser, html_outputer print "爬虫百度百科调度入口" # 创建爬虫类class SpiderMai

学习笔记之html5相关内容

写一下昨天学习的html5的相关内容,首先谈下初次接触html5的感受.以前总是听说html5是如何的强大,如何的将要改变世界.总是充满了神秘感.首先来谈一下我接触的第一个属性是  input的里面的一个属性是 type="email".以前用html的时候,type是有很多类型的,有text,password,summit.就是没听说过email.当得知这个email是验证输入的内容是否为email格式的时候.我顿时兴奋了.以前接触到html的时候,如果要验证输入内容时,是需要写js

在生成一系列相关内容后,签名文件生成

然后上传刚刚生成的CSR文件 按下Generate后,稍等一会,证书就生成了,你可以下载然后安装到本机. 3. AppID 需要强调一下的是,这里的AppID和常说的AppleID不是一个概念.AppleID是用户在苹果的账号,在AppStore上下载应用时,需要使用的就是这个账号.而AppID则是应用的身份证,用来表明应用的ID. 在证书生成后,下一步就是生成AppID,相当于帮你想开发的应用生成一张身份证. AppID需要你起一个名字以方便描述.这里不能输入特殊字符. AppID还分成带通配

App Store审核指南中文版(2014.9.10更新):新增Apple Pay相关内容

苹果在9月3日对App Store审核指南进行了重大更新,新添加了扩展.HealthKit.HomeKit以及TestFlight相关内容.另外,在9月10日新品发布会之后,苹果再次更新了App Store审核指南,添加Apple Pay相关内容.文中红色部分是相对于此前版本的新增内容,蓝色部分表示苹果相关官方文档的链接. App Store Review Guidelines(英文版). 前言 感谢您付出宝贵的才华与时间来开发iOS应用程程序.从职业与报酬的角度而言,这对于成千上万的开发员来说

linux中Makefile文件相关内容

第一章.概述什么是makefile?或许很多Winodws的程序员都不知道这个东西,因为那些Windows的IDE都为你做了这个工作,但我觉得要作一个好的和professional(专业)的程序员,makefile还是要懂.这就好像现在有这么多的HTML的编辑器,但如果你想成为一个专业人士,你还是要了解HTML的标识的含义.特别在Unix下的软件编译,你就不能不自己写makefile了,会不会写makefile,从一个侧面说明了一个人是否具备完成大型工程的能力.因为,makefile关系到了整个

Flume sink 相关内容

SinkRunner.java 开启线程调用相应的Processor(Policy) , 根据  Policy调用process的返回值来决定线程睡眠时间,每次默认延后1s,最大默认为5s. public class SinkRunner implements LifecycleAware { private static final Logger logger = LoggerFactory .getLogger(SinkRunner.class); private static final