Solved

This page was executed in this time...

Posted on 2003-10-21
5
211 Views
Last Modified: 2008-02-26
I've been quite curious for a while on how sites like phpmyadmin it says things like "SQL-query executed in .0095 seconds" etc. and on PHP pages things like "Page rendered in .94 seconds".

Also, when pages say "Executed 8 queries, and a total of 980 queries".

Just wondering how to do simple little footer details that might spruce up a site footer.

Thanks in advance.
0
Comment
Question by:drakkarnoir
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
5 Comments
 
LVL 13

Expert Comment

by:lozloz
ID: 9595611
hi,

this should work

<?
$start = microtime();
$starta = explode(" ", $start);
$start = $starta[1] + $starta[0];
?>
your content here
<?
$end = microtime();
$enda = explode(" ", $end);
$end = $enda[1] + $end[0];
$overall = $end - $start;
print "Page rendered in " . $overall . " microseconds";
?>
0
 
LVL 1

Accepted Solution

by:
paStiSSet earned 250 total points
ID: 9595762
test this one (it works succesfully):

<?
function getmicrotime() {  
    list($usec, $sec) = explode(" ",microtime());  
    return ((float)$usec + (float)$sec);  
}
$start_time = getmicrotime();
?>

you can put this anywhere (header its a good idea)

<?
$end_time = getmicrotime();
$total_time = round($end_time - $start_time,3);  # the "3" returns: X.XXX, if put "2" this will return X.XX
echo "page generated in $total_time seconds";
?>

and this other one prints the x.xxx secons you talking about
0
 
LVL 2

Assisted Solution

by:ASCII_Man
ASCII_Man earned 250 total points
ID: 9597866
The option from paStiSSet will work a jiffy for page execution time. As for the number of SQL queries, I alias the mysql_query function for that:
----------------------------------
function query($sql){
      global $sql_num_queries, $sql_num_rows, $sql_num_fields, $sql_time;

      if(!isset($num_queries))
            $num_queries = 1;
      else
            $num_queries++;

      $start_query_time = getmicrotime();
      $query = mysql_query($sql);
      $end_query_time = getmicrotime();

      if(!isset($sql_num_rows))
            $sql_num_rows = mysql_num_rows($query);
      else
            $sql_num_rows += mysql_num_rows($query);
      if(!isset($sql_num_fields))
            $sql_num_fields = mysql_num_fields($query);
      else
            $sql_num_fields += mysql_num_fields($query);

      if(!isset($sql_time))
            $sql_time = ($end_query_time - $start_query_time);
      else
            $sql_time += ($end_query_time - $start_query_time);
}
----------------------------------

Then embed something more like this at the end of your page:
<?php
$total_page_time = round(getmicrotime() - $start_time, 3);
$total_sql_time = round($sql_time, 3);
echo <<<END
Statistics:
 Page generated in $total_page_time seconds
 Read $sql_num_fields within $sql_num_rows rows from $sql_num_queries queries in $total_sql_time seconds
END;
?>

You can add all sorts of useless but interisting server stats if you're bored enough - current number of visitors, bandwidth usage, server uptime, number of SETI data packets crunched...
0
 
LVL 13

Expert Comment

by:lozloz
ID: 9598796
ignore my script, its poo
0
 

Author Comment

by:drakkarnoir
ID: 9599150
Thank you so so much everybody for your input.

ASCII_Man, when you said I could calculate bandwith, how would I go about doing that? I've seen it done on cPanelX (like that Bandwith used this month) but how would I go about doing that via PHP?
0

Featured Post

Industry Leaders: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Things That Drive Us Nuts Have you noticed the use of the reCaptcha feature at EE and other web sites?  It wants you to read and retype something that looks like this. Insanity!  It's not EE's fault - that's just the way reCaptcha works.  But it i…
This article discusses how to create an extensible mechanism for linked drop downs.
The viewer will learn how to create and use a small PHP class to apply a watermark to an image. This video shows the viewer the setup for the PHP watermark as well as important coding language. Continue to Part 2 to learn the core code used in creat…
This tutorial will teach you the core code needed to finalize the addition of a watermark to your image. The viewer will use a small PHP class to learn and create a watermark.

707 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question