本文整理汇总了PHP中xhprof_disable函数的典型用法代码示例。如果您正苦于以下问题:PHP xhprof_disable函数的具体用法?PHP xhprof_disable怎么用?PHP xhprof_disable使用的例子?那么, 这里精选的函数代码示例或许可以为您提供帮助。
在下文中一共展示了xhprof_disable函数的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的PHP代码示例。
示例1: end
public function end()
{
$xhprof_data = xhprof_disable();
$xhprof_runs = new XHProfRuns_Default();
$run_id = $xhprof_runs->save_run($xhprof_data, $this->name);
return "<a href='http://localhost:8080/xhprof/xhprof_html/index.php?run={$run_id}&source=" . $this->name . "'>See result</a>";
}
示例2: stopProfiler
public static function stopProfiler()
{
if (self::$profilerStarted) {
$data = xhprof_disable();
$data = serialize($data);
$file_class = 'PhabricatorFile';
// Since these happen on GET we can't do guarded writes. These also
// sometimes happen after we've disposed of the write guard; in this
// case we need to disable the whole mechanism.
$use_scope = AphrontWriteGuard::isGuardActive();
if ($use_scope) {
$unguarded = AphrontWriteGuard::beginScopedUnguardedWrites();
} else {
AphrontWriteGuard::allowDangerousUnguardedWrites(true);
}
$caught = null;
try {
$file = call_user_func(array($file_class, 'newFromFileData'), $data, array('mime-type' => 'application/xhprof', 'name' => 'profile.xhprof'));
} catch (Exception $ex) {
$caught = $ex;
}
if ($use_scope) {
unset($unguarded);
} else {
AphrontWriteGuard::allowDangerousUnguardedWrites(false);
}
if ($caught) {
throw $caught;
} else {
return $file->getPHID();
}
} else {
return null;
}
}
示例3: indexAction
public function indexAction()
{
$m_article = $this->load('Article');
$userID = $this->getSession('userID');
if ($userID) {
$buffer['username'] = $this->getSession('username');
// User Aritcles
$where = array('userID' => USER_ID);
$total = $m_article->Where($where)->Total();
$page = $this->get('page');
$page = $page ? $page : 1;
$size = 10;
$pages = ceil($total / $size);
$order = array('addTime' => 'DESC');
$start = ($page - 1) * $size;
$limit = $start . ',' . $size;
$url = '/user/profile';
$buffer['pageNav'] = generatePageLink($page, $pages, $url, $total);
$buffer['articles'] = $m_article->Where($where)->Order($order)->Limit($limit)->Select();
} else {
$this->redirect('/');
}
// 如果有 xhprof 则开启跟踪功能
if (function_exists('xhprof_disable')) {
$data = xhprof_disable();
include_once LIB_PATH . '/xhprof_lib/utils/xhprof_lib.php';
include_once LIB_PATH . '/xhprof_lib/utils/xhprof_runs.php';
$objXhprofRun = new XHProfRuns_Default();
$run_id = $objXhprofRun->save_run($data, 'xhprof');
}
$buffer['run_id'] = $run_id;
$this->getView()->assign($buffer);
}
示例4: ADisable
public static function ADisable()
{
if (self::_isEnable()) {
return xhprof_disable();
}
return array();
}
示例5: profilingFinalize
function profilingFinalize($pre)
{
include_once "/usr/share/php5-xhprof/xhprof_lib/utils/xhprof_lib.php";
include_once "/usr/share/php5-xhprof/xhprof_lib/utils/xhprof_runs.php";
$xhprof_runs = new XHProfRuns_Default();
$xhprof_runs->save_run(xhprof_disable(), 'nagvis-' . $pre);
}
示例6: save
/**
* @inheritdoc
*/
public function save()
{
if (function_exists('xhprof_disable')) {
$data = xhprof_disable();
}
return isset($data) && $data !== null ? $data : [];
}
示例7: stop
/**
* Stops XHProf profiling and saves profile data in var/log/xhprof
*
* @return mixed false|string (the run_id)|true (when nosave==true)
*/
public static function stop($dosave = true)
{
if (!extension_loaded('xhprof')) {
eZPerfLoggerDebug::writeWarning('Extension xhprof not loaded, can not stop profiling', __METHOD__);
return false;
}
if (!self::$profilingRunning) {
return false;
}
$xhprofData = xhprof_disable();
self::$profilingRunning = false;
if (!$dosave) {
return true;
}
if (!is_dir(self::$logdir)) {
mkdir(self::$logdir);
}
$logger = new XHProfRuns_Default(self::$logdir);
$runId = $logger->save_run($xhprofData, "xhprof");
if ($runId) {
// beside profiling data, save extra info in another file to make it more useful later
file_put_contents(self::$logdir . "/{$runId}.info", eZPerfLoggerApacheLogger::apacheLogLine('combined'));
self::$runs[] = $runId;
}
return $runId;
}
示例8: stop
/**
* Stop collecting profiling data.
*
* Only the first invocation of this method will effect the internal
* object state. Subsequent calls will return the data collected by the
* initial call.
*
* @return array Collected profiling data (possibly cached)
*/
public function stop()
{
if ($this->hieraData === null) {
$this->hieraData = $this->pruneData(xhprof_disable());
}
return $this->hieraData;
}
示例9: testSearchEvents
public function testSearchEvents()
{
$allUsers = Tinebase_User::getInstance()->getFullUsers('');
xhprof_enable();
$numSearches = 0;
foreach ($allUsers as $user) {
if ($numSearches > 5) {
break;
}
echo "getting month view for {$user->accountDisplayName}\n";
$filterData = array(array('field' => 'container_id', 'operator' => 'in', 'value' => array('/personal/' . $user->getId(), '/shared')), array('field' => 'period', 'operator' => 'within', 'value' => array('from' => '2010-03-01 00:00:00', 'until' => '2010-04-01 00:00:00')));
// $filter = new Calendar_Model_EventFilter($filterData);
// $events = Calendar_Controller_Event::getInstance()->search($filter, NULL, FALSE);
$this->_json->searchEvents($filterData, NULL);
$numSearches += 1;
}
$xhprof_data = xhprof_disable();
//Tinebase_Core::getDbProfiling();
$XHPROF_ROOT = '/opt/local/www/php5-xhprof';
include_once $XHPROF_ROOT . "/xhprof_lib/utils/xhprof_lib.php";
include_once $XHPROF_ROOT . "/xhprof_lib/utils/xhprof_runs.php";
$xhprof_runs = new XHProfRuns_Default();
$run_id = $xhprof_runs->save_run($xhprof_data, "xhprof_tine20");
echo "http://localhost/xhprof_html/index.php?run={$run_id}&source=xhprof_tine20 \n";
print_r(Tinebase_Record_Abstract::$cns);
}
示例10: disable
/**
* Stop xhprof profiler
*
* @return array|null xhprof data from the run, or null if xhprof was not running.
*/
public static function disable()
{
if (self::isEnabled()) {
self::$enabled = false;
return xhprof_disable();
}
}
示例11: xhprof_stop
function xhprof_stop()
{
// 关闭xhprof
global $gearman_enabled;
$error = error_get_last();
$resp_time = sprintf("%.4f", $GLOBALS['AX_PAGE_END_TIME'] - $GLOBALS['AX_PAGE_START_TIME']);
if (!empty($error) || $GLOBALS['AX_XHPROF_IS_RUN'] || $resp_time >= $GLOBALS['AX_XHPROF_TIMEOUT']) {
$data = array();
$data['host'] = $_SERVER['HTTP_HOST'];
$data['uri'] = $_SERVER['REQUEST_URI'];
$data['client_time'] = date('Y-m-d H:i:s');
$data['resp_time'] = $resp_time;
$data['xhprof'] = null;
if ($GLOBALS['AX_XHPROF_IS_RUN']) {
$data['xhprof'] = xhprof_disable();
$GLOBALS['AX_XHPROF_IS_RUN'] = false;
}
$data['error'] = $error;
// 检查是否安装gearman扩展,并已设置gearman server
if ($gearman_enabled) {
$ret = do_background_job('xhprof.write', serialize($data));
echo "\n<!-- gearman save: {$ret} -->\n";
} else {
$xhprof_run = new XHProfRuns_DB();
$run_id = $xhprof_run->save_run($data);
echo "\n<!-- xhprof save, id: {$run_id} -->\n";
}
}
}
示例12: endProf
public static function endProf()
{
$xhprof_data = xhprof_disable();
$xhprof_runs = new XHProfRuns_Default();
$run_id = $xhprof_runs->save_run($xhprof_data, "xhprof_foo");
echo '<a href="/xhprof_html/index.php?run=' . $run_id . '&source=xhprof_foo" target="_blank">count</a>';
}
示例13: collect
/**
* Collects data.
*
* @param MvcEvent $mvcEvent
*/
public function collect(MvcEvent $mvcEvent)
{
$rawData = xhprof_disable();
$rawData = empty($rawData) ? [] : $rawData;
$data = $this->getFunctions($rawData);
$heaps = [];
foreach ($this->options->getMetrics() as $name => $options) {
$this->data[$name] = [];
$heaps[$name] = new MaxHeap();
}
if (!empty($data)) {
foreach ($data as $entry) {
/** @var Entry $entry */
foreach ($this->options->getMetrics() as $name => $options) {
if ($options['skipInternal'] && $entry->isInternal()) {
continue;
}
if (!empty($options['skipPattern']) && preg_match($options['skipPattern'], $entry->getName())) {
continue;
}
$heaps[$name]->insert(['name' => $entry->getName(), 'value' => $entry->{$options['getter']}()]);
}
}
foreach ($this->options->getMetrics() as $name => $options) {
for ($i = $options['limit']; $i--;) {
$value = $heaps[$name]->extract();
$this->data[$name][$value['name']] = $value['value'];
}
}
}
}
示例14: index
public function index()
{
function bar($x)
{
if ($x > 0) {
bar($x - 1);
}
}
function foo()
{
for ($idx = 0; $idx < 5; $idx++) {
bar($idx);
$x = strlen("abc");
}
}
//开启调试
xhprof_enable();
// cpu:XHPROF_FLAGS_CPU 内存:XHPROF_FLAGS_MEMORY
// 如果两个一起:XHPROF_FLAGS_CPU + XHPROF_FLAGS_MEMORY
xhprof_enable(XHPROF_FLAGS_CPU + XHPROF_FLAGS_MEMORY);
//要测试的php代码
foo();
//停止监测
$xhprof_data = xhprof_disable();
// display raw xhprof data for the profiler run
print_r($xhprof_data);
//包含工具类,在下载的 tgz 包中可以找到
//$XHPROF_ROOT = realpath(dirname(__FILE__) .'/..');
Vendor('Xhprof.autoload');
//Vendor('Xhprof.xhprof_runs');
//include_once $XHPROF_ROOT . "/xhprof_lib/utils/xhprof_lib.php";
//include_once $XHPROF_ROOT . "/xhprof_lib/utils/xhprof_runs.php";
// save raw data for this profiler run using default
// implementation of iXHProfRuns.
}
示例15: register
private function register()
{
register_shutdown_function(function () {
$execTime = microtime(true) - START_TIME;
$memoryUsage = round((memory_get_usage() - START_MEMORY_USAGE) / 1024, 2);
$info = '执行时间: ' . round($execTime, 2) . 's, 内存使用: ' . $memoryUsage . 'KB';
$info .= ", 查询次数: " . Db::$queryCount . ", 慢查询数量: " . Db::$slowCount;
if ($this->xhporfEnabled) {
$route = str_replace('/', '_', CUR_ROUTE);
$xhprofData = xhprof_disable();
$dir = DATA_PATH . 'xhprof/';
if (is_dir($dir) || @mkdir($dir)) {
$xhprofRuns = new \XHProfRuns_Default($dir);
$runId = $xhprofRuns->save_run($xhprofData, $route);
$info .= ', 性能分析: <a href="' . $this->xhprofUrl . '?run=' . $runId . '&source=' . $route . '" target="_blank">' . $runId . '</a>';
}
}
$isAjax = isset($_SERVER['HTTP_X_REQUESTED_WITH']) && strtolower($_SERVER['HTTP_X_REQUESTED_WITH']) === 'xmlhttprequest';
$isGet = !empty($_SERVER['REQUEST_METHOD']) && strtolower($_SERVER['REQUEST_METHOD']) === 'get';
if ($this->showStatusBar && $isGet && !$isAjax) {
echo '<div style="padding:5px 0;background:#faebcc;text-align:center;">';
echo $info;
echo '</div>';
}
});
}