<?php
$mysql_stat=mysql_stat($dbconnect);
$tot_count=preg_match_all('/([a-z ]+):\s*([0-9.]+)/i', $mysql_stat, $matches);
for ($i=0; $i<$tot_count; $i++) {
$info1=$matches[1][$i];
$info2=$matches[2][$i];
echo "$info1 ($info2)<br>";
}
/*
example output:
Uptime (13651)
Threads (1)
Questions (12910)
Slow queries (0)
Opens (314)
Flush tables (1)
Open tables (24)
Queries per second avg (0.945)
*/
?>
mysql_stat
(PHP 4 >= 4.3.0, PHP 5)
mysql_stat — Pobiera aktualny stan systemu
Opis
string mysql_stat
([ resource $identyfikator_połączenia
] )
mysql_stat() zwraca aktualny stan serwera.
Informacja: mysql_stat() w chwili obecnej zwraca jedynie czas pracy serwera, liczbę wątków, zapytań, otwartych tabel, oraz liczbę zapytań na sekundę. Pełną listę parametrów opisujących stan można uzyskać wydając komendę SQL: SHOW STATUS.
Przykład #1 przykład użycia mysql_stat()
<?php
$link = mysql_connect('localhost', 'uzytkownik', 'haslo');
printf("%s\n", mysql_stat($link));
?>
Powyższy przykład da następujący wynik:
Uptime: 5380 Threads: 1 Questions: 1321299 Slow queries: 1 Opens: 26 Flush tables: 1 Open tables: 17 Queries per second avg: 245.595
mysql_stat
Topper_
02-Sep-2008 08:51
02-Sep-2008 08:51
Enzo_01 at abv dot bg
31-May-2008 07:22
31-May-2008 07:22
<?php
// function that return stat elements into array
function mysql_stat_array($A=null) {
$status = explode(' ', mysql_stat());
foreach($status as $k=>$v) { $v=explode(':',$v,2); $status[$v[0]]=$v[1]; }
return (isset($status[$A])?$status[$A]:$status);
}
/*
example return:
Array ( [0] => Uptime: 385815 [1] => Threads: 1 [2] => Questions: 3515 [3] => Slow queries: 0 [4] => Opens: 32 [5] => Flush tables: 1 [6] => Open tables: 8 [7] => Queries per second avg: 0.009 [Uptime] => Array ( [0] => Uptime [1] => 385815 ) [Threads] => Array ( [0] => Threads [1] => 1 ) [Questions] => Array ( [0] => Questions [1] => 3515 ) [Slow queries] => Array ( [0] => Slow queries [1] => 0 ) [Opens] => Array ( [0] => Opens [1] => 32 ) [Flush tables] => Array ( [0] => Flush tables [1] => 1 ) [Open tables] => Array ( [0] => Open tables [1] => 8 ) [Queries per second avg] => Array ( [0] => Queries per second avg [1] => 0.009 ) )
*/
?>
09-Feb-2005 02:16
if you need the complete status as outputted by the "show status" command. Try this function.
<?
function mysql_status($db=NULL) {
if(!mysql_ping($db))
$db=mysql_connect("localhost","user","password");
$res=mysql_query("show status",$db);
while (list($key,$value)=mysql_fetch_array($res))
$sql[$key]=$value;
return $sql;
}
?>
