WordPress EXP
分享10年建站经验

WordPress显示页面加载时间、数据库查询次数及内存占用

本文于 2020-09-13 00:31 更新,WordPress EXP 部分内容具有时效性,如有失效,请联系站长。

经常有人问“缙哥哥的博客”底部有个“本页数据库查询次数,页面生成操作耗时,PHP内存消耗量”,小伙伴们也想实现,这个功能。一来可以看看自己的 WordPress 站点的页面状态,二来可以通过某个插件或某段代码执行后的内存使用情况对内存的影响。

页面加载时间代码

本页数据库查询:<?php echo get_num_queries(); ?> 次;

数据库查询次数代码

页面生成操作耗时:<?php timer_stop(3); ?> 秒;
WordPress 站点显示页面加载时间、数据库查询次数及内存占用

内存占用代码

通过memory_get_usage()函数,返回当前分配给你的 PHP 脚本的内存量,单位是字节(byte)。也就是当时 PHP 脚本使用的内存(不含memory_get_usage()函数本身占用的内存)。

获取当前内存

如果是自己调试对比,那么用这个,可以快速对比加某段代码或插件甚至更换主题后的内存占用情况。

<?php 
echo memory_get_usage(); 
$var = str_repeat("liuhui", 10000); 
echo memory_get_usage(); 
unset($var); 
echo memory_get_usage(); 
?>

优化内存显示单位

目前缙哥哥使用的就是这个,毕竟 bytes 单位显得数值太大了!至于其他中文字,在其前后加上即可。

该函数默认返回的是占用内存的字节数,我们可以通过除以 1024 来以 KB 为单位,再除以 1024 以 MB 为单位。

<?php 
function convert($size){ 
$unit=array('B','KB','MB','GB','TB','PB'); 
return @round($size/pow(1024,($i=floor(log($size,1024)))),2).' '.$unit[$i]; 
} 
echo convert(memory_get_usage(true)); 
?>

自定义函数获取数组或变量值大小

<?php 
function array_size($arr) { 
ob_start(); 
print_r($arr); 
$mem = ob_get_contents(); 
ob_end_clean(); 
$mem = preg_replace("/\n +/", "", $mem); 
$mem = strlen($mem); 
return $mem; 
} 
$memEstimate = array_size($GLOBALS); 
?>

HTML页面显示指数

通过 functions 函数调用,在当前主题的 functions.php 文件添加:

//WordPress 站点显示页面加载时间、数据库查询次数及内存占用 - https://wpexp.cn/?p=74
function performance( $visible = false ) {
	$stat = sprintf( '本页生成数据库 %d 次查询,耗时 %.3f 秒,使用 %.2fMB 内存',
		get_num_queries(),
		timer_stop( 0, 3 ),
		memory_get_peak_usage() / 1024 / 1024
	);
	echo $visible ? $stat : "<!-- {$stat} -->" ;
}

然后可以在需要显示的地方,使用下面的代码进行调用:

<?php if(function_exists('performance')) performance(false) ;?>

performance参数false表示在页面前端不显示,只在HTML源码中可见。如果你想在页面中直接显示,可改为true即可。

如果你想在页脚加载,可以将下面的代码添加到functions.php该函数的下面(确保你的主题文件中包含wp_footer()):

add_action( 'wp_footer', 'performance', 20 );
赞(0) 打赏
转载请注明来源及链接:WPEXP » WordPress显示页面加载时间、数据库查询次数及内存占用
分享到: 更多 (0)

WordPress EXP - 分享10年WP建站经验,提供WordPress相关服务!

我要帮助我要托管

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏